mirror of
https://github.com/koloideal/Argenta.git
synced 2026-06-10 18:15:28 +03:00
refactor, new model e.t.c.
This commit is contained in:
@@ -1,5 +0,0 @@
|
||||
__all__ = ["Flag", "FlagsGroup"]
|
||||
|
||||
|
||||
from .entity import Flag
|
||||
from .flags_group.entity import FlagsGroup
|
||||
@@ -1,7 +1,7 @@
|
||||
from typing import Literal, Pattern
|
||||
|
||||
|
||||
class Flag:
|
||||
class BaseFlag:
|
||||
def __init__(self, flag_name: str,
|
||||
flag_prefix: Literal['-', '--', '---'] = '--',
|
||||
possible_flag_values: list[str] | Pattern[str] | False = True):
|
||||
@@ -9,8 +9,6 @@ class Flag:
|
||||
self._flag_prefix = flag_prefix
|
||||
self.possible_flag_values = possible_flag_values
|
||||
|
||||
self._flag_value = None
|
||||
|
||||
def get_string_entity(self):
|
||||
string_entity: str = self._flag_prefix + self._flag_name
|
||||
return string_entity
|
||||
@@ -21,12 +19,6 @@ class Flag:
|
||||
def get_flag_prefix(self):
|
||||
return self._flag_prefix
|
||||
|
||||
def get_value(self):
|
||||
return self._flag_value
|
||||
|
||||
def set_value(self, value):
|
||||
self._flag_value = value
|
||||
|
||||
def validate_input_flag_value(self, input_flag_value: str | None):
|
||||
if self.possible_flag_values is False:
|
||||
if input_flag_value is None:
|
||||
@@ -1,22 +1,23 @@
|
||||
from argenta.command.flag import Flag
|
||||
from argenta.command.flag.input_flag.entity import InputFlag
|
||||
from argenta.command.flag.registered_flag import Flag
|
||||
|
||||
|
||||
class FlagsGroup:
|
||||
def __init__(self, *flags: Flag):
|
||||
self._flags: list[Flag] = [] if not flags else flags
|
||||
def __init__(self, *flags: Flag | InputFlag):
|
||||
self._flags: list[Flag | InputFlag] = [] if not flags else flags
|
||||
|
||||
def get_flags(self) -> list[Flag]:
|
||||
def get_flags(self) -> list[Flag | InputFlag]:
|
||||
return self._flags
|
||||
|
||||
def add_flag(self, flag: Flag):
|
||||
def add_flag(self, flag: Flag | InputFlag):
|
||||
self._flags.append(flag)
|
||||
|
||||
def add_flags(self, flags: list[Flag]):
|
||||
def add_flags(self, flags: list[Flag | InputFlag]):
|
||||
self._flags.extend(flags)
|
||||
|
||||
def unparse_to_dict(self):
|
||||
result_dict: dict[str, dict] = {}
|
||||
for flag in self._flags:
|
||||
for flag in self.get_flags():
|
||||
result_dict[flag.get_flag_name()] = {
|
||||
'name': flag.get_flag_name(),
|
||||
'string_entity': flag.get_string_entity(),
|
||||
|
||||
@@ -0,0 +1,18 @@
|
||||
from re import Pattern
|
||||
from typing import Literal
|
||||
|
||||
from argenta.command.flag.base_flag.entity import BaseFlag
|
||||
|
||||
|
||||
class InputFlag(BaseFlag):
|
||||
def __init__(self, flag_name: str,
|
||||
flag_prefix: Literal['-', '--', '---'] = '--',
|
||||
possible_flag_values: list[str] | Pattern[str] | False = True):
|
||||
super().__init__(flag_name, flag_prefix, possible_flag_values)
|
||||
self._flag_value = None
|
||||
|
||||
def get_value(self):
|
||||
return self._flag_value
|
||||
|
||||
def set_value(self, value):
|
||||
self._flag_value = value
|
||||
@@ -0,0 +1,5 @@
|
||||
__all__ = ["Flag", "FlagsGroup"]
|
||||
|
||||
|
||||
from .entity import Flag
|
||||
from argenta.command.flag.flags_group import FlagsGroup
|
||||
@@ -1,5 +1,5 @@
|
||||
from dataclasses import dataclass
|
||||
from argenta.command.flag import Flag
|
||||
from argenta.command.flag.registered_flag import Flag
|
||||
import re
|
||||
|
||||
|
||||
@@ -0,0 +1,5 @@
|
||||
from argenta.command.flag.base_flag.entity import BaseFlag
|
||||
|
||||
|
||||
class Flag(BaseFlag):
|
||||
pass
|
||||
Reference in New Issue
Block a user