%global _empty_manifest_terminate_build 0
Name: python-click-extra
Version: 3.10.0
Release: 1
Summary: 🌈 Extra colorization and configuration loading for Click.
License: GPL-2.0-or-later
URL: https://github.com/kdeldycke/click-extra
Source0: https://mirrors.nju.edu.cn/pypi/web/packages/06/04/c7c0cb18120e8cb8629c975ae5e118e5b44b2c0cfaa63dc39b45d779e66f/click_extra-3.10.0.tar.gz
BuildArch: noarch
Requires: python3-Pallets-Sphinx-Themes
Requires: python3-boltons
Requires: python3-click
Requires: python3-click-log
Requires: python3-cloup
Requires: python3-commentjson
Requires: python3-furo
Requires: python3-importlib-metadata
Requires: python3-mergedeep
Requires: python3-pygments
Requires: python3-pygments-ansi-color
Requires: python3-pyyaml
Requires: python3-regex
Requires: python3-requests
Requires: python3-sphinx
Requires: python3-tabulate[widechars]
Requires: python3-tomli
Requires: python3-wcmatch
Requires: python3-xmltodict
%description
[data:image/s3,"s3://crabby-images/4b206/4b206fb7d20c4527c99433f0412dab08a66d18f2" alt="Last release"](https://pypi.python.org/pypi/click-extra)
[data:image/s3,"s3://crabby-images/839dd/839ddb23995ae7e64bc2ae7d198d750d965e1ae0" alt="Python versions"](https://pypi.python.org/pypi/click-extra)
[data:image/s3,"s3://crabby-images/d1f89/d1f899e0b6d29999f7a25d7fc3a2f8c56c12355f" alt="Unittests status"](https://github.com/kdeldycke/click-extra/actions/workflows/tests.yaml?query=branch%3Amain)
[data:image/s3,"s3://crabby-images/65c65/65c65c2e21edce3423484b1af7b4d44b69a1d7ee" alt="Documentation status"](https://github.com/kdeldycke/click-extra/actions/workflows/docs.yaml?query=branch%3Amain)
[data:image/s3,"s3://crabby-images/e8fec/e8fecb3d4b7ea2315f24681d351205b0cc7a7c7f" alt="Coverage status"](https://app.codecov.io/gh/kdeldycke/click-extra)
[data:image/s3,"s3://crabby-images/d6deb/d6deb705f0fc95930ebf13c40dd1feb9db00d7dd" alt="DOI"](https://zenodo.org/badge/latestdoi/418402236)
## What is Click Extra?
A ready-to-use wrapper for [Click](https://click.palletsprojects.com), the Python CLI framework.
It is a drop-in replacement with good defaults that saves lots of boilerplate code and frustration.
It also comes with
[workarounds and patches](https://kdeldycke.github.io/click-extra/issues.html) that have not
reached upstream yet (or are unlikely to).
## Example
It transforms this vanilla `click` CLI:
data:image/s3,"s3://crabby-images/e17e7/e17e72fe06ff8cfd5d1acb59533d5e4e0985f76e" alt="click CLI help screen"
Into this:
data:image/s3,"s3://crabby-images/e4b88/e4b88f784ae39d9a207f6c5583315858c1714bc0" alt="click-extra CLI help screen"
To undestrand how we ended up with the result above, [go read the tutorial](https://kdeldycke.github.io/click-extra/tutorial.html).
## Features
- Configuration file loader for:
- `TOML`
- `YAML`
- `JSON`, with inline and block comments (Python-style `#` and Javascript-style `//`)
- `INI`, with extended interpolation, multi-level sections and non-native types (`list`, `set`, …)
- `XML`
- Automatic inference of the configuration file structure from your CLI's options
- Remote loading of configuration files from URLs
- Optional strict validation of configuration
- Search of configuration file from default user folder and glob patterns
- Respect of `CLI` > `Configuration` > `Environment` > `Defaults` precedence
- `--show-params` option to debug parameters defaults, values, environment variables and provenance
- Colorization of help screens
- `-h`/`--help` option names (see [rant on other inconsistencies](https://blog.craftyguy.net/cmdline-help/))
- `--color`/`--no-color` option flag
- Recognize the `NO_COLOR` environment variable convention from [`no-color.org`](https://no-color.org)
- Colored `--version` option
- Colored `--verbosity` option and logs
- `--time`/`--no-time` flag to measure duration of command execution
- Platform recognition utilities (macOS, Linux, Windows, UNIX, *BSD, …)
- New conditional markers for `pytest`:
- `@skip_linux`, `@skip_macos` and `@skip_windows`
- `@unless_linux`, `@unless_macos` and `@unless_windows`
- `@destructive` and `@non_destructive`
- [`.. click:example::` and `.. click:run::` Sphinx directives](https://kdeldycke.github.io/click-extra/sphinx.html) to document CLI source code and their execution
- [ANSI-capable Pygments lexers](https://kdeldycke.github.io/click-extra/pygments.html#lexers) for shell session and console output
- Pygments styles and filters for ANSI rendering
- [Fixes 30+ bugs](https://kdeldycke.github.io/click-extra/issues.html) from other Click-related projects
- Rely on [`cloup`](https://github.com/janluke/cloup) to add:
- option groups
- constraints
- subcommands sections
- aliases
- command suggestion (`Did you mean ?`)
## Used in
Check these projects to get real-life examples of `click-extra` usage:
- data:image/s3,"s3://crabby-images/07be7/07be778e4479b167971e62d16f3a16348a00fd44" alt="GitHub stars" [Meta Package Manager](https://github.com/kdeldycke/meta-package-manager#readme)
\- A unifying CLI for multiple package managers.
- data:image/s3,"s3://crabby-images/4ef8c/4ef8c21ae6a2da4419acc8bbdf74a3e09823c07a" alt="GitHub stars" [Mail Deduplicate](https://github.com/kdeldycke/mail-deduplicate#readme) - A
CLI to deduplicate similar emails.
- data:image/s3,"s3://crabby-images/394f4/394f4b5234eb32d6e1a7b9f07785927c74b016b7" alt="GitHub stars" [fireproxng](https://github.com/Sprocket-Security/fireproxng#readme) - A rewrite of the fireprox tool.
- data:image/s3,"s3://crabby-images/40a59/40a5993b6c74773664c6c22a905797c3215bcf8f" alt="GitHub stars" [badger-proxy](https://github.com/hugolundin/badger#readme) - An mDNS-based reverse
proxy for naming services on a local network.
- data:image/s3,"s3://crabby-images/f80f6/f80f6cd36178e6c9caedead09692bd004a407c0d" alt="GitHub stars" [Molecular Dynamics Trajectory Analysis](https://github.com/tclick/mdstab#readme)
Feel free to send a PR to add your project in this list if you are relying on Click Extra in any way.
## Development
[Development guidelines](https://kdeldycke.github.io/meta-package-manager/development.html)
are the same as
[parent project `mpm`](https://github.com/kdeldycke/meta-package-manager), from
which `click-extra` originated.
%package -n python3-click-extra
Summary: 🌈 Extra colorization and configuration loading for Click.
Provides: python-click-extra
BuildRequires: python3-devel
BuildRequires: python3-setuptools
BuildRequires: python3-pip
%description -n python3-click-extra
[data:image/s3,"s3://crabby-images/4b206/4b206fb7d20c4527c99433f0412dab08a66d18f2" alt="Last release"](https://pypi.python.org/pypi/click-extra)
[data:image/s3,"s3://crabby-images/839dd/839ddb23995ae7e64bc2ae7d198d750d965e1ae0" alt="Python versions"](https://pypi.python.org/pypi/click-extra)
[data:image/s3,"s3://crabby-images/d1f89/d1f899e0b6d29999f7a25d7fc3a2f8c56c12355f" alt="Unittests status"](https://github.com/kdeldycke/click-extra/actions/workflows/tests.yaml?query=branch%3Amain)
[data:image/s3,"s3://crabby-images/65c65/65c65c2e21edce3423484b1af7b4d44b69a1d7ee" alt="Documentation status"](https://github.com/kdeldycke/click-extra/actions/workflows/docs.yaml?query=branch%3Amain)
[data:image/s3,"s3://crabby-images/e8fec/e8fecb3d4b7ea2315f24681d351205b0cc7a7c7f" alt="Coverage status"](https://app.codecov.io/gh/kdeldycke/click-extra)
[data:image/s3,"s3://crabby-images/d6deb/d6deb705f0fc95930ebf13c40dd1feb9db00d7dd" alt="DOI"](https://zenodo.org/badge/latestdoi/418402236)
## What is Click Extra?
A ready-to-use wrapper for [Click](https://click.palletsprojects.com), the Python CLI framework.
It is a drop-in replacement with good defaults that saves lots of boilerplate code and frustration.
It also comes with
[workarounds and patches](https://kdeldycke.github.io/click-extra/issues.html) that have not
reached upstream yet (or are unlikely to).
## Example
It transforms this vanilla `click` CLI:
data:image/s3,"s3://crabby-images/e17e7/e17e72fe06ff8cfd5d1acb59533d5e4e0985f76e" alt="click CLI help screen"
Into this:
data:image/s3,"s3://crabby-images/e4b88/e4b88f784ae39d9a207f6c5583315858c1714bc0" alt="click-extra CLI help screen"
To undestrand how we ended up with the result above, [go read the tutorial](https://kdeldycke.github.io/click-extra/tutorial.html).
## Features
- Configuration file loader for:
- `TOML`
- `YAML`
- `JSON`, with inline and block comments (Python-style `#` and Javascript-style `//`)
- `INI`, with extended interpolation, multi-level sections and non-native types (`list`, `set`, …)
- `XML`
- Automatic inference of the configuration file structure from your CLI's options
- Remote loading of configuration files from URLs
- Optional strict validation of configuration
- Search of configuration file from default user folder and glob patterns
- Respect of `CLI` > `Configuration` > `Environment` > `Defaults` precedence
- `--show-params` option to debug parameters defaults, values, environment variables and provenance
- Colorization of help screens
- `-h`/`--help` option names (see [rant on other inconsistencies](https://blog.craftyguy.net/cmdline-help/))
- `--color`/`--no-color` option flag
- Recognize the `NO_COLOR` environment variable convention from [`no-color.org`](https://no-color.org)
- Colored `--version` option
- Colored `--verbosity` option and logs
- `--time`/`--no-time` flag to measure duration of command execution
- Platform recognition utilities (macOS, Linux, Windows, UNIX, *BSD, …)
- New conditional markers for `pytest`:
- `@skip_linux`, `@skip_macos` and `@skip_windows`
- `@unless_linux`, `@unless_macos` and `@unless_windows`
- `@destructive` and `@non_destructive`
- [`.. click:example::` and `.. click:run::` Sphinx directives](https://kdeldycke.github.io/click-extra/sphinx.html) to document CLI source code and their execution
- [ANSI-capable Pygments lexers](https://kdeldycke.github.io/click-extra/pygments.html#lexers) for shell session and console output
- Pygments styles and filters for ANSI rendering
- [Fixes 30+ bugs](https://kdeldycke.github.io/click-extra/issues.html) from other Click-related projects
- Rely on [`cloup`](https://github.com/janluke/cloup) to add:
- option groups
- constraints
- subcommands sections
- aliases
- command suggestion (`Did you mean ?`)
## Used in
Check these projects to get real-life examples of `click-extra` usage:
- data:image/s3,"s3://crabby-images/07be7/07be778e4479b167971e62d16f3a16348a00fd44" alt="GitHub stars" [Meta Package Manager](https://github.com/kdeldycke/meta-package-manager#readme)
\- A unifying CLI for multiple package managers.
- data:image/s3,"s3://crabby-images/4ef8c/4ef8c21ae6a2da4419acc8bbdf74a3e09823c07a" alt="GitHub stars" [Mail Deduplicate](https://github.com/kdeldycke/mail-deduplicate#readme) - A
CLI to deduplicate similar emails.
- data:image/s3,"s3://crabby-images/394f4/394f4b5234eb32d6e1a7b9f07785927c74b016b7" alt="GitHub stars" [fireproxng](https://github.com/Sprocket-Security/fireproxng#readme) - A rewrite of the fireprox tool.
- data:image/s3,"s3://crabby-images/40a59/40a5993b6c74773664c6c22a905797c3215bcf8f" alt="GitHub stars" [badger-proxy](https://github.com/hugolundin/badger#readme) - An mDNS-based reverse
proxy for naming services on a local network.
- data:image/s3,"s3://crabby-images/f80f6/f80f6cd36178e6c9caedead09692bd004a407c0d" alt="GitHub stars" [Molecular Dynamics Trajectory Analysis](https://github.com/tclick/mdstab#readme)
Feel free to send a PR to add your project in this list if you are relying on Click Extra in any way.
## Development
[Development guidelines](https://kdeldycke.github.io/meta-package-manager/development.html)
are the same as
[parent project `mpm`](https://github.com/kdeldycke/meta-package-manager), from
which `click-extra` originated.
%package help
Summary: Development documents and examples for click-extra
Provides: python3-click-extra-doc
%description help
[data:image/s3,"s3://crabby-images/4b206/4b206fb7d20c4527c99433f0412dab08a66d18f2" alt="Last release"](https://pypi.python.org/pypi/click-extra)
[data:image/s3,"s3://crabby-images/839dd/839ddb23995ae7e64bc2ae7d198d750d965e1ae0" alt="Python versions"](https://pypi.python.org/pypi/click-extra)
[data:image/s3,"s3://crabby-images/d1f89/d1f899e0b6d29999f7a25d7fc3a2f8c56c12355f" alt="Unittests status"](https://github.com/kdeldycke/click-extra/actions/workflows/tests.yaml?query=branch%3Amain)
[data:image/s3,"s3://crabby-images/65c65/65c65c2e21edce3423484b1af7b4d44b69a1d7ee" alt="Documentation status"](https://github.com/kdeldycke/click-extra/actions/workflows/docs.yaml?query=branch%3Amain)
[data:image/s3,"s3://crabby-images/e8fec/e8fecb3d4b7ea2315f24681d351205b0cc7a7c7f" alt="Coverage status"](https://app.codecov.io/gh/kdeldycke/click-extra)
[data:image/s3,"s3://crabby-images/d6deb/d6deb705f0fc95930ebf13c40dd1feb9db00d7dd" alt="DOI"](https://zenodo.org/badge/latestdoi/418402236)
## What is Click Extra?
A ready-to-use wrapper for [Click](https://click.palletsprojects.com), the Python CLI framework.
It is a drop-in replacement with good defaults that saves lots of boilerplate code and frustration.
It also comes with
[workarounds and patches](https://kdeldycke.github.io/click-extra/issues.html) that have not
reached upstream yet (or are unlikely to).
## Example
It transforms this vanilla `click` CLI:
data:image/s3,"s3://crabby-images/e17e7/e17e72fe06ff8cfd5d1acb59533d5e4e0985f76e" alt="click CLI help screen"
Into this:
data:image/s3,"s3://crabby-images/e4b88/e4b88f784ae39d9a207f6c5583315858c1714bc0" alt="click-extra CLI help screen"
To undestrand how we ended up with the result above, [go read the tutorial](https://kdeldycke.github.io/click-extra/tutorial.html).
## Features
- Configuration file loader for:
- `TOML`
- `YAML`
- `JSON`, with inline and block comments (Python-style `#` and Javascript-style `//`)
- `INI`, with extended interpolation, multi-level sections and non-native types (`list`, `set`, …)
- `XML`
- Automatic inference of the configuration file structure from your CLI's options
- Remote loading of configuration files from URLs
- Optional strict validation of configuration
- Search of configuration file from default user folder and glob patterns
- Respect of `CLI` > `Configuration` > `Environment` > `Defaults` precedence
- `--show-params` option to debug parameters defaults, values, environment variables and provenance
- Colorization of help screens
- `-h`/`--help` option names (see [rant on other inconsistencies](https://blog.craftyguy.net/cmdline-help/))
- `--color`/`--no-color` option flag
- Recognize the `NO_COLOR` environment variable convention from [`no-color.org`](https://no-color.org)
- Colored `--version` option
- Colored `--verbosity` option and logs
- `--time`/`--no-time` flag to measure duration of command execution
- Platform recognition utilities (macOS, Linux, Windows, UNIX, *BSD, …)
- New conditional markers for `pytest`:
- `@skip_linux`, `@skip_macos` and `@skip_windows`
- `@unless_linux`, `@unless_macos` and `@unless_windows`
- `@destructive` and `@non_destructive`
- [`.. click:example::` and `.. click:run::` Sphinx directives](https://kdeldycke.github.io/click-extra/sphinx.html) to document CLI source code and their execution
- [ANSI-capable Pygments lexers](https://kdeldycke.github.io/click-extra/pygments.html#lexers) for shell session and console output
- Pygments styles and filters for ANSI rendering
- [Fixes 30+ bugs](https://kdeldycke.github.io/click-extra/issues.html) from other Click-related projects
- Rely on [`cloup`](https://github.com/janluke/cloup) to add:
- option groups
- constraints
- subcommands sections
- aliases
- command suggestion (`Did you mean ?`)
## Used in
Check these projects to get real-life examples of `click-extra` usage:
- data:image/s3,"s3://crabby-images/07be7/07be778e4479b167971e62d16f3a16348a00fd44" alt="GitHub stars" [Meta Package Manager](https://github.com/kdeldycke/meta-package-manager#readme)
\- A unifying CLI for multiple package managers.
- data:image/s3,"s3://crabby-images/4ef8c/4ef8c21ae6a2da4419acc8bbdf74a3e09823c07a" alt="GitHub stars" [Mail Deduplicate](https://github.com/kdeldycke/mail-deduplicate#readme) - A
CLI to deduplicate similar emails.
- data:image/s3,"s3://crabby-images/394f4/394f4b5234eb32d6e1a7b9f07785927c74b016b7" alt="GitHub stars" [fireproxng](https://github.com/Sprocket-Security/fireproxng#readme) - A rewrite of the fireprox tool.
- data:image/s3,"s3://crabby-images/40a59/40a5993b6c74773664c6c22a905797c3215bcf8f" alt="GitHub stars" [badger-proxy](https://github.com/hugolundin/badger#readme) - An mDNS-based reverse
proxy for naming services on a local network.
- data:image/s3,"s3://crabby-images/f80f6/f80f6cd36178e6c9caedead09692bd004a407c0d" alt="GitHub stars" [Molecular Dynamics Trajectory Analysis](https://github.com/tclick/mdstab#readme)
Feel free to send a PR to add your project in this list if you are relying on Click Extra in any way.
## Development
[Development guidelines](https://kdeldycke.github.io/meta-package-manager/development.html)
are the same as
[parent project `mpm`](https://github.com/kdeldycke/meta-package-manager), from
which `click-extra` originated.
%prep
%autosetup -n click-extra-3.10.0
%build
%py3_build
%install
%py3_install
install -d -m755 %{buildroot}/%{_pkgdocdir}
if [ -d doc ]; then cp -arf doc %{buildroot}/%{_pkgdocdir}; fi
if [ -d docs ]; then cp -arf docs %{buildroot}/%{_pkgdocdir}; fi
if [ -d example ]; then cp -arf example %{buildroot}/%{_pkgdocdir}; fi
if [ -d examples ]; then cp -arf examples %{buildroot}/%{_pkgdocdir}; fi
pushd %{buildroot}
if [ -d usr/lib ]; then
find usr/lib -type f -printf "/%h/%f\n" >> filelist.lst
fi
if [ -d usr/lib64 ]; then
find usr/lib64 -type f -printf "/%h/%f\n" >> filelist.lst
fi
if [ -d usr/bin ]; then
find usr/bin -type f -printf "/%h/%f\n" >> filelist.lst
fi
if [ -d usr/sbin ]; then
find usr/sbin -type f -printf "/%h/%f\n" >> filelist.lst
fi
touch doclist.lst
if [ -d usr/share/man ]; then
find usr/share/man -type f -printf "/%h/%f.gz\n" >> doclist.lst
fi
popd
mv %{buildroot}/filelist.lst .
mv %{buildroot}/doclist.lst .
%files -n python3-click-extra -f filelist.lst
%dir %{python3_sitelib}/*
%files help -f doclist.lst
%{_docdir}/*
%changelog
* Fri May 05 2023 Python_Bot - 3.10.0-1
- Package Spec generated