File: riece-eval-ruby.el

package info (click to toggle)
xemacs21-packages 2009.02.17.dfsg.1-1
  • links: PTS
  • area: main
  • in suites: squeeze
  • size: 116,928 kB
  • ctags: 88,975
  • sloc: lisp: 1,232,060; ansic: 16,570; java: 13,514; xml: 6,477; sh: 4,611; makefile: 4,036; asm: 3,007; perl: 839; cpp: 500; ruby: 257; csh: 96; haskell: 93; awk: 49; python: 47
file content (91 lines) | stat: -rw-r--r-- 2,893 bytes parent folder | download | duplicates (10)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
;;; riece-eval-ruby.el --- evaluate input string as a Ruby program
;; Copyright (C) 1998-2005 Daiki Ueno

;; Author: Daiki Ueno <ueno@unixuser.org>
;; Created: 1998-09-28
;; Keywords: IRC, riece, Ruby

;; This file is part of Riece.

;; This program is free software; you can redistribute it and/or modify
;; it under the terms of the GNU General Public License as published by
;; the Free Software Foundation; either version 2, or (at your option)
;; any later version.

;; This program is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.	 See the
;; GNU General Public License for more details.

;; You should have received a copy of the GNU General Public License
;; along with GNU Emacs; see the file COPYING.  If not, write to the
;; Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
;; Boston, MA 02110-1301, USA.

;;; Commentary:

;; NOTE: This is an add-on module for Riece.

;;; Code:

(require 'riece-ruby)
(require 'riece-message)

(defgroup riece-eval-ruby nil
  "Evaluate input string as a Ruby program."
  :prefix "riece-"
  :group 'riece)

(defcustom riece-eval-ruby-prefix-regexp "^,ruby\\s-+"
  "Pattern of of the prefix for sending Ruby programs."
  :type 'string
  :group 'riece-eval-ruby)

(defconst riece-eval-ruby-description
  "Evaluate input string as a Ruby program.")

(defun riece-eval-ruby-exit-handler (name)
  (riece-ruby-inspect name)
  (let* ((data (copy-sequence (or riece-ruby-data "nil")))
	 (length (length data))
	 (index 0))
    (while (< index length)
      (if (eq (aref data index) ?\n)
	  (aset data index ? ))
      (setq index (1+ index)))
    (riece-send-string
     (format "NOTICE %s :%s\r\n"
	     (riece-identity-prefix
	      (riece-ruby-property name 'riece-eval-ruby-target))
	     data))
    (riece-display-message
     (riece-make-message (riece-current-nickname)
			 (riece-ruby-property name 'riece-eval-ruby-target)
			 data
			 'notice))))

(defun riece-eval-ruby-display-message-function (message)
  (if (and (get 'riece-eval-ruby 'riece-addon-enabled)
	   (riece-message-own-p message)
	   (string-match riece-eval-ruby-prefix-regexp
			 (riece-message-text message)))
      (let ((name (riece-ruby-execute
		   (substring (riece-message-text message)
			      (match-end 0)))))
	(riece-ruby-set-property name
				 'riece-eval-ruby-target
				 (riece-message-target message))
	(riece-ruby-set-exit-handler name
				     #'riece-eval-ruby-exit-handler))))

(defun riece-eval-ruby-insinuate ()
  (add-hook 'riece-after-display-message-functions
	    'riece-eval-ruby-display-message-function))

(defun riece-eval-ruby-uninstall ()
  (remove-hook 'riece-after-display-message-functions
	       'riece-eval-ruby-display-message-function))

(provide 'riece-eval-ruby)

;;; riece-eval-ruby.el ends here