mirror of
https://github.com/koloideal/Argenta.git
synced 2026-06-10 10:05:28 +03:00
ce7e24b924
The entire public api is covered with documentation in two languages - Russian and English. the library now supports the latest three versions of python - 3.12, 3.13 and 3.14 minor design changes: now, when a Boolean flag is entered, its value is an empty string, not None. tests have been adapted to the supported versions of python, readmi has been redesigned in two languages, German is no longer available.
79 lines
3.6 KiB
ReStructuredText
79 lines
3.6 KiB
ReStructuredText
.. _root_api_command_validation_status:
|
||
|
||
ValidationStatus
|
||
================
|
||
|
||
``ValidationStatus`` — это перечисление, которое определяет состояние валидации флага. Его задача — предоставить стандартные константы для отображения результата проверки. ``ValidationStatus`` используется в атрибуте ``status`` класса ``InputFlag``.
|
||
|
||
``ValidationStatus`` содержит три значения: **VALID** (корректный флаг), **INVALID** (некорректный) и **UNDEFINED** (незарегистрированный).
|
||
|
||
.. note::
|
||
|
||
Статус валидации устанавливается автоматически при создании экземпляра ``InputFlag`` на основе правил, заданных в соответствующем ``Flag``.
|
||
|
||
.. seealso::
|
||
|
||
Документация по :ref:`InputFlag <root_api_command_input_flag>` — класс введённого флага, использующий ``ValidationStatus``.
|
||
|
||
Документация по :ref:`Flag <root_api_command_flag>` — класс флага с правилами валидации.
|
||
|
||
Документация по :ref:`PossibleValues <root_api_command_possible_values>` — типы допустимых значений.
|
||
|
||
-----
|
||
|
||
VALID
|
||
~~~~~
|
||
|
||
.. code-block:: python
|
||
:linenos:
|
||
|
||
ValidationStatus.VALID = 'VALID'
|
||
|
||
Указывает, что флаг и его значение **прошли** валидацию.
|
||
|
||
Флаги с этим статусом соответствуют правилам, заданным в ``possible_values`` соответствующего ``Flag``. Их можно безопасно использовать в логике приложения без дополнительных проверок.
|
||
|
||
**Условия получения статуса** ``VALID``:
|
||
|
||
* Флаг с ``PossibleValues.NEITHER`` передан без значения.
|
||
* Флаг с ``PossibleValues.ALL`` передан с любым значением или без него.
|
||
* Значение флага входит в список разрешённых.
|
||
* Значение флага соответствует регулярному выражению.
|
||
|
||
-----
|
||
|
||
INVALID
|
||
~~~~~~~
|
||
|
||
.. code-block:: python
|
||
:linenos:
|
||
|
||
ValidationStatus.INVALID = 'INVALID'
|
||
|
||
Указывает, что флаг или его значение **не прошли** валидацию.
|
||
|
||
Флаги с этим статусом нарушают правила, заданные в ``possible_values`` соответствующего ``Flag``. Их следует обрабатывать как ошибочные.
|
||
|
||
**Условия получения статуса** ``INVALID``:
|
||
|
||
* Флаг с ``PossibleValues.NEITHER`` передан со значением.
|
||
* Значение флага не входит в список разрешённых.
|
||
* Значение флага не соответствует регулярному выражению.
|
||
* Флаг требует значение, но передан без него.
|
||
|
||
-----
|
||
|
||
UNDEFINED
|
||
~~~~~~~~~
|
||
|
||
.. code-block:: python
|
||
:linenos:
|
||
|
||
ValidationStatus.UNDEFINED = 'UNDEFINED'
|
||
|
||
Указывает, что введённый флаг не был зарегистрирован в команде.
|
||
|
||
**Условия получения статуса** ``UNDEFINED``:
|
||
|
||
* Введённый флаг не найден среди зарегистрированных для данной команды.
|