argenta 0.4.9__tar.gz → 0.5.0a0__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (33) hide show
  1. {argenta-0.4.9 → argenta-0.5.0a0}/PKG-INFO +1 -1
  2. argenta-0.5.0a0/argenta/app/__init__.py +3 -0
  3. argenta-0.5.0a0/argenta/app/autocompleter/__init__.py +4 -0
  4. argenta-0.5.0a0/argenta/app/autocompleter/entity.py +48 -0
  5. {argenta-0.4.9 → argenta-0.5.0a0}/argenta/app/defaults.py +1 -0
  6. argenta-0.5.0a0/argenta/app/exceptions.py +15 -0
  7. {argenta-0.4.9 → argenta-0.5.0a0}/argenta/app/models.py +110 -74
  8. argenta-0.5.0a0/argenta/command/__init__.py +3 -0
  9. argenta-0.5.0a0/argenta/command/flag/__init__.py +4 -0
  10. {argenta-0.4.9 → argenta-0.5.0a0}/argenta/command/models.py +7 -2
  11. {argenta-0.4.9 → argenta-0.5.0a0}/argenta/router/command_handler/entity.py +6 -6
  12. {argenta-0.4.9 → argenta-0.5.0a0}/argenta/router/entity.py +44 -21
  13. {argenta-0.4.9 → argenta-0.5.0a0}/pyproject.toml +1 -1
  14. argenta-0.4.9/argenta/app/__init__.py +0 -3
  15. argenta-0.4.9/argenta/app/exceptions.py +0 -25
  16. argenta-0.4.9/argenta/command/__init__.py +0 -3
  17. argenta-0.4.9/argenta/command/flag/__init__.py +0 -4
  18. {argenta-0.4.9 → argenta-0.5.0a0}/LICENSE +0 -0
  19. {argenta-0.4.9 → argenta-0.5.0a0}/README.md +0 -0
  20. {argenta-0.4.9 → argenta-0.5.0a0}/argenta/__init__.py +0 -0
  21. {argenta-0.4.9 → argenta-0.5.0a0}/argenta/app/dividing_line/__init__.py +0 -0
  22. {argenta-0.4.9 → argenta-0.5.0a0}/argenta/app/dividing_line/models.py +0 -0
  23. {argenta-0.4.9 → argenta-0.5.0a0}/argenta/app/registered_routers/__init__.py +0 -0
  24. {argenta-0.4.9 → argenta-0.5.0a0}/argenta/app/registered_routers/entity.py +0 -0
  25. {argenta-0.4.9 → argenta-0.5.0a0}/argenta/command/exceptions.py +0 -0
  26. {argenta-0.4.9 → argenta-0.5.0a0}/argenta/command/flag/defaults.py +0 -0
  27. {argenta-0.4.9 → argenta-0.5.0a0}/argenta/command/flag/models.py +0 -0
  28. {argenta-0.4.9 → argenta-0.5.0a0}/argenta/router/__init__.py +0 -0
  29. {argenta-0.4.9 → argenta-0.5.0a0}/argenta/router/command_handler/__init__.py +0 -0
  30. {argenta-0.4.9 → argenta-0.5.0a0}/argenta/router/command_handlers/__init__.py +0 -0
  31. {argenta-0.4.9 → argenta-0.5.0a0}/argenta/router/command_handlers/entity.py +0 -0
  32. {argenta-0.4.9 → argenta-0.5.0a0}/argenta/router/defaults.py +0 -0
  33. {argenta-0.4.9 → argenta-0.5.0a0}/argenta/router/exceptions.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.3
2
2
  Name: argenta
3
- Version: 0.4.9
3
+ Version: 0.5.0a0
4
4
  Summary: Python library for creating TUI
5
5
  License: MIT
6
6
  Author: kolo
