mirror of
https://github.com/avatao-content/test-tutorial-framework
synced 2024-11-12 19:27:17 +00:00
Rename stuff in Command class to be more expressive
This commit is contained in:
parent
93f211c410
commit
b718f960f7
@ -17,45 +17,41 @@ def cenator(history):
|
||||
|
||||
class Commands:
|
||||
def __init__(self):
|
||||
self.command_impls = {self._parse_command_name(fun): getattr(self, fun) for fun in dir(self)
|
||||
if callable(getattr(self, fun))
|
||||
and self._is_command_implementation(fun)}
|
||||
self._command_method_regex = r'^command_(.+)$'
|
||||
self.command_implemetations = {self._parse_command_name(fun): getattr(self, fun) for fun in dir(self)
|
||||
if callable(getattr(self, fun)) and self._is_command_implementation(fun)}
|
||||
|
||||
@staticmethod
|
||||
def _is_command_implementation(method_name):
|
||||
return bool(Commands._match_command_regex(method_name))
|
||||
def _is_command_implementation(self, method_name):
|
||||
return bool(self._match_command_regex(method_name))
|
||||
|
||||
@staticmethod
|
||||
def _parse_command_name(method_name):
|
||||
def _parse_command_name(self, method_name):
|
||||
try:
|
||||
return Commands._match_command_regex(method_name).groups()[0]
|
||||
return self._match_command_regex(method_name).groups()[0]
|
||||
except AttributeError:
|
||||
return ''
|
||||
|
||||
@staticmethod
|
||||
def _match_command_regex(string):
|
||||
command_impl_regex = r'^_command_impl_(.+)$'
|
||||
return match(command_impl_regex, string)
|
||||
def _match_command_regex(self, string):
|
||||
return match(self._command_method_regex, string)
|
||||
|
||||
def callback(self, history):
|
||||
parts = history[-1].split()
|
||||
command = parts[0]
|
||||
if command in self.command_impls.keys():
|
||||
if command in self.command_implemetations.keys():
|
||||
try:
|
||||
self.command_impls[command](*parts[1:])
|
||||
self.command_implemetations[command](*parts[1:])
|
||||
except IndexError:
|
||||
LOG.debug('Command "%s" failed!', command)
|
||||
|
||||
def _command_impl_selectdir(self, *args):
|
||||
def command_selectdir(self, *args):
|
||||
TFWServerConnector().send_to_eventhandler('webide',
|
||||
{'data': {'command': 'selectdir',
|
||||
'directory': args[0]}})
|
||||
|
||||
def _command_impl_trigger(self, *args):
|
||||
def command_trigger(self, *args):
|
||||
TFWServerConnector().send('selectdir_needs_no_key',
|
||||
{'trigger': args[0]})
|
||||
|
||||
def _command_impl_togglenext(self, *args):
|
||||
def command_togglenext(self, *args):
|
||||
if not hasattr(self, 'togglenext_visible'):
|
||||
self.togglenext_visible = True
|
||||
TFWServerConnector().send('messagecontrol',
|
||||
|
Loading…
Reference in New Issue
Block a user