work on v0.3.0

This commit is contained in:
2025-02-20 22:10:29 +03:00
parent a63c46a78b
commit 79ccfbb3b1
5 changed files with 23 additions and 11 deletions
+10 -4
View File
@@ -14,7 +14,7 @@ class Command:
self._description = description self._description = description
self._flags = flags self._flags = flags
self._input_flags: FlagsGroup | None = None self._input_flags: InputFlag | FlagsGroup | None = None
def get_string_entity(self): def get_string_entity(self):
return self._command return self._command
@@ -37,15 +37,21 @@ class Command:
raise InvalidCommandInstanceException(self._command) raise InvalidCommandInstanceException(self._command)
if not isinstance(self._description, str): if not isinstance(self._description, str):
raise InvalidDescriptionInstanceException() raise InvalidDescriptionInstanceException()
if not (isinstance(self._flags, Flag) or not isinstance(self._flags, FlagsGroup)) or not self._flags is None: if not any([(isinstance(self._flags, Flag), isinstance(self._flags, FlagsGroup)), not self._flags]):
raise InvalidFlagsInstanceException raise InvalidFlagsInstanceException
def validate_input_flag(self, flag: InputFlag): def validate_input_flag(self, flag: InputFlag):
registered_flags: FlagsGroup = self._flags registered_flags: FlagsGroup | Flag | None = self._flags
if registered_flags: if registered_flags:
if isinstance(registered_flags, Flag):
if registered_flags.get_string_entity() == flag.get_string_entity():
is_valid = registered_flags.validate_input_flag_value(flag.get_value())
if is_valid:
return True
else:
for registered_flag in registered_flags: for registered_flag in registered_flags:
if registered_flag.get_string_entity() == flag.get_string_entity(): if registered_flag.get_string_entity() == flag.get_string_entity():
is_valid = registered_flag.validate_input_flag_value(flag) is_valid = registered_flag.validate_input_flag_value(flag.get_value())
if is_valid: if is_valid:
return True return True
return False return False
+2
View File
@@ -50,6 +50,8 @@ class InputCommand(Command, Generic[T]):
current_flag_name = None current_flag_name = None
current_flag_value = None current_flag_value = None
if any([current_flag_name, current_flag_value]):
raise IncorrectInputFlagException()
if len(flags.get_flags()) == 0: if len(flags.get_flags()) == 0:
return InputCommand(command=command) return InputCommand(command=command)
else: else:
-1
View File
@@ -18,7 +18,6 @@ class Flag:
string_entity: str = self.flag_prefix + self.flag_name.lower() string_entity: str = self.flag_prefix + self.flag_name.lower()
else: else:
string_entity: str = self.flag_prefix + self.flag_name string_entity: str = self.flag_prefix + self.flag_name
print(string_entity)
return string_entity return string_entity
def get_value(self): def get_value(self):
+9 -4
View File
@@ -1,6 +1,7 @@
from rich.console import Console from rich.console import Console
from argenta.command.entity import Command from argenta.command.entity import Command
from argenta.command.params.flag.entity import Flag
from argenta.command.params.flag.flags_group.entity import FlagsGroup from argenta.command.params.flag.flags_group.entity import FlagsGroup
from argenta.router import Router from argenta.router import Router
@@ -12,11 +13,15 @@ settings_router: Router = Router(title='Settings points:')
console = Console() console = Console()
@work_router.command(command=Command(command='0', description='Get Help')) @work_router.command(command=Command(command='0', description='Get Help', flags=Flag(flag_name='host',
flag_prefix='--',
ignore_flag_value_register=True,
possible_flag_values=['tester', 'ffmpeg'])))
def command_help(args: FlagsGroup): def command_help(args: FlagsGroup):
print(args.get_flags()) flags = args.get_flags()
print('aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa') for flag in flags:
help_command() print(f'name: "{flag.get_string_entity()}", value: "{flag.get_value()}"')
#help_command()
'''@work_router.command(command='1', description='Start Solving') '''@work_router.command(command='1', description='Start Solving')