@@ -0,0 +1,3 @@
1
+ __all__ = ["App"]
2
+
3
+ from argenta.app.models import App
@@ -0,0 +1,4 @@
1
+ __all__ = ["AutoCompleter"]
2
+
3
+
4
+ from argenta.app.autocompleter.entity import AutoCompleter
@@ -0,0 +1,48 @@
1
+ import os
2
+
3
+ import readline
4
+
5
+
6
+ class AutoCompleter:
7
+ def __init__(self, history_filename: str = False, autocomplete_button: str = 'tab'):
8
+ self.history_filename = history_filename
9
+ self.autocomplete_button = autocomplete_button
10
+ self.matches = []
11
+
12
+ def complete(self, text, state):
13
+ matches = sorted(cmd for cmd in self.get_history_items() if cmd.startswith(text))
14
+ if len(matches) > 1:
15
+ common_prefix = matches[0]
16
+ for match in matches[1:]:
17
+ i = 0
18
+ while i < len(common_prefix) and i < len(match) and common_prefix[i] == match[i]:
19
+ i += 1
20
+ common_prefix = common_prefix[:i]
21
+ if state == 0:
22
+ readline.insert_text(common_prefix[len(text):])
23
+ readline.redisplay()
24
+ return None
25
+ elif len(matches) == 1:
26
+ return matches[0] if state == 0 else None
27
+ else:
28
+ return None
29
+
30
+ def initial_setup(self, all_commands: list[str]):
31
+ if self.history_filename:
32
+ if os.path.exists(self.history_filename):
33
+ readline.read_history_file(self.history_filename)
34
+ else:
35
+ for line in all_commands:
36
+ readline.add_history(line)
37
+
38
+ readline.set_completer(self.complete)
39
+ readline.set_completer_delims(readline.get_completer_delims().replace(' ', ''))
40
+ readline.parse_and_bind(f'{self.autocomplete_button}: complete')
41
+
42
+ def exit_setup(self):
43
+ if self.history_filename:
44
+ readline.write_history_file(self.history_filename)
45
+
46
+ @staticmethod
47
+ def get_history_items():
48
+ return [readline.get_history_item(i) for i in range(1, readline.get_current_history_length() + 1)]
@@ -5,4 +5,5 @@ from dataclasses import dataclass
5
5
  class PredeterminedMessages:
6
6
  USAGE = '[b dim]Usage[/b dim]: [i]<command> <[green]flags[/green]>[/i]'
7
7
  HELP = '[b dim]Help[/b dim]: [i]<command>[/i] [b red]--help[/b red]'
8
+ AUTOCOMPLETE = '[b dim]Autocomplete[/b dim]: [i]<part>[/i] [bold]<tab>'
8
9
 
@@ -0,0 +1,15 @@
1
+ class InvalidRouterInstanceException(Exception):
2
+ def __str__(self):
3
+ return "Invalid Router Instance"
4
+
5
+
6
+ class NoRegisteredRoutersException(Exception):
7
+ def __str__(self):
8
+ return "No Registered Router Found"
9
+
10
+
11
+ class NoRegisteredHandlersException(Exception):
12
+ def __init__(self, router_name):
13
+ self.router_name = router_name
14
+ def __str__(self):
15
+ return f"No Registered Handlers Found For '{self.router_name}'"
@@ -1,5 +1,6 @@
1
1
  from typing import Callable
2
2
  from rich.console import Console
3
+ from rich.markup import escape
3
4
  from art import text2art
4
5
  from contextlib import redirect_stdout
5
6
  import io
@@ -8,78 +9,106 @@ import re
8
9
  from argenta.command.models import Command, InputCommand
9
10
  from argenta.router import Router
10
11
  from argenta.router.defaults import system_router
12
+ from argenta.app.autocompleter import AutoCompleter
11
13
  from argenta.app.dividing_line.models import StaticDividingLine, DynamicDividingLine
12
14
  from argenta.command.exceptions import (UnprocessedInputFlagException,
13
15
  RepeatedInputFlagsException,
14
16
  EmptyInputCommandException,
15
17
  BaseInputCommandException)
16
18
  from argenta.app.exceptions import (InvalidRouterInstanceException,
17
- InvalidDescriptionMessagePatternException,
18
19
  NoRegisteredRoutersException,
19
20
  NoRegisteredHandlersException)
20
21
  from argenta.app.registered_routers.entity import RegisteredRouters
21
22
 
22
23
 
23
24
 
