-
Notifications
You must be signed in to change notification settings - Fork 2
/
README
254 lines (185 loc) · 9.3 KB
/
README
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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
XChat-Ruby Plugin v. 1.2
http://sourceforge.net/projects/xchat-ruby/
Jamis Buck <jgb3@email.byu.edu>
25 April 2007
===============================
This is a plugin for XChat2 (http://www.xchat.org) which allows you to use
plugins written in the Ruby scripting language (http://www.ruby-lang.org).
Installation and Configuration
------------------------------
See the INSTALL file.
Usage
-----
Once the plugin has been loaded, you can interact with it using the following
commands:
/rb help -- displays a list of available /rb commands
/rb load <filename> -- load (and execute) a ruby script/plugin
/rb unload <filename> -- unload the given ruby script/plugin
/rb list -- show all loaded ruby scripts/plugins
/rb commands -- show all available ruby-based commands
/rb exec <code> -- execute ruby code immediately
/rb about -- display copyright and credits info about the plugin
Additionally, the XChat-Ruby plugin extends the /load and /unload commands, so that if
you specify a file with a '.rb' extension, it will load (or unload) it with the
XChat-Ruby plugin.
Plugin Documentation
--------------------
If you are a Ruby programmer and would like to use this plugin to write your
own plugins in Ruby, this section will attempt to document the XChat/Ruby
API and how to use it. You should also refer to the XChat C API
(http://www.xchat.org/docs/plugin20.html), since it will describe the
API functions and how they work in greater detail. Also, the plugins in
the samples directory will be helpful in learning how to write your own
plugins.
Typically, creating a ruby plugin involves creating a class that inherits
from XChatRubyPlugin, registering the necessary hooks in the new class's
initialize method, and then defining the hooks and auxiliary methods. At
the very end, instantiate the class; this will start your plugin.
All of these classes are in the XChatRuby module, which may be included
in your plugin source for convenience.
class XChatRubyEnvironment
--------------------------
You will rarely need to access the class directly, but there are a few
(singleton) methods of it that you may find useful.
XChatRubyEnvironment.load_plugin( file )
Loads the given (Ruby) source file as a Ruby plugin. The 'file'
parameter must either be an absolute path, or refer to a file
in one of the paths of the Ruby environment's $LOAD_PATH array.
XChatRubyEnvironment.unload_plugin( file )
Unloads the given (Ruby) source file as a Ruby plugin. The 'file'
parameter must be exactly the same as the name given when the
plugin was loaded.
XChatRubyEnvironment.remove_hooks_for( requester )
This will remove all registered hooks for a given plugin (requester).
class XChatRubyPlugin
---------------------
The XChatRubyPlugin class is the interface for the XChat API. You should
inherit your plugin classes from this class.
All of the 'hook' methods that require a priority should use one of the
XCHAT_PRI_xxx constants for that parameter. Likewise, any hook callback
should return one of the XCHAT_EAT_xxx constants. All of the hook methods
return an opaque XChatHook object, which may be used with the
unhook() function.
hook_command( name, priority, hook, help, data )
Registers a command hook, with the given name and help text. The 'hook'
parameter must be a Method object (as returned by the method() function)
and should accept three parameters:
hook_fn( words, words_eol, data )
where 'words' and 'words_eol' are identical to the same parameters as
described in the XChat plugin API.
hook_print( name, priority, hook, data )
Registers a callback to be called when the named print even occurs. The
hook parameter must be a Method object and should accept two parameters:
hook_fn( words, data )
hook_server( name, priority, hook, data )
Registers a callback to be called when the named server event is recieved.
The hook parameter should be a Method object and should accept three
parameters:
hook_fn( words, words_eol, data )
hook_timer( timeout, hook, data )
Registers a timer, which will call the given hook every 'timeout' milliseconds
until it is removed (with unhook()). The hook should be a Method object and
should accept one parameter:
hook_fn( data )
unhook( hook_id )
Unregisters the previously-registered hook with the given 'id'. The
hook_id parameter should be a XChatHook object that was returned by a
prior call to one of the hook_xxx methods.
Note for print and puts:
The output is only visible to you. Use /say to post messages to the channel.
print( text )
Prints the given text to the current context (currently active channel
or server tab/window).
print( text, channel )
Prints the given text to the first matching channel, or the current
context if no match.
print( text, server, nil )
Prints the given text to the first channel or server context of the
given server, or the current context if no match.
print( text, server, channel )
Prints the given text to the channel with matching channel and server,
or the current context if no match.
puts( text )
puts( text, channel )
puts( text, server, channel )
Just like the "print" functions, but also appends a newline.
print_fmt( text )
print_fmt( text, channel )
print_fmt( text, server, channel )
Just like the "print" functions, but also processes 'text' through the
XChatText.format method (see below).
puts_fmt( text )
puts_fmt( text, channel )
puts_fmt( text, server, channel )
Just like the "puts" functions, but also processes 'text' through the
XChatText.format method (see below).
command( command )
Has XChat process the given command (without the '/').
find_context( channel )
find_context( server, channel )
Returns the context with matching server and channel, or nil if not
found.
If server or channel is nil, the first match of the non-nil argument is
returned.
The server name is what is listed in the XChat Network List, including
spaces.
get_context
Returns the current context.
set_context( context )
Sets the current context to context.
get_info( id )
Returns either nil (if the given id doesn't match any known information
parameter), or a string or integer defining the named information parameter.
get_prefs( name )
Returns the named preference item, or nil if the item doesn't exist.
nickcmp( s1, s2 )
Compares the two nicknames (as strcasecmp()), taking into account servers
and so forth.
emit_print( event, ... )
Emits the named print event with the given parameters.
XChat-Ruby 1.2 only supports 16 events.
format( text )
The 'text' parameter may contain formatting codes to define where
text should be bolded, inverted (or underlined), or where the color
should be changed. The formatted text is returned.
Formatting codes are contained in ![...] delimiters. Valid codes
are:
b -- toggle bold
u -- toggle underline
r -- toggle reverse text
i -- toggle italics
o -- turn off all font color and attributes
| -- (the pipe character) -- puts all preceding text in the gutter
c -- reset colors to defaults
cn -- set foreground color to 'n' (see below)
cn,m -- set foreground color to 'n' and background color to 'm'
For the valid 'n' and 'm' color values, you may specify a number
(corresponding to the valid mIRC color indices), or the name of
a color in parentheses.
For the '|' (pipe) code, the preceding text will only be placed in the
gutter if the text is printed (ie, print or puts). If the formatted text
is sent through an IRC command (ie, /msg), the '|' code is ignored.
For example:
format( "some ![c(red)b]RED![bc] text" )
This would format the word RED, with a red foreground, in bold.
Valid color names are white, black, blue, green, red, brown, purple,
orange, yellow, ltgreen, teal, ltcyan, ltblue, pink, grey, and ltgrey.
How do you output text containing '!['?
Just format the formatting and output the text in between the formatting
directly.
For example:
format( "![b]") + "some ![c(red)b]RED![bc] text" + format( "![b]" )
This formats the string "some ![c(red)b]RED![bc] text" in bold.
class XChatRubyList
-------------------
This class is the interface for the XChat list API. Each list request instantiates
a new XChatRubyList.
XChatRubyList.new( name )
Creates new list of the given name.
next
Moves to the next item in the list. Returns 0 if the end of the list has been
reached, or 1 if it has moved to a valid item.
str( name )
Returns the given named field of the current record as a string.
int( name )
Returns the given named field of the current record as an integer.