only reload modules when necessary (instead of all when one changed), move commandprefix into sieve
This commit is contained in:
parent
b88b107343
commit
13bd7fd3fe
27
bot.py
27
bot.py
|
@ -29,28 +29,34 @@ class Bot(object):
|
||||||
bot = Bot(nick, channel, network)
|
bot = Bot(nick, channel, network)
|
||||||
|
|
||||||
print 'Loading plugins'
|
print 'Loading plugins'
|
||||||
typs = '|'.join('command filter event'.split())
|
|
||||||
magic_re = re.compile(r'^\s*#!(%s)(?:: +(\S+) *(\S.*)?)?\s*$' % typs)
|
|
||||||
|
|
||||||
def reload_plugins(mtime=[0]):
|
plugin_mtimes = {}
|
||||||
new_mtime = os.stat('plugins')
|
|
||||||
if new_mtime == mtime[0]:
|
|
||||||
return
|
|
||||||
|
|
||||||
|
def reload_plugins():
|
||||||
|
|
||||||
|
if not hasattr(bot, 'plugs'):
|
||||||
bot.plugs = collections.defaultdict(lambda: [])
|
bot.plugs = collections.defaultdict(lambda: [])
|
||||||
|
|
||||||
for filename in glob.glob("plugins/*.py"):
|
for filename in glob.glob("core/*.py") + glob.glob("plugins/*.py"):
|
||||||
|
mtime = os.stat(filename).st_mtime
|
||||||
|
if mtime != plugin_mtimes.get(filename):
|
||||||
shortname = os.path.splitext(os.path.basename(filename))[0]
|
shortname = os.path.splitext(os.path.basename(filename))[0]
|
||||||
try:
|
try:
|
||||||
plugin = imp.load_source(shortname, filename)
|
plugin = imp.load_source(shortname, filename)
|
||||||
|
except Exception, e:
|
||||||
|
print ' error:', e
|
||||||
|
continue
|
||||||
|
|
||||||
|
# remove plugins already loaded from this filename
|
||||||
|
for name, data in bot.plugs.iteritems():
|
||||||
|
bot.plugs[name] = filter(lambda x: x[0][0] != filename, data)
|
||||||
|
|
||||||
for obj in vars(plugin).itervalues():
|
for obj in vars(plugin).itervalues():
|
||||||
if hasattr(obj, '_skybot_hook'): #check for magic
|
if hasattr(obj, '_skybot_hook'): #check for magic
|
||||||
for type, data in obj._skybot_hook:
|
for type, data in obj._skybot_hook:
|
||||||
bot.plugs[type] += [data]
|
bot.plugs[type] += [data]
|
||||||
except Exception, e:
|
|
||||||
print ' error:', e
|
|
||||||
|
|
||||||
mtime[0] = new_mtime
|
plugin_mtimes[filename] = mtime
|
||||||
|
|
||||||
reload_plugins()
|
reload_plugins()
|
||||||
|
|
||||||
|
@ -69,7 +75,6 @@ print
|
||||||
print 'Connecting to IRC'
|
print 'Connecting to IRC'
|
||||||
bot.irc = irc.irc(network, nick)
|
bot.irc = irc.irc(network, nick)
|
||||||
bot.irc.join(channel)
|
bot.irc.join(channel)
|
||||||
bot.commandprefix = r'^(?:[.!]|'+nick+r'[:,]*\s*)'
|
|
||||||
bot.persist_dir = os.path.abspath('persist')
|
bot.persist_dir = os.path.abspath('persist')
|
||||||
|
|
||||||
print 'Running main loop'
|
print 'Running main loop'
|
||||||
|
|
|
@ -16,7 +16,7 @@ def sieve_suite(bot, input, func, args):
|
||||||
args.setdefault('prefix', True)
|
args.setdefault('prefix', True)
|
||||||
|
|
||||||
if args.get('prefix', True):
|
if args.get('prefix', True):
|
||||||
hook = bot.commandprefix + hook
|
hook = r'^(?:[.!]|' + bot.nick +r'[:,]*\s*)' + hook
|
||||||
|
|
||||||
if input.command == 'INVITE':
|
if input.command == 'INVITE':
|
||||||
print func, hook
|
print func, hook
|
||||||
|
|
Loading…
Reference in New Issue