24
- class BaseApp:
25
+ class AppInit:
25
26
  def __init__(self,
26
27
  prompt: str = '[italic dim bold]What do you want to do?\n',
27
28
  initial_message: str = '\nArgenta\n',
28
29
  farewell_message: str = '\nSee you\n',
29
- exit_command: str = 'Q',
30
- exit_command_description: str = 'Exit command',
31
- system_points_title: str = 'System points:',
30
+ exit_command: Command = Command('Q', 'Exit command'),
31
+ system_points_title: str | None = 'System points:',
32
32
  ignore_command_register: bool = True,
33
33
  dividing_line: StaticDividingLine | DynamicDividingLine = StaticDividingLine(),
34
34
  repeat_command_groups: bool = True,
35
35
  full_override_system_messages: bool = False,
36
+ autocompleter: AutoCompleter = AutoCompleter(),
36
37
  print_func: Callable[[str], None] = Console().print) -> None:
37
38
  self._prompt = prompt
38
39
  self._print_func = print_func
39
40
  self._exit_command = exit_command
40
- self._exit_command_description = exit_command_description
41
41
  self._system_points_title = system_points_title
42
42
  self._dividing_line = dividing_line
43
43
  self._ignore_command_register = ignore_command_register
44
44
  self._repeat_command_groups_description = repeat_command_groups
45
45
  self._full_override_system_messages = full_override_system_messages
46
+ self._autocompleter = autocompleter
46
47
 
47
- self.farewell_message = farewell_message
48
- self.initial_message = initial_message
48
+ self._farewell_message = farewell_message
49
+ self._initial_message = initial_message
49
50
 
50
- self._description_message_pattern: str = '[bold red][{command}][/bold red] [blue dim]*=*=*[/blue dim] [bold yellow italic]{description}'
51
+
52
+ self._description_message_gen: Callable[[str, str], str] = lambda command, description: f'[bold red]{escape('['+command+']')}[/bold red] [blue dim]*=*=*[/blue dim] [bold yellow italic]{escape(description)}'
51
53
  self._registered_routers: RegisteredRouters = RegisteredRouters()
52
54
  self._messages_on_startup = []
53
55
 
54
- self.invalid_input_flags_handler: Callable[[str], None] = lambda raw_command: print_func(f'[red bold]Incorrect flag syntax: {raw_command}')
55
- self.repeated_input_flags_handler: Callable[[str], None] = lambda raw_command: print_func(f'[red bold]Repeated input flags: {raw_command}')
56
- self.empty_input_command_handler: Callable[[], None] = lambda: print_func('[red bold]Empty input command')
57
- self.unknown_command_handler: Callable[[InputCommand], None] = lambda command: print_func(f"[red bold]Unknown command: {command.get_trigger()}")
58
- self.exit_command_handler: Callable[[], None] = lambda: print_func(self.farewell_message)
56
+ self._invalid_input_flags_handler: Callable[[str], None] = lambda raw_command: print_func(f'[red bold]Incorrect flag syntax: {raw_command}')
57
+ self._repeated_input_flags_handler: Callable[[str], None] = lambda raw_command: print_func(f'[red bold]Repeated input flags: {raw_command}')
58
+ self._empty_input_command_handler: Callable[[], None] = lambda: print_func('[red bold]Empty input command')
59
+ self._unknown_command_handler: Callable[[InputCommand], None] = lambda command: print_func(f"[red bold]Unknown command: {command.get_trigger()}")
60
+ self._exit_command_handler: Callable[[], None] = lambda: print_func(self._farewell_message)
59
61
 
60
- self._setup_default_view()
61
62
 
63
+ class AppSetters(AppInit):
64
+ def set_description_message_pattern(self, pattern: Callable[[str, str], str]) -> None:
65
+ self._description_message_gen: Callable[[str, str], str] = pattern
62
66
 
63
- def _setup_default_view(self):
64
- if not self._full_override_system_messages:
65
- self.initial_message = f'\n[bold red]{text2art(self.initial_message, font='tarty1')}\n\n'
66
- self.farewell_message = (f'[bold red]\n{text2art(f'\n{self.farewell_message}\n', font='chanky')}[/bold red]\n'
67
- f'[red i]github.com/koloideal/Argenta[/red i] | [red bold i]made by kolo[/red bold i]\n')
68
67
 
68
+ def set_invalid_input_flags_handler(self, handler: Callable[[str], None]) -> None:
69
+ self._invalid_input_flags_handler = handler
69
70
 
70
- def _validate_number_of_routers(self) -> None:
71
- if not self._registered_routers:
72
- raise NoRegisteredRoutersException()
73
71
 
