This repository has been archived by the owner on Sep 8, 2021. It is now read-only.
forked from myano/jenni
-
Notifications
You must be signed in to change notification settings - Fork 2
/
CREATE
374 lines (285 loc) · 17.8 KB
/
CREATE
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
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
#==============================================================================#
#====================================PHENNY====================================#
#==============================================================================#
This file was created by Michael S. Yanovich from The Ohio State University Open
Source Club <http://opensource.cse.ohio-state.edu/~yanovich/>
Revision 0.6 (draft) created February 24, 2010
I) BASICS
Creating a jenney module is simple and fun! This document is laid out in
the following format;
I) Basics
II) How To Get Started
III) Create A Module
IV) Functions in a Module
V) Commands, Rules, Events, and Priorities (Oh my!)
VI) Documenting Your Module
VII) Built-In Functions, Constants, and Variables
IIX) Further Reading
IX) Author's Comments
II) HOW TO GET STARTED
Before you can get started you need to have a fork of jenney on your co_
mptuer. You can obtain a copy of jenney at <http://inamidst.com/jenney/>
You can also obtain a different fork (if you wish) from The Ohio State
University Open Source Club: <http://opensource.cse.ohio-state.edu/git/>
Regardless of which fork you have you can create modules for either or.
I won't go through the instructions of installing jenney since those are
already included in both jenney packages.
Also I'm assuming you now the complete basics about Phenny, (ie: what
language she is written in; how to set her up; how to config her, etc.)
III) CREATE A MODULE
The very first step in creating a module is to open up your text editor
of choice and save the file in your jenney/modules folder. (Assuming you
haven't changed the default location of where modules will be placed for
jenney.) As far as I am aware there really isn't a convention already in
place for how to name your files. The way I recommend doing it is to
summarize what the goal of the whole file will accomplish or does. Later
one you will see that if you have a collection of functions you might
want to name the file for what the collection collectively does or
accomplishes.
Once you have saved your file you now have created a file that jenney
can "reload" in a chat room with the admin commands. So for example lets
say you have created a file hello_world.py without restarting jenney you
can simply go into a chat room she is sitting in and run the command
"jenney: reload hello_world" but change "jenney" to whatever her nick is
on the server you are running her on.
NOTICE: When you reload a module in the chat room or via private message
you do NOT specify the extension.
FOLLOW ALONG: Now go create a "hello_world.py" file in your modules fol_
der and then reload it in your chat room. If it were successful you will
see a message along these lines:
nick: <module 'hello_world.py' from '/home/nick/jenney/modules/h
ello_world.py'> (version: 2010-02-18 02:00:00)
Now what this all means is that it has successfully loaded the module
from your path where jenney is located at. The version is the time and
date that the file was last modify. The 'nick' mentioned above is your
irc nick that you are using to administer jenney.
NOTE: You can use anything that is included in your current library of
Python that is locally installed on the computer in which you are runni_
ng jenney. Which means you can use modules, such as MATH, PICKLE,
SQLITE3, etc.. if they are normally available locally in your Python
PATH directories.
IV) FUNCTIONS IN A MODULE
Now if you have ever done any programming before, especially in python
then you'll probably know what a function is, if not I would recommend
you pick up a book about programming (or try several great e-books) to
learn about the wonderful world of programming.
Now the way functions work in Python is like this:
def function_name(myvar1, myvar2):
"def" is how you declare that this is a function and obviously "function
_name" is the name of the function. Please try to keep your function
names descriptive and short so if you share your code it will be easy to
understand by fellow programmers.
Also "myvar1" and "myvar2" are the incoming variables into this functio_
n. However, for most of the functions you'll be creating with jenney it
will look like this:
def helloworld(jenney, input):
Here you need to always (unless you know what you are doing) include
"jenney" and "input." "jenney" brings into scope the variables and
accessor you'll need in order for jenney to do what you want her to do.
The "input" variable is what listens and brings into scope certain vari_
ables that are usually used to trigger the function. You'll see in the
next section on how to 'trigger' a function. I'll also show an example
of a working module you can use to test.
V) COMMANDS, RULES, AND PRIORITIES (OH MY!)
Ok this is where, in my opinion, the most fun starts. Using commands you
can get jenney to actually compute a given function and "say" things in
the irc chat room. I'm going to display an example of a fully working
module and I'll break down the pieces of what each thing does so you'll
better understand what exactly is going on.
def helloworld(jenney, input):
jenney.say("Hello world!")
helloworld.commands = ['hello']
helloworld.priority = 'medium'
Figure 5-1
If you saved the above code into a hello_world.py file in your modules
directory of jenney and then loaded as I mentioned above then why type
.hello in the chat room she is currently sitting in your jenney bot sho_
uld she should say "Hello world!" in the chat room.
The first important thing (and new thing) is the jenney.say command.
'jenney.say' will basically take any string or python variable that can
be printed natively to stdout into the chat room. You can even have her
say variables that of type string, int, etc.. (eg: jenney.say(mystr) )
The key thing about this example is helloworld.commands = ['hello']
This basically tells jenney to keep an eye out for anything that begins
with a ".hello" regardless of what is following it. You could try typing
.hello 125
Figure 5-2
and you'll still get your nice message of "Hello world!" I'll show later
where you can actually pass those extra stuff into your functions and
actually use them to manipulate data.
Another key thing to note about figure 5-1 is the last line. This isn't
required for every function but it helps jenney keep things in order
when a bunch of things are going on. This is really handy when she is
being used by several different people at the same time. Basically
inside jenney's guts she runs all commands in the following order based
on priority. High, Medium, then low. All high commands will execute bef_
ore all medium commands, and all medium commands will execute before all
low commands. But this order is only done when there are commands being
requested to be executed. Unless you build a function that is of utmost
importance to the operation of jenney, you'll most likely want to give
the function a medium priority. If you are doing something really obscu_
re then you can get away with a low priority.
RULES
I've saved the best for last!
Rules can be tricky, because they aren't as easy as "commands." Because
they differ in the way they offer more flexibility and you can monitor
more messages for lines in a chatroom than with commands. Let's say you
built a function that logs the current channel you are in. But you don't
know how to have jenney compute your function for every line in the room
you can do this using rules.
A key concept to remember is that you never want to have a function have
both a "command" and a "rule" defined because there could be an example
where a certain phrase someone enters could trigger the function twice
so your output or even data you may be manipulating may be done more ti_
mes than you want it to be done.
The most powerful way to use rules are to use them in the form of regul_
ar expressions. Using regular expressions you actually have more power
of what "types" of things you are looking for in each line in the room.
For every message in a chat room on irc that is sent that line is check_
ed against your rule. If your rule would apply to a line, then your fun_
ction is called, but if your rule doesn't match a line in a room it sil_
ently fails. (There is no error message displayed, your function simply
does not execute.)
Here is a great example of a "rule" in action.
def interjection(jenney, input):
jenney.say(input.nick + '!')
interjection.rule = r'$nickname!'
interjection.priority = 'high'
interjection.thread = False
Figure 5-3
There a few new things in this example. First off is the use of a 'rule'
to call the function. The r' means that the string of code you enter is
to be interpreted as a raw string. In Python this means that the escape
sequence are different. This makes it easier for you to enter regular
expressions without having to double up on some of your characters.
Another thing to note, the use of $nickname, is a global variable built
inside jenney that refers to whatever nickname that you have set for
jenney in your configuration file. Therefore the regular expression rule
is keeping an eye out for anyone who types just 'jenney!' in the channel
where jenney could be the nick of your clone of jenney.
Another thing to point out is the use of interjection.thread = False.
This is a cool feature the creator (sbp) has added into jenney.
Out of the box, jenney is multi-threaded so technically it can use two
cores on a dual-core machine. But the best part is, you can specifically
tell a given function not to be "multi-threaded." There are numerous
occasions where this may be necessary.
The best tip I can give regarding rules is to take a look at the modules
that come with jenney out of the box specifically the ping.py and if you
are using the jenney_osu fork the resp.py module.
EVENTS
Events are basically 'triggers' that will execute your function when the
specified event that you listed occurs. A perfect example is to have a
function execute every time someone joins a channel.
def message_join(jenney, input):
...
message_join.event = 'JOIN'
Figure 5 - 4
You can use either JOIN, PART, NICK, and PRIVMSG. JOIN watches for join
commands from the IRC server. PART looks for people leaving a channel
that jenney is currently in. NICK looks for people in the room that have
changed their nicks, and PRIVMSG is the default and it looks for any
message sent to the channel or to jenney.
VI) DOCUMENTING YOUR MODULE
This is probably the most important part of creating a module. This all_
ows you to make your module easy to understand to other people and it
also allows you to create examples for other people to see how to use
your modules in the chat room!
First off the first 7 lines of your document should be used to create a
description based off of how the author started it. Here is an example
of how to start off your brand new module!
"""
quote.py - Phenny Quote Module
Copyright 2010, Michael Yanovich, opensource.osu.edu/~yanovich/
Licensed under the Eiffel Forum License 2.
http://inamidst.com/jenney/
"""
Figure 6-1
Now you don't necessarily have to do everything exactly the same as I
and sbp have done but it is highly recommend, especially if you would
like to create your very own fork of the jenney project.
The second line right after the three double quotes, represents the name
of the file and a brief title of the file. Then the next line identifies
the copyright, if you choose to have one, then your name and possibly a
url to your site. The fourth line represents the type of license you wo_
uld like to license your module as. Phenny, as a whole, is licensed und_
er the Eiffel Forum License 2. After reading up on it I prefer to licen_
se my own modules under this. You make choose any license you would like
for the modules that you create.
Then the final line before the last three double quotes, is a URL to the
original creator's site. I would highly recommend keeping this there,
because the author (sbp) deserves as much credit as he does for creating
jenney completely from scratch. Plus it is good to give credit in the
open source community!
DOCUMENTING YOUR FUNCTIONS
This part is in my opinion very important, especially if you have sever_
al functions in your module file. You should add a doctype to your main
function. To do this you simply go to the line right below the declarat_
ion of your function and using three double quotes ( """ ) type in a
brief description of what this function does.
For example:
def addpoint(jenney, input):
""".addpoint <nick> - Adds 1 point to the score system
for <nick>."""
...
Figure 6-2
A nice but not necessary thing to include in your functions that you
want to present to the world is the .example property. This displays
an example you set, when someone messages jenney "help command."
For example:
def join(jenney, input):
...
join.example = '.join #example or .join #example key'
Figure 6-3
Here in Figure 6-3, when a user messages jenney, "help join" jenney will
respond saying ".join #example or .join #example key"
Next at the very end of your document you are going to want to add the
following lines of code. This is a small python hack, if you will, that
prevents some weird things from happening if you tried to run the module
directly inside of python and not inside jenney. I won't get into the
specifics as they can get really confusing if you don't completely unde_
rstand Python.
if __name__ == _main_:
print __doc__.strip()
Figure 6-4
VII) BUILT-IN FUNCTIONS, CONSTANTS, AND VARIABLES
Here is an incomplete and growing list of built-in functions that jenney
has access to that you wouldn't normally find in other Python programs.
This section is expected to grow with time.
jenney.nick
will return the string that represents the current nick of
jenney running, according to your configuration file.
jenney.say(myvar)
will print the contents of the variable "myvar" to the chatroom
jenney.write(['JOIN'], channel)
this makes jenney said a JOIN command to the IRC server to the
join specified channel.
input.admin
is a variable of the type of a list, that contains the nicks
mentioned in the user configuration file under "admin"
input.group()
basically it takes everything after the command that was issued
for the function and throws it into this variable. However, it
really does a dump of the python function match.group. Type of
variable unknown.
input.nick
contains the nick of the person that sent a message that trigge_
red the function.
if input.sender.startswith('#')
this checks to see if any message sent to jenney is from a chat
room. This if-statement yields true for all messages sent in any
chat room. The only time this if-statement yields a false is
when jenney receives a private message.
f.rule = r'(.*)'
this rule will trigger the function 'f' every time a message is
sent to the channel.
IIX) FURTHER READING
If you are new to Python and have programming experience in some other
language I would highly recommend the e-book Dive Into Python. It can be
found for free at <http://diveintopython.org/>
Regardless if you know Python or are comfortable with Python you should
still read up on Python. I am always learning new and fantastic things
that one can do with Python. It is truly an amazing language!
IX) AUTHOR'S COMMENTS
If you have any comments or questions, please don't hesitate to ask! My
contact information is <[email protected]> You can also contact
Sean B. Palmer via his website <http://inamidst.com/>