92 lines
2.3 KiB
Python
92 lines
2.3 KiB
Python
|
"""Logger module: contains the logger class which creates and writes
|
||
|
data to log files on disk"""
|
||
|
|
||
|
import time
|
||
|
import math
|
||
|
|
||
|
class Logger:
|
||
|
def __init__(self, fileName="log"):
|
||
|
"""
|
||
|
Logger constructor
|
||
|
"""
|
||
|
self.__timeStamp = 1
|
||
|
self.__startTime = 0.0
|
||
|
self.__logFile = None
|
||
|
self.__logFileName = fileName
|
||
|
|
||
|
def setTimeStamp(self, bool):
|
||
|
"""
|
||
|
Toggle time stamp printing with log entries on and off
|
||
|
"""
|
||
|
self.__timeStamp = bool
|
||
|
|
||
|
def getTimeStamp(self):
|
||
|
"""
|
||
|
Return whether or not we are printing time stamps with log entries
|
||
|
"""
|
||
|
return(self.__timeStamp)
|
||
|
|
||
|
|
||
|
# logging control
|
||
|
|
||
|
def resetStartTime(self):
|
||
|
"""
|
||
|
Reset the start time of the log file for time stamps
|
||
|
"""
|
||
|
self.__startTime = time.time()
|
||
|
|
||
|
def log(self, entryString):
|
||
|
"""log(self, string)
|
||
|
Print the given string to the log file"""
|
||
|
if (self.__logFile == None):
|
||
|
self.__openLogFile()
|
||
|
if (self.__timeStamp):
|
||
|
self.__logFile.write(self.__getTimeStamp())
|
||
|
self.__logFile.write(entryString + '\n')
|
||
|
|
||
|
|
||
|
# logging functions
|
||
|
|
||
|
def __openLogFile(self):
|
||
|
"""
|
||
|
Open a file for logging error/warning messages
|
||
|
"""
|
||
|
self.resetStartTime()
|
||
|
t = time.localtime(self.__startTime)
|
||
|
st = time.strftime("%m-%d-%Y-%H-%M-%S", t)
|
||
|
logFileName = self.__logFileName + "." + st
|
||
|
self.__logFile = open(logFileName, "w")
|
||
|
|
||
|
def __closeLogFile(self):
|
||
|
"""
|
||
|
Close the error/warning output file
|
||
|
"""
|
||
|
if (self.__logFile != None):
|
||
|
self.__logFile.close()
|
||
|
|
||
|
def __getTimeStamp(self):
|
||
|
"""
|
||
|
Return the offset between current time and log file startTime
|
||
|
"""
|
||
|
t = time.time()
|
||
|
dt = t - self.__startTime
|
||
|
if (dt >= 86400):
|
||
|
days = int(math.floor(dt/86400))
|
||
|
dt = dt%86400
|
||
|
else:
|
||
|
days = 0
|
||
|
if (dt >= 3600):
|
||
|
hours = int(math.floor(dt/3600))
|
||
|
dt = dt%3600
|
||
|
else:
|
||
|
hours = 0
|
||
|
if (dt >= 60):
|
||
|
minutes = int(math.floor(dt/60))
|
||
|
dt = dt%60
|
||
|
else:
|
||
|
minutes = 0
|
||
|
seconds = int(math.ceil(dt))
|
||
|
return("%02d:%02d:%02d:%02d: " % (days, hours, minutes, seconds))
|
||
|
|
||
|
|