72
+ def set_repeated_input_flags_handler(self, handler: Callable[[str], None]) -> None:
73
+ self._repeated_input_flags_handler = handler
74
74
 
75
- def _validate_included_routers(self) -> None:
76
- for router in self._registered_routers:
77
- if not router.get_command_handlers():
78
- raise NoRegisteredHandlersException(router.get_name())
75
+
76
+ def set_unknown_command_handler(self, handler: Callable[[str], None]) -> None:
77
+ self._unknown_command_handler = handler
78
+
79
+
80
+ def set_empty_command_handler(self, handler: Callable[[], None]) -> None:
81
+ self._empty_input_command_handler = handler
82
+
83
+
84
+ def set_exit_command_handler(self, handler: Callable[[], None]) -> None:
85
+ self._exit_command_handler = handler
86
+
87
+
88
+ class AppPrinters(AppInit):
89
+ def _print_command_group_description(self):
90
+ for registered_router in self._registered_routers:
91
+ if registered_router.get_title():
92
+ self._print_func(registered_router.get_title())
93
+ for command_handler in registered_router.get_command_handlers():
94
+ self._print_func(self._description_message_gen(
95
+ command_handler.get_handled_command().get_trigger(),
96
+ command_handler.get_handled_command().get_description()))
97
+ self._print_func('')
98
+
99
+
100
+ def _print_framed_text_with_dynamic_line(self, text: str):
101
+ clear_text = re.sub(r'\u001b\[[0-9;]*m', '', text)
102
+ max_length_line = max([len(line) for line in clear_text.split('\n')])
103
+ max_length_line = max_length_line if 10 <= max_length_line <= 80 else 80 if max_length_line > 80 else 10
104
+ self._print_func(self._dividing_line.get_full_line(max_length_line))
105
+ print(text.strip('\n'))
106
+ self._print_func(self._dividing_line.get_full_line(max_length_line))
79
107
 
80
108
 
109
+ class AppNonStandardHandlers(AppPrinters):
81
110
  def _is_exit_command(self, command: InputCommand):
82
- if command.get_trigger().lower() == self._exit_command.lower():
111
+ if command.get_trigger().lower() == self._exit_command.get_trigger().lower():
83
112
  if self._ignore_command_register:
84
113
  system_router.input_command_handler(command)
85
114
  return True
@@ -93,59 +122,82 @@ class BaseApp:
93
122
  for router_entity in self._registered_routers:
94
123
  for command_handler in router_entity.get_command_handlers():
95
124
  handled_command_trigger = command_handler.get_handled_command().get_trigger()
125
+ handled_command_aliases = command_handler.get_handled_command().get_aliases()
96
126
  if handled_command_trigger.lower() == command.get_trigger().lower() and self._ignore_command_register:
97
127
  return False
98
128
  elif handled_command_trigger == command.get_trigger():
99
129
  return False
130
+ elif handled_command_aliases:
131
+ if command.get_trigger().lower() in [x.lower() for x in handled_command_aliases] and self._ignore_command_register:
132
+ return False
133
+ elif command.get_trigger() in handled_command_trigger:
134
+ return False
100
135
  if isinstance(self._dividing_line, StaticDividingLine):
101
136
  self._print_func(self._dividing_line.get_full_line())
102
- self.unknown_command_handler(command)
137
+ self._unknown_command_handler(command)
103
138
  self._print_func(self._dividing_line.get_full_line())
104
139
  elif isinstance(self._dividing_line, DynamicDividingLine):
105
140
  with redirect_stdout(io.StringIO()) as f:
106
- self.unknown_command_handler(command)
141
+ self._unknown_command_handler(command)
107
142
  res: str = f.getvalue()
108
143
  self._print_framed_text_with_dynamic_line(res)
109
144
  return True
110
145
 
111
146
 
112
- def _print_command_group_description(self):
113
- for registered_router in self._registered_routers:
114
- self._print_func(registered_router.get_title())
115
- for command_handler in registered_router.get_command_handlers():
116
- self._print_func(self._description_message_pattern.format(
117
- command=command_handler.get_handled_command().get_trigger(),
118
- description=command_handler.get_handled_command().get_description()))
119
- self._print_func('')
120
-
121
-
122
147
  def _error_handler(self, error: BaseInputCommandException, raw_command: str) -> None:
123
148
  match error:
124
149
  case UnprocessedInputFlagException():
