mirror of
https://github.com/koloideal/Argenta.git
synced 2026-06-10 18:15:28 +03:00
256 lines
9.0 KiB
ReStructuredText
256 lines
9.0 KiB
ReStructuredText
.. _root_api_command_input_flags:
|
|
|
|
InputFlags
|
|
==========
|
|
|
|
`InputFlags` — это коллекция флагов, введённых пользователем. Её основная задача — группировать и управлять набором флагов, переданных вместе с командой. `InputFlags` служит контейнером, который позволяет удобно извлекать, итерировать и проверять наличие флагов, а также работать с их значениями и статусами валидации.
|
|
|
|
`InputFlags` наследуется от `BaseFlags` и специализируется на работе с объектами типа `InputFlag`. Этот класс создаётся автоматически при обработке пользовательского ввода и передаётся в обработчики команд через объект `Response`.
|
|
|
|
.. seealso::
|
|
|
|
Документация по отдельным флагам (:ref:`Flag <root_api_command_flag>`, :ref:`InputFlag <root_api_command_input_flag>`)
|
|
|
|
Документация по :ref:`InputFlags <root_api_command_input_flags>` — коллекция обработанных флагов, введённых пользователем.
|
|
|
|
Документация по :ref:`Response <root_api_response>` — объект ответа, содержащий ``InputFlags``
|
|
|
|
:ref:`Общая информация <root_flags>` о флагах и их использовании в приложении ``Argenta``
|
|
|
|
-----
|
|
|
|
Инициализация
|
|
-------------
|
|
|
|
.. code-block:: python
|
|
:linenos:
|
|
|
|
__init__(self, flags: list[InputFlag] | None = None) -> None
|
|
|
|
Создаёт новую коллекцию введённых флагов.
|
|
|
|
* ``flags``: Необязательный список флагов типа `InputFlag` для инициализации коллекции. Если не указан, создаётся пустая коллекция.
|
|
|
|
.. warning ::
|
|
Экземпляры этого класса обычно не создаются напрямую. Они автоматически формируются системой при обработке пользовательского ввода и доступны через атрибут `input_flags` объекта `Response`.
|
|
|
|
**Атрибуты:**
|
|
|
|
.. py:attribute:: flags
|
|
:no-index:
|
|
|
|
Список всех введённых флагов типа `InputFlag`. Пуст, если флаги не были переданы при инициализации или пользователь не ввёл их с командой.
|
|
|
|
**Пример использования:**
|
|
|
|
.. literalinclude:: ../../../code_snippets/input_flags/snippet1.py
|
|
:linenos:
|
|
:language: python
|
|
|
|
-----
|
|
|
|
Методы
|
|
------
|
|
|
|
get_flag_by_name
|
|
~~~~~~~~~~~~~~~~
|
|
|
|
.. code-block:: python
|
|
:linenos:
|
|
|
|
get_flag_by_name(self, name: str) -> InputFlag | None
|
|
|
|
Возвращает введённый флаг по имени.
|
|
|
|
:param name: Имя искомого флага (без префикса).
|
|
:return: Объект `InputFlag` или `None`, если флаг не найден.
|
|
|
|
Метод выполняет поиск по списку `flags` и возвращает первый флаг с соответствующим именем (без учёта префикса).
|
|
|
|
**Пример использования:**
|
|
|
|
.. literalinclude:: ../../../code_snippets/input_flags/snippet2.py
|
|
:linenos:
|
|
:language: python
|
|
|
|
-----
|
|
|
|
add_flag
|
|
~~~~~~~~
|
|
|
|
.. code-block:: python
|
|
:linenos:
|
|
|
|
add_flag(self, flag: InputFlag) -> None
|
|
|
|
Добавляет введённый флаг в коллекцию.
|
|
|
|
:param flag: Флаг типа `InputFlag` для добавления.
|
|
:return: None.
|
|
|
|
Метод добавляет флаг в конец списка `flags`. Используется для динамического расширения коллекции.
|
|
|
|
.. note::
|
|
Этот метод используется редко, так как `InputFlags` обычно создаётся автоматически. Однако он может быть полезен для тестирования или ручного создания коллекций.
|
|
|
|
**Пример использования:**
|
|
|
|
.. literalinclude:: ../../../code_snippets/input_flags/snippet3.py
|
|
:linenos:
|
|
:language: python
|
|
|
|
-----
|
|
|
|
add_flags
|
|
~~~~~~~~~
|
|
|
|
.. code-block:: python
|
|
:linenos:
|
|
|
|
add_flags(self, flags: list[InputFlag]) -> None
|
|
|
|
Добавляет в коллекцию список введённых флагов.
|
|
|
|
:param flags: Список флагов типа `InputFlag` для добавления.
|
|
:return: None.
|
|
|
|
Метод расширяет коллекцию, добавляя в неё все флаги из переданного списка. Эффективен для пакетного добавления.
|
|
|
|
**Пример использования:**
|
|
|
|
.. literalinclude:: ../../../code_snippets/input_flags/snippet4.py
|
|
:linenos:
|
|
:language: python
|
|
|
|
-----
|
|
|
|
Магические методы
|
|
-----------------
|
|
|
|
__iter__
|
|
~~~~~~~~
|
|
|
|
.. code-block:: python
|
|
:linenos:
|
|
|
|
__iter__(self) -> Iterator[InputFlag]
|
|
|
|
Делает коллекцию итерируемой для использования в циклах.
|
|
|
|
:return: Итератор по списку введённых флагов.
|
|
|
|
Позволяет перебирать все введённые флаги, что полезно для проверки их статусов или пакетной обработки.
|
|
|
|
**Пример использования:**
|
|
|
|
.. literalinclude:: ../../../code_snippets/input_flags/snippet5.py
|
|
:linenos:
|
|
:language: python
|
|
|
|
-----
|
|
|
|
__getitem__
|
|
~~~~~~~~~~~
|
|
|
|
.. code-block:: python
|
|
:linenos:
|
|
|
|
__getitem__(self, flag_index: int) -> InputFlag
|
|
|
|
Позволяет получать введённый флаг по индексу.
|
|
|
|
:param flag_index: Индекс флага в списке.
|
|
:return: Флаг по указанному индексу.
|
|
|
|
Позволяет обращаться к флагам по их позиции, что может быть полезно для их обработки в определённом порядке.
|
|
|
|
**Пример использования:**
|
|
|
|
.. literalinclude:: ../../../code_snippets/input_flags/snippet6.py
|
|
:linenos:
|
|
:language: python
|
|
|
|
-----
|
|
|
|
__bool__
|
|
~~~~~~~~
|
|
|
|
.. code-block:: python
|
|
:linenos:
|
|
|
|
__bool__(self) -> bool
|
|
|
|
Определяет, содержит ли коллекция флаги.
|
|
|
|
:return: `True`, если в коллекции есть хотя бы один флаг, иначе `False`.
|
|
|
|
Позволяет проверять наличие флагов в команде для условной логики.
|
|
|
|
**Пример использования:**
|
|
|
|
.. literalinclude:: ../../../code_snippets/input_flags/snippet7.py
|
|
:linenos:
|
|
:language: python
|
|
|
|
-----
|
|
|
|
__eq__
|
|
~~~~~~
|
|
|
|
.. code-block:: python
|
|
:linenos:
|
|
|
|
__eq__(self, other: object) -> bool
|
|
|
|
Сравнивает две коллекции введённых флагов на равенство.
|
|
|
|
:param other: Объект для сравнения.
|
|
:return: `True`, если коллекции равны, иначе `False`.
|
|
:raises NotImplementedError: Если `other` не является экземпляром `InputFlags`.
|
|
|
|
Две коллекции считаются равными, если они содержат одинаковое количество флагов и все соответствующие флаги равны (сравнение по имени, см. `InputFlag.__eq__`).
|
|
|
|
**Пример использования:**
|
|
|
|
.. literalinclude:: ../../../code_snippets/input_flags/snippet8.py
|
|
:linenos:
|
|
:language: python
|
|
|
|
-----
|
|
|
|
__contains__
|
|
~~~~~~~~~~~~
|
|
|
|
.. code-block:: python
|
|
:linenos:
|
|
|
|
__contains__(self, ingressable_item: object) -> bool
|
|
|
|
Проверяет, содержится ли введённый флаг в коллекции.
|
|
|
|
:param ingressable_item: Объект `InputFlag` для проверки.
|
|
:return: `True`, если флаг найден, иначе `False`.
|
|
:raises TypeError: Если `ingressable_item` не является экземпляром `InputFlag`.
|
|
|
|
Позволяет использовать оператор `in` для проверки наличия флага в коллекции.
|
|
|
|
**Пример использования:**
|
|
|
|
.. literalinclude:: ../../../code_snippets/input_flags/snippet9.py
|
|
:linenos:
|
|
:language: python
|
|
|
|
-----
|
|
|
|
Практические примеры
|
|
--------------------
|
|
|
|
Обработка всех флагов с проверкой статусов
|
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
Пример демонстрирует итерацию по всем введённым флагам с проверкой их статусов валидации:
|
|
|
|
.. literalinclude:: ../../../code_snippets/input_flags/snippet10.py
|
|
:linenos:
|
|
:language: python
|