mirror of
https://github.com/koloideal/Argenta.git
synced 2026-06-10 18:15:28 +03:00
work on v0.3.0
This commit is contained in:
@@ -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
|
||||||
|
|||||||
Binary file not shown.
@@ -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:
|
||||||
|
|||||||
@@ -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):
|
||||||
|
|||||||
@@ -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')
|
||||||
|
|||||||
Reference in New Issue
Block a user