125
- self.invalid_input_flags_handler(raw_command)
150
+ self._invalid_input_flags_handler(raw_command)
126
151
  case RepeatedInputFlagsException():
127
- self.repeated_input_flags_handler(raw_command)
152
+ self._repeated_input_flags_handler(raw_command)
128
153
  case EmptyInputCommandException():
129
- self.empty_input_command_handler()
154
+ self._empty_input_command_handler()
130
155
 
131
156
 
132
- def _print_framed_text_with_dynamic_line(self, text: str):
133
- clear_text = re.sub(r'\u001b\[[0-9;]*m', '', text)
134
- max_length_line = max([len(line) for line in clear_text.split('\n')])
135
- max_length_line = max_length_line if 10 <= max_length_line <= 80 else 80 if max_length_line > 80 else 10
136
- self._print_func(self._dividing_line.get_full_line(max_length_line))
137
- print(text.strip('\n'))
138
- self._print_func(self._dividing_line.get_full_line(max_length_line))
157
+ class AppValidators(AppInit):
158
+ def _validate_number_of_routers(self) -> None:
159
+ if not self._registered_routers:
160
+ raise NoRegisteredRoutersException()
161
+
162
+
163
+ def _validate_included_routers(self) -> None:
164
+ for router in self._registered_routers:
165
+ if not router.get_command_handlers():
166
+ raise NoRegisteredHandlersException(router.get_name())
167
+
168
+
169
+ class AppSetups(AppValidators, AppPrinters):
170
+ def _setup_system_router(self):
171
+ system_router.set_title(self._system_points_title)
139
172
 
173
+ @system_router.command(self._exit_command)
174
+ def exit_command():
175
+ self._exit_command_handler()
140
176
 
177
+ if system_router not in self._registered_routers.get_registered_routers():
178
+ system_router.set_ignore_command_register(self._ignore_command_register)
179
+ self._registered_routers.add_registered_router(system_router)
141
180
 
142
- class App(BaseApp):
143
- def start_polling(self) -> None:
181
+ def _setup_default_view(self):
182
+ if not self._full_override_system_messages:
183
+ self._initial_message = f'\n[bold red]{text2art(self._initial_message, font='tarty1')}\n\n'
184
+ self._farewell_message = (
185
+ f'[bold red]\n{text2art(f'\n{self._farewell_message}\n', font='chanky')}[/bold red]\n'
186
+ f'[red i]github.com/koloideal/Argenta[/red i] | [red bold i]made by kolo[/red bold i]\n')
187
+
188
+ def _pre_cycle_setup(self):
189
+ self._setup_default_view()
144
190
  self._setup_system_router()
145
191
  self._validate_number_of_routers()
146
192
  self._validate_included_routers()
147
193
 
148
- self._print_func(self.initial_message)
194
+ all_triggers: list[str] = []
195
+ for router_entity in self._registered_routers:
196
+ all_triggers.extend(router_entity.get_triggers())
197
+ all_triggers.extend(router_entity.get_aliases())
198
+ self._autocompleter.initial_setup(all_triggers)
199
+
200
+ self._print_func(self._initial_message)
149
201
 
150
202
  for message in self._messages_on_startup:
151
203
  self._print_func(message)
@@ -153,6 +205,10 @@ class App(BaseApp):
153
205
  if not self._repeat_command_groups_description:
154
206
  self._print_command_group_description()
155
207
 
208
+
209
+ class App(AppSetters, AppNonStandardHandlers, AppSetups):
210
+ def start_polling(self) -> None:
211
+ self._pre_cycle_setup()
156
212
  while True:
157
213
  if self._repeat_command_groups_description:
158
214
  self._print_command_group_description()
@@ -174,6 +230,7 @@ class App(BaseApp):
174
230
  continue
175
231
 
176
232
  if self._is_exit_command(input_command):
233
+ self._autocompleter.exit_setup()
177
234
  return
178
235
 
179
236
  if self._is_unknown_command(input_command):
@@ -211,24 +268,3 @@ class App(BaseApp):
211
268
  def add_message_on_startup(self, message: str) -> None:
212
269
  self._messages_on_startup.append(message)
213
270
 
