Skip to content

define.param.param_mixin

ParamMixin

Source code in /home/sean/sourcecode/arc/arc/define/param/param_mixin.py
class ParamMixin:
    SPECIAL_PARAMS = {"help", "version", "autocomplete"}
    callback: at.CommandCallback
    parent: t.Any
    config: Config

    @cached_property
    def param_def(self) -> ParamDefinition:
        # NOTE: This gets loaded lazily so we only actually
        # construct the param tree for the command
        # that is being executed. In development,
        # all definitions are constructed to check for
        # errors
        root = ParamDefinitionFactory(
            lambda: Join.with_space(t.cast("Command", self).doc.fullname),
            self.config.transform_snake_case,
        ).from_function(self.callback)

        self.__add_help_param(root)

        return root

    @cached_property
    def param_map(self) -> t.Mapping[str, Param[t.Any]]:
        data: AliasDict[str, Param[t.Any]] = AliasDict()
        for param in self.params:
            data[param.argument_name] = param
            data.add_alias(param.argument_name, param.param_name)
            if param.short_name:
                data.add_alias(param.argument_name, param.short_name)
            data.add_aliases(param.argument_name, *param.get_param_names())

        return data

    @property
    def params(self) -> t.Generator[Param[t.Any], None, None]:
        yield from self.param_def.all_params()

    @property
    def cli_params(self) -> t.Generator[Param[t.Any], None, None]:
        """All params that are available on the command line"""
        for param in self.params:
            if not param.is_injected:
                yield param

    @property
    def argument_params(self) -> t.Generator[ArgumentParam[t.Any], None, None]:
        for param in self.params:
            if param.is_argument:
                yield param  # type: ignore

    @property
    def key_params(self) -> t.Generator[KeywordParam[t.Any], None, None]:
        for param in self.params:
            if param.is_keyword:
                yield param  # type: ignore

    @property
    def option_params(self) -> t.Generator[OptionParam[t.Any], None, None]:
        for param in self.params:
            if param.is_option:
                yield param  # type: ignore

    @property
    def flag_params(self) -> t.Generator[FlagParam, None, None]:
        for param in self.params:
            if param.is_flag:
                yield param  # type: ignore

    @property
    def injected_params(self) -> t.Generator[InjectedParam[t.Any], None, None]:
        for param in self.params:
            if param.is_injected:
                yield param  # type: ignore

    def get_param(self, name: str) -> t.Optional[Param[t.Any]]:
        return self.param_map.get(name)

    def __add_help_param(self, group: ParamDefinition) -> None:
        group.params.appendleft(
            FlagParam(
                "help",
                short_name="h",
                type=TypeInfo.analyze(bool),
                description="Displays this help message",
                default=False,
                action=CustomHelpAction,
                expose=False,
            ),
        )

cli_params: t.Generator[Param[t.Any], None, None] property

All params that are available on the command line