75 lines
3.4 KiB
Python
75 lines
3.4 KiB
Python
#!/bin/python
|
|
import importlib.util
|
|
import glob
|
|
import os
|
|
import time
|
|
from utils import debug
|
|
|
|
class commandManager():
|
|
def __init__(self):
|
|
pass
|
|
|
|
def loadCommands(self, environment, section='commands'):
|
|
commandFolder = "commands/" + section +"/"
|
|
commandList = glob.glob(commandFolder+'*')
|
|
for currCommand in commandList:
|
|
try:
|
|
fileName, fileExtension = os.path.splitext(currCommand)
|
|
fileName = fileName.split('/')[-1]
|
|
if fileName in ['__init__','__pycache__']:
|
|
continue
|
|
if fileExtension.lower() == '.py':
|
|
spec = importlib.util.spec_from_file_location(fileName, currCommand)
|
|
command_mod = importlib.util.module_from_spec(spec)
|
|
spec.loader.exec_module(command_mod)
|
|
environment['commands'][section][fileName] = command_mod.command()
|
|
except Exception as e:
|
|
print(e)
|
|
environment['runtime']['debug'].writeDebugOut(environment,"Error while loading command:" + currCommand ,debug.debugLevel.ERROR)
|
|
environment['runtime']['debug'].writeDebugOut(environment,str(e),debug.debugLevel.ERROR)
|
|
continue
|
|
return environment
|
|
|
|
def executeTriggerCommands(self, environment, trigger):
|
|
if environment['generalInformation']['suspend']:
|
|
return environment
|
|
for cmd in sorted(environment['commands'][trigger]):
|
|
try:
|
|
environ = environment['commands'][trigger][cmd].run(environment)
|
|
if environ != None:
|
|
environment = environ
|
|
except Exception as e:
|
|
print(e)
|
|
environment['runtime']['debug'].writeDebugOut(environment,"Error while executing trigger:" + trigger + "." + cmd ,debug.debugLevel.ERROR)
|
|
environment['runtime']['debug'].writeDebugOut(environment,str(e),debug.debugLevel.ERROR)
|
|
return environment
|
|
|
|
def executeCommand(self, environment, currCommand, section = 'commands'):
|
|
if environment['generalInformation']['suspend']:
|
|
return environment
|
|
if self.isCommandDefined(environment):
|
|
try:
|
|
environ = environment['commands'][section][currCommand].run(environment)
|
|
if environ != None:
|
|
environment = environ
|
|
except Exception as e:
|
|
print(e)
|
|
environment['runtime']['debug'].writeDebugOut(environment,"Error while executing command:" + section + "." + currCommand ,debug.debugLevel.ERROR)
|
|
environment['runtime']['debug'].writeDebugOut(environment,str(e),debug.debugLevel.ERROR)
|
|
environment['commandInfo']['currCommand'] = ''
|
|
environment['commandInfo']['lastCommandTime'] = time.time()
|
|
return environment
|
|
|
|
def isShortcutDefined(self, environment):
|
|
return( environment['input']['currShortcutString'] in environment['bindings'])
|
|
|
|
def getCommandForShortcut(self, environment):
|
|
if not self.isShortcutDefined(environment):
|
|
return environment
|
|
environment['commandInfo']['currCommand'] = environment['bindings'][environment['input']['currShortcutString']]
|
|
return environment
|
|
|
|
def isCommandDefined(self, environment):
|
|
return( environment['commandInfo']['currCommand'] in environment['commands']['commands'])
|
|
|