mirror of
				https://github.com/Mikaela/Limnoria.git
				synced 2025-10-22 20:17:29 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			60 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| So here's a general *programming* introduction to what the different modules do
 | |
| and what services they provide.  It is, however, only an introduction.  Read
 | |
| the modules themselves for a much more detailed explanation :)
 | |
| 
 | |
| fix.py: Just some stuff that needs to be done to make the bot work in some
 | |
|         older versions of Python (like 2.2 :))
 | |
| 
 | |
| cdb.py: A constant database library, translated from C (and my O'Caml version)
 | |
|         More information available at http://cr.yp.to/cdb.html .
 | |
| 
 | |
| ansi.py: Contains different ANSI color sequences.
 | |
|          Mostly used by the debug module.
 | |
| 
 | |
| debug.py: Functions for handling bugs and errors in a consistent manner
 | |
|           throughout the bot.
 | |
| 
 | |
| conf.py: The configuration file for the bot -- it sets a lot of variables that
 | |
|          other modules check for when they have questions about what they need
 | |
|          to do.
 | |
| 
 | |
| world.py: Just a dropping off place for some globals that need to be shared
 | |
|           among all the modules.  It's obviously not used *a lot*, but some
 | |
|           things seem to fit better here than anywhere else.
 | |
| 
 | |
| bot.py: The topmost module, the one that runs the bot.  It's also probably the
 | |
|         'dirtiest' module right now, but I'll add proper command line parsing
 | |
|         and clean it up a bit later.
 | |
| 
 | |
| privmsgs.py: The privmsg commands that are included by default in the bot.
 | |
|              It's probably most useful from a programming standpoint simply so
 | |
|              a new programmer can see what commands look like.
 | |
| 
 | |
| callbacks.py: A few basic callbacks providing significant functionality.  
 | |
|               You'll likely be inheriting from Privmsg quite a bit.
 | |
| 
 | |
| ircdb.py: The users and channels databases are here, as well as the
 | |
|           IrcUser and IrcChannel classes.  Look here when you want to
 | |
|           restrict a command to only certain users.
 | |
| 
 | |
| irclib.py: Provides the most important class in the irclib, Irc.  It represents
 | |
|            a connection to an IRC server, but it's entirely separate from the
 | |
|            network implementation.  It's connected to the network (or whatever
 | |
|            else drives it) by a "driver" module which uses its feedMsg/takeMsg
 | |
|            functions.
 | |
| 
 | |
| drivers.py: The baseclass (IrcDriver) for various drivers to drive irclib.Irc
 | |
|             classes.  Also, the driving mechanism.
 | |
| 
 | |
| asyncoreDrivers.py: The asyncore-based drivers for use with the bot.
 | |
| 
 | |
| ircmsgs.py: The IrcMsg class (get to know it :)) and various functions for
 | |
|             making the creation of IrcMsgs easier.
 | |
| 
 | |
| ircutils.py: Various utility functions for Irc -- read the module to see what
 | |
|              goodies are there :)
 | |
| 
 | |
| schedule.py: A schedule driver (which is automatically registered with the
 | |
|              drivers module) to run things at a particular time, or at
 | |
|              specified periods of time.
 | 
