forked from pool/python-argh
* The typing hints introspection feature is automatically
enabled for any command (function) which does not have any
arguments specified via @arg decorator.
* A small change in the legacy argument mapping policy
BY_NAME_IF_HAS_DEFAULT concerning the order of variadic
positional vs. keyword-only arguments. The following function
now results in main alpha [args ...] beta instead of main
alpha beta [args ...]: def main(alpha, *args, beta): ...
This does not concern the default name mapping policy. Even
for the legacy one it's an edge case which is extremely
unlikely to appear in any real-life application.
* Added experimental support for basic typing hints (issue
#203) The following hints are currently supported: str, int,
float, bool (goes to type); list (affects nargs), list[T]
(first subtype goes into type); Literal[T1, T2, ...]
(interpreted as choices); Optional[T] AKA T | None (currently
interpreted as required=False for optional and nargs="?" for
positional arguments; likely to change in the future as use
cases accumulate). The exact interpretation of the type
hints is subject to change in the upcoming versions of Argh.
* Added always_flush argument to dispatch() (issue #145)
* High-level functions argh.dispatch_command() and
argh.dispatch_commands() now accept a new parameter
old_name_mapping_policy. The behaviour hasn't changed
because the parameter is True by default. It will change to
False in Argh v.0.33 or v.1.0.
OBS-URL: https://build.opensuse.org/package/show/devel:languages:python/python-argh?expand=0&rev=38
77 lines
2.4 KiB
RPMSpec
77 lines
2.4 KiB
RPMSpec
#
|
|
# spec file for package python-argh
|
|
#
|
|
# Copyright (c) 2024 SUSE LLC
|
|
#
|
|
# All modifications and additions to the file contributed by third parties
|
|
# remain the property of their copyright owners, unless otherwise agreed
|
|
# upon. The license for this file, and modifications and additions to the
|
|
# file, is the same license as for the pristine package itself (unless the
|
|
# license for the pristine package is not an Open Source License, in which
|
|
# case the license is the MIT License). An "Open Source License" is a
|
|
# license that conforms to the Open Source Definition (Version 1.9)
|
|
# published by the Open Source Initiative.
|
|
|
|
# Please submit bugfixes or comments via https://bugs.opensuse.org/
|
|
#
|
|
|
|
|
|
%{?!python_module:%define python_module() python-%{**} python3-%{**}}
|
|
Name: python-argh
|
|
Version: 0.31.0
|
|
Release: 0
|
|
Summary: An argparse wrapper
|
|
License: LGPL-3.0-or-later
|
|
URL: https://github.com/neithere/argh/
|
|
Source: https://files.pythonhosted.org/packages/source/a/argh/argh-%{version}.tar.gz
|
|
BuildRequires: %{python_module flit-core}
|
|
BuildRequires: %{python_module pip}
|
|
BuildRequires: %{python_module pytest}
|
|
BuildRequires: %{python_module setuptools}
|
|
BuildRequires: fdupes
|
|
BuildRequires: python-rpm-macros
|
|
BuildArch: noarch
|
|
%python_subpackages
|
|
|
|
%description
|
|
This Python module provides a wrapper for argparse with support for hierarchical
|
|
commands that can be bound to modules or classes.
|
|
|
|
Features that argh adds to argparse:
|
|
|
|
* mark a function as a CLI command and specify its arguments before the parser
|
|
is instantiated;
|
|
* nested commands made easy: no messing with subparsers (though they are of
|
|
course used under the hood);
|
|
* infer agrument type from the default value;
|
|
* infer command name from function name;
|
|
* add an alias root command help for the --help argument;
|
|
* enable passing unwrapped arguments to certain functions instead of a
|
|
argparse.Namespace object.
|
|
|
|
Argh is fully compatible with argparse. argh-agnostic and argh-aware code
|
|
can be mixed. Keep in mind that argh.dispatch does some extra
|
|
work that a custom dispatcher may not do.
|
|
|
|
%prep
|
|
%autosetup -p1 -n argh-%{version}
|
|
|
|
%build
|
|
%pyproject_wheel
|
|
|
|
%install
|
|
%pyproject_install
|
|
%python_expand %fdupes %{buildroot}%{$python_sitelib}
|
|
|
|
%check
|
|
# do not run test_integration, which requires dropped iocapture
|
|
rm tests/test_integration.py
|
|
%pytest -v
|
|
|
|
%files %{python_files}
|
|
%doc README.rst
|
|
%{python_sitelib}/argh/
|
|
%{python_sitelib}/argh-%{version}.dist-info
|
|
|
|
%changelog
|