214
-
215
- def set_description_message_pattern(self, pattern: str) -> None:
216
- first_check = re.match(r'.*{command}.*', pattern)
217
- second_check = re.match(r'.*{description}.*', pattern)
218
-
219
- if bool(first_check) and bool(second_check):
220
- self._description_message_pattern: str = pattern
221
- else:
222
- raise InvalidDescriptionMessagePatternException(pattern)
223
-
224
-
225
- def _setup_system_router(self):
226
- system_router.set_title(self._system_points_title)
227
- @system_router.command(Command(self._exit_command, self._exit_command_description))
228
- def exit_command():
229
- self.exit_command_handler()
230
-
231
- if system_router not in self._registered_routers.get_registered_routers():
232
- self.include_router(system_router)
233
-
234
-
@@ -0,0 +1,3 @@
1
+ __all__ = ["Command"]
2
+
3
+ from argenta.command.models import Command
@@ -0,0 +1,4 @@
1
+ __all__ = ('InputFlags', 'InputFlag', 'Flag', 'Flags')
2
+
3
+
4
+ from argenta.command.flag.models import InputFlags, InputFlag, Flags, Flag
@@ -19,14 +19,19 @@ class BaseCommand:
19
19
  class Command(BaseCommand):
20
20
  def __init__(self, trigger: str,
21
21
  description: str = None,
22
- flags: Flag | Flags = None):
22
+ flags: Flag | Flags = None,
23
+ aliases: list[str] = None):
23
24
  super().__init__(trigger)
24
25
  self._registered_flags: Flags = flags if isinstance(flags, Flags) else Flags(flags) if isinstance(flags, Flag) else Flags()
25
- self._description = f'description for "{self._trigger}" command' if not description else description
26
+ self._description = f'Description for "{self._trigger}" command' if not description else description
27
+ self._aliases = aliases
26
28
 
27
29
  def get_registered_flags(self) -> Flags:
28
30
  return self._registered_flags
29
31
 
32
+ def get_aliases(self) -> list[str] | None:
33
+ return self._aliases
34
+
30
35
  def validate_input_flag(self, flag: InputFlag):
31
36
  registered_flags: Flags | None = self.get_registered_flags()
32
37
  if registered_flags:
@@ -5,17 +5,17 @@ from argenta.command.flag.models import InputFlags
5
5
 
6
6
  class CommandHandler:
7
7
  def __init__(self, handler: Callable[[], None] | Callable[[InputFlags], None], handled_command: Command):
8
- self.handler = handler
9
- self.handled_command = handled_command
8
+ self._handler = handler
9
+ self._handled_command = handled_command
10
10
 
11
11
  def handling(self, input_flags: InputFlags = None):
12
12
  if input_flags is not None:
13
- self.handler(input_flags)
13
+ self._handler(input_flags)
14
14
  else:
15
- self.handler()
15
+ self._handler()
16
16
 
17
17
  def get_handler(self):
18
- return self.handler
18
+ return self._handler
19
19
 
20
20
  def get_handled_command(self):
21
- return self.handled_command
21
+ return self._handled_command
@@ -7,15 +7,15 @@ from argenta.router.command_handlers.entity import CommandHandlers
7
7
  from argenta.router.command_handler.entity import CommandHandler
8
8
  from argenta.command.flag.models import Flag, Flags, InputFlags
9
9
  from argenta.router.exceptions import (RepeatedFlagNameException,
10
- TooManyTransferredArgsException,
11
- RequiredArgumentNotPassedException,
12
- IncorrectNumberOfHandlerArgsException,
13
- TriggerCannotContainSpacesException)
10
+ TooManyTransferredArgsException,
11
+ RequiredArgumentNotPassedException,
12
+ IncorrectNumberOfHandlerArgsException,
13
+ TriggerCannotContainSpacesException)
14
14
 
15
15
 
16
16
  class Router:
17
17
  def __init__(self,
18
- title: str = 'Commands group title:',
18
+ title: str = None,
19
19
  name: str = 'Default'):
20
20
  self._title = title
21
21
  self._name = name
@@ -54,21 +54,29 @@ class Router:
54
54
  for command_handler in self._command_handlers:
55
55
  handle_command = command_handler.get_handled_command()
56
56
  if input_command_name.lower() == handle_command.get_trigger().lower():
