fenrir/src/fenrirscreenreader/core/debugManager.py
2019-09-07 22:10:42 +02:00

85 lines
2.9 KiB
Python

#!/usr/bin/python
# Debugger module for the Fenrir screen reader.
from fenrirscreenreader.core import debug
from datetime import datetime
import pathlib, os
class debugManager():
def __init__(self, fileName = ''):
self._file = None
self._fileOpened = False
self._fileName = '/tmp/fenrir_' + str(os.getpid()) + '_' + str(datetime.utcnow().strftime('%Y-%m-%d_%H-%M-%S')) + '.log'
if fileName != '':
self._fileName = fileName
def initialize(self, environment):
self.env = environment
def shutdown(self):
self.closeDebugFile()
def __del__(self):
try:
self.shutdown()
except:
pass
def openDebugFile(self, fileName = ''):
self._fileOpened = False
if fileName != '':
self._fileName = fileName
if self._fileName != '':
directory = os.path.dirname(self._fileName)
if not os.path.exists(directory):
pathlib.Path(directory).mkdir(parents=True, exist_ok=True)
try:
self._file = open(self._fileName,'a')
self._fileOpened = True
except Exception as e:
print(e)
def writeDebugOut(self, text, level = debug.debugLevel.DEACTIVE, onAnyLevel=False):
mode = self.env['runtime']['settingsManager'].getSetting('general','debugMode')
if mode == '':
mode = 'FILE'
mode = mode.upper().split(',')
fileMode = 'FILE' in mode
printMode = 'PRINT' in mode
if (self.env['runtime']['settingsManager'].getSettingAsInt('general','debugLevel') < int(level)) and \
not (onAnyLevel and self.env['runtime']['settingsManager'].getSettingAsInt('general','debugLevel') > int(debug.debugLevel.DEACTIVE)) :
if self._fileOpened:
self.closeDebugFile()
return
else:
if not self._fileOpened and fileMode:
self.openDebugFile()
if onAnyLevel:
msg = 'ANY '+ str(level) + ' ' + str(datetime.utcnow().strftime('%Y-%m-%d %H:%M:%S.%f'))
else:
msg = str(level) +' ' + str(datetime.utcnow().strftime('%Y-%m-%d %H:%M:%S.%f')
)
msg += ': ' + text
if printMode:
print(msg)
if fileMode:
try:
self._file.write(msg + '\n')
except Exception as e:
print(e)
def closeDebugFile(self):
if not self._fileOpened:
return False
if self._file != None:
try:
self._file.close()
except Exception as e:
print(e)
self._fileOpened = False
return True
def getDebugFile(self):
return self._fileName
def setDebugFile(self, fileName):
self.closeDebugFile()
self._fileName = fileName