2003-03-12 07:26:59 +01:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
|
|
|
###
|
|
|
|
# Copyright (c) 2002, Jeremiah Fincher
|
|
|
|
# All rights reserved.
|
|
|
|
#
|
|
|
|
# Redistribution and use in source and binary forms, with or without
|
|
|
|
# modification, are permitted provided that the following conditions are met:
|
|
|
|
#
|
|
|
|
# * Redistributions of source code must retain the above copyright notice,
|
|
|
|
# this list of conditions, and the following disclaimer.
|
|
|
|
# * Redistributions in binary form must reproduce the above copyright notice,
|
|
|
|
# this list of conditions, and the following disclaimer in the
|
|
|
|
# documentation and/or other materials provided with the distribution.
|
|
|
|
# * Neither the name of the author of this software nor the name of
|
|
|
|
# contributors to this software may be used to endorse or promote products
|
|
|
|
# derived from this software without specific prior written consent.
|
|
|
|
#
|
|
|
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
|
|
|
# AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
|
|
|
|
# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
|
|
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
|
|
|
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
|
|
|
# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
|
|
|
# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
|
|
|
# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
# POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
###
|
|
|
|
|
2003-10-04 14:53:09 +02:00
|
|
|
"""
|
|
|
|
Module for general worldly stuff, like global variables and whatnot.
|
|
|
|
"""
|
|
|
|
|
2003-11-25 09:38:19 +01:00
|
|
|
__revision__ = "$Id$"
|
|
|
|
|
2003-10-05 14:47:19 +02:00
|
|
|
import fix
|
2003-03-12 07:26:59 +01:00
|
|
|
|
|
|
|
import gc
|
2003-11-02 20:00:15 +01:00
|
|
|
import os
|
2004-01-15 12:54:41 +01:00
|
|
|
import sys
|
2003-11-02 20:00:15 +01:00
|
|
|
import sre
|
2003-03-12 07:26:59 +01:00
|
|
|
import time
|
|
|
|
import types
|
|
|
|
import atexit
|
2003-11-15 08:56:27 +01:00
|
|
|
import threading
|
2003-03-12 07:26:59 +01:00
|
|
|
|
2003-11-26 19:21:12 +01:00
|
|
|
import log
|
2003-03-12 07:26:59 +01:00
|
|
|
import conf
|
2004-01-15 13:55:19 +01:00
|
|
|
import drivers
|
2003-12-03 23:17:12 +01:00
|
|
|
import ircutils
|
2004-02-10 03:49:52 +01:00
|
|
|
import registry
|
2004-02-08 11:49:08 +01:00
|
|
|
import schedule
|
2003-03-12 07:26:59 +01:00
|
|
|
|
2003-12-03 23:17:12 +01:00
|
|
|
startedAt = time.time() # Just in case it doesn't get set later.
|
2003-04-08 09:23:56 +02:00
|
|
|
|
2004-02-12 01:49:41 +01:00
|
|
|
starting = False
|
|
|
|
|
2003-11-15 08:56:27 +01:00
|
|
|
mainThread = threading.currentThread()
|
2004-01-15 13:16:55 +01:00
|
|
|
assert 'MainThread' in repr(mainThread)
|
2003-11-15 08:56:27 +01:00
|
|
|
|
2003-11-05 09:32:26 +01:00
|
|
|
threadsSpawned = 1 # Starts at one for the initial "thread."
|
2003-08-29 09:08:03 +02:00
|
|
|
commandsProcessed = 0
|
2003-03-12 07:26:59 +01:00
|
|
|
|
2003-12-03 23:17:12 +01:00
|
|
|
ircs = [] # A list of all the IRCs.
|
2003-03-12 07:26:59 +01:00
|
|
|
|
2003-11-14 23:10:57 +01:00
|
|
|
flushers = [] # A periodic function will flush all these.
|
2003-03-12 07:26:59 +01:00
|
|
|
|
2004-02-03 23:58:54 +01:00
|
|
|
registryFilename = None
|
|
|
|
|
2003-03-12 07:26:59 +01:00
|
|
|
def flush():
|
2003-10-04 14:53:09 +02:00
|
|
|
"""Flushes all the registered flushers."""
|
2003-03-12 07:26:59 +01:00
|
|
|
for f in flushers:
|
|
|
|
f()
|
|
|
|
|
2004-01-15 13:16:55 +01:00
|
|
|
def upkeep():
|
2003-10-04 14:53:09 +02:00
|
|
|
"""Does upkeep (like flushing, garbage collection, etc.)"""
|
2004-01-15 12:54:41 +01:00
|
|
|
sys.exc_clear() # Just in case, let's clear the exception info.
|
2003-09-03 19:27:08 +02:00
|
|
|
collected = gc.collect()
|
2003-03-26 03:31:13 +01:00
|
|
|
if os.name == 'nt':
|
2003-10-09 19:24:28 +02:00
|
|
|
try:
|
2003-11-15 08:56:27 +01:00
|
|
|
import msvcrt
|
2003-10-09 19:24:28 +02:00
|
|
|
msvcrt.heapmin()
|
2003-11-15 08:56:27 +01:00
|
|
|
except ImportError:
|
|
|
|
pass
|
2003-10-09 19:24:28 +02:00
|
|
|
except IOError: # Win98 sux0rs!
|
|
|
|
pass
|
2003-03-12 07:26:59 +01:00
|
|
|
if gc.garbage:
|
2003-11-26 19:21:12 +01:00
|
|
|
log.warning('Uncollectable garbage: %s', gc.garbage)
|
2004-02-12 01:49:41 +01:00
|
|
|
flushed = conf.supybot.flush() and not starting
|
2004-02-03 23:58:54 +01:00
|
|
|
if flushed:
|
2003-03-12 07:26:59 +01:00
|
|
|
flush()
|
2004-02-10 03:49:52 +01:00
|
|
|
# This is so registry._cache gets filled.
|
|
|
|
if registryFilename is not None:
|
|
|
|
registry.open(registryFilename)
|
2003-12-03 23:31:33 +01:00
|
|
|
if not dying:
|
|
|
|
log.debug('Regexp cache size: %s', len(sre._cache))
|
|
|
|
log.debug('Pattern cache size: %s'%len(ircutils._patternCache))
|
2003-12-16 21:36:43 +01:00
|
|
|
log.debug('HostmaskPatternEqual cache size: %s' %
|
|
|
|
len(ircutils._hostmaskPatternEqualCache))
|
2004-02-03 23:58:54 +01:00
|
|
|
timestamp = log.timestamp()
|
|
|
|
if flushed:
|
|
|
|
log.info('%s Flushers flushed and garbage collected.', timestamp)
|
|
|
|
else:
|
|
|
|
log.info('%s Garbage collected.', timestamp)
|
2004-02-08 11:49:08 +01:00
|
|
|
schedule.addEvent(upkeep, time.time() + conf.supybot.upkeepInterval())
|
2003-09-03 19:27:08 +02:00
|
|
|
return collected
|
2003-03-12 07:26:59 +01:00
|
|
|
|
2004-01-15 13:55:19 +01:00
|
|
|
def makeDriversDie():
|
|
|
|
"""Kills drivers."""
|
|
|
|
log.info('Killing Driver objects.')
|
|
|
|
for driver in drivers._drivers.itervalues():
|
|
|
|
driver.die()
|
|
|
|
|
2003-11-14 23:10:57 +01:00
|
|
|
def makeIrcsDie():
|
2003-12-03 23:17:12 +01:00
|
|
|
"""Kills Ircs."""
|
2003-12-16 22:06:20 +01:00
|
|
|
log.info('Killing Irc objects.')
|
2003-11-14 23:10:57 +01:00
|
|
|
for irc in ircs[:]:
|
|
|
|
irc.die()
|
2003-09-12 09:48:01 +02:00
|
|
|
|
2003-11-14 23:10:57 +01:00
|
|
|
def startDying():
|
2003-12-03 23:17:12 +01:00
|
|
|
"""Starts dying."""
|
2003-12-16 22:06:20 +01:00
|
|
|
log.info('Shutdown initiated.')
|
2003-11-14 23:10:57 +01:00
|
|
|
global dying
|
|
|
|
dying = True
|
2003-03-27 07:06:56 +01:00
|
|
|
|
2003-12-16 22:06:20 +01:00
|
|
|
def finished():
|
|
|
|
log.info('Shutdown complete.')
|
|
|
|
|
|
|
|
atexit.register(finished)
|
2003-11-14 23:10:57 +01:00
|
|
|
atexit.register(upkeep)
|
|
|
|
atexit.register(makeIrcsDie)
|
2004-01-15 13:55:19 +01:00
|
|
|
atexit.register(makeDriversDie)
|
2003-11-14 23:10:57 +01:00
|
|
|
atexit.register(startDying)
|
|
|
|
|
|
|
|
##################################################
|
|
|
|
##################################################
|
|
|
|
##################################################
|
|
|
|
## Don't even *think* about messing with these. ##
|
|
|
|
##################################################
|
|
|
|
##################################################
|
|
|
|
##################################################
|
2003-04-08 09:23:56 +02:00
|
|
|
testing = False
|
2003-11-14 23:10:57 +01:00
|
|
|
dying = False
|
2003-03-26 00:42:37 +01:00
|
|
|
|
2004-01-02 23:29:03 +01:00
|
|
|
|
2003-03-24 09:41:19 +01:00
|
|
|
# vim:set shiftwidth=4 tabstop=8 expandtab textwidth=78:
|