57
- if handle_command.get_registered_flags().get_flags():
58
- if input_command_flags.get_flags():
59
- if self._validate_input_flags(handle_command, input_command_flags):
60
- command_handler.handling(input_command_flags)
61
- return
62
- else:
63
- command_handler.handling(input_command_flags)
64
- return
65
- else:
66
- if input_command_flags.get_flags():
67
- self._not_valid_flag_handler(input_command_flags[0])
68
- return
69
- else:
70
- command_handler.handling()
71
- return
57
+ self._validate_input_command(input_command_flags, command_handler)
58
+ elif handle_command.get_aliases():
59
+ if input_command_name.lower() in handle_command.get_aliases():
60
+ self._validate_input_command(input_command_flags, command_handler)
61
+
62
+
63
+ def _validate_input_command(self, input_command_flags: InputFlags, command_handler: CommandHandler):
64
+ handle_command = command_handler.get_handled_command()
65
+ if handle_command.get_registered_flags().get_flags():
66
+ if input_command_flags.get_flags():
67
+ if self._validate_input_flags(handle_command, input_command_flags):
68
+ command_handler.handling(input_command_flags)
69
+ return
70
+ else:
71
+ command_handler.handling(input_command_flags)
72
+ return
73
+ else:
74
+ if input_command_flags.get_flags():
75
+ self._not_valid_flag_handler(input_command_flags[0])
76
+ return
77
+ else:
78
+ command_handler.handling()
79
+ return
72
80
 
73
81
 
74
82
  def _validate_input_flags(self, handle_command: Command, input_flags: InputFlags):
@@ -110,6 +118,21 @@ class Router:
110
118
  self._ignore_command_register = ignore_command_register
111
119
 
112
120
 
121
+ def get_triggers(self):
122
+ all_triggers: list[str] = []
123
+ for command_handler in self._command_handlers:
124
+ all_triggers.append(command_handler.get_handled_command().get_trigger())
125
+ return all_triggers
126
+
127
+
128
+ def get_aliases(self):
129
+ all_aliases: list[str] = []
130
+ for command_handler in self._command_handlers:
131
+ if command_handler.get_handled_command().get_aliases():
132
+ all_aliases.extend(command_handler.get_handled_command().get_aliases())
133
+ return all_aliases
134
+
135
+
113
136
  def get_command_handlers(self) -> CommandHandlers:
114
137
  return self._command_handlers
115
138
 
@@ -118,7 +141,7 @@ class Router:
118
141
  return self._name
119
142
 
120
143
 
121
- def get_title(self) -> str:
144
+ def get_title(self) -> str | None:
122
145
  return self._title
123
146
 
124
147
 
@@ -1,6 +1,6 @@
1
1
  [project]
2
2
  name = "argenta"
3
- version = "0.4.9"
3
+ version = "0.5.0-alpha"
4
4
  description = "Python library for creating TUI"
5
5
  authors = [
6
6
  {name = "kolo", email = "kolo.is.main@gmail.com"}
@@ -1,3 +0,0 @@
1
- __all__ = ["App"]
2
-
3
- from .models import App
@@ -1,25 +0,0 @@
1
- class InvalidRouterInstanceException(Exception):
2
- def __str__(self):
3
- return "Invalid Router Instance"
4
-
5
-
6
- class InvalidDescriptionMessagePatternException(Exception):
7
- def __init__(self, pattern: str):
8
- self.pattern = pattern
9
- def __str__(self):
10
- return ("Invalid Description Message Pattern\n"
11
- "Correct pattern example: [{command}] *=*=* {description}\n"
12
- "The pattern must contain two variables: `command` and `description` - description of the command\n"
13
- f"Your pattern: {self.pattern}")
14
-
15
-
16
- class NoRegisteredRoutersException(Exception):
17
- def __str__(self):
18
- return "No Registered Router Found"
19
-
20
-
21
- class NoRegisteredHandlersException(Exception):
22
- def __init__(self, router_name):
23
- self.router_name = router_name
24
- def __str__(self):
25
- return f"No Registered Handlers Found For '{self.router_name}'"
@@ -1,3 +0,0 @@
1
- __all__ = ["Command"]
2
-
3
- from .models import Command
@@ -1,4 +0,0 @@
1
- __all__ = ('InputFlags', 'InputFlag', 'Flag', 'Flags')
2
-
3
-
4
- from .models import InputFlags, InputFlag, Flags, Flag
File without changes
File without changes
File without changes