#MUDPyE - (M)ulti-(U)ser (D)imension (Py)thon (E)ngine #Copyright (C) 2005 Corey Staten #This program is free software; you can redistribute it and/or #modify it under the terms of the GNU General Public License #as published by the Free Software Foundation; either version 2 #of the License, or (at your option) any later version. #This program is distributed in the hope that it will be useful, #but WITHOUT ANY WARRANTY; without even the implied warranty of #MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #GNU General Public License for more details. #You should have received a copy of the GNU General Public License #along with this program; if not, write to the Free Software #Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. #Send feedback/questions to MUDPyE@gmail.com import gzip import logging import logging.config import os.path import time from mpmudobject import Ex loggers = ["engine", "engine.db", "engine.server", "engine.fileloader", "mud", "mud.scripterror"] mudWorld = None class ZipLogHandler(logging.Handler): def __init__(self, fileName, maxSize, zipDir): logging.Handler.__init__(self) self.fileName = os.path.normpath(fileName) self.maxSize = maxSize self.zipDir = zipDir self.fileObj = file(fileName, "a") print "Successfully opened logfile [%s]." % fileName def emit(self, record): self.fileObj.write("".join((self.format(record), "\n"))) if self.fileObj.tell() >= self.maxSize: self.fileObj.close() zipFileName = ("%s %s.gz" % (time.asctime(), os.path.split(self.fileName)[1])) zipFilePath = os.path.join(self.zipDir, zipFileName).replace(":", "#") try: zipFileObj = file(zipFilePath, "wb") zipFileObj = gzip.GzipFile(zipFileName, "wb", 9, zipFileObj) logFileObj = file(self.fileName, "r") buffer = logFileObj.read(8192) while len(buffer): zipFileObj.write(buffer) buffer = logFileObj.read(8192) zipFileObj.close() logFileObj.close() except IOError: print "Error saving zipped log file." self.fileObj = file(self.fileName, "w") class MudHandler(logging.Handler): def __init__(self): logging.Handler.__init__(self) self.ready = True def emit(self, record): print self.format(record) #Temporarily disable self from logging, since some of these functions may emit logs. if self.ready: self.ready = False if mudWorld.__dict__.has_key("objDB") and mudWorld.objDB.HasObj(mudWorld.loggingObjID): logObj = mudWorld.objDB.GetObjRef(mudWorld.loggingObjID) Ex(logObj, "_Sys_LogString", self.format(record)) self.ready = True def InitLogging(mudWorld, fileName): exec "import mplog" in logging.__dict__ globals()["mudWorld"] = mudWorld logging.config.fileConfig(fileName) loggerDict = {} map(loggerDict.setdefault, loggers, [logging.getLogger(logger) for logger in loggers]) return loggerDict