Reasonable defaults for Click CLI applications.
Project description
Nob.py
Reasonable defaults for Click CLI applications with rich logging...
... and additional goodies.
Installation
uv add nob.py
Or:
pip install nob.py
Install from GitHub
uv add git+https://github.com/ThomasByr/nob.py --branch main
or lock a specific version:
uv add git+https://github.com/ThomasByr/nob.py --tag v0.1.0
Or if you are using pip
pip install git+https://github.com/ThomasByr/nob.py@main
You may directly also use @ with a tag, for example:
pip install git+https://github.com/ThomasByr/nob.py@v0.1.0
Usage
[!Note] Get more usage examples in the Wiki.
import logging
from nob import cli
@cli.cmd()
@cli.opt("--name", required=True, help="Greet someone.")
def hello(lg: logging.Logger, name: str):
lg.info("Hello %s", name)
if __name__ == "__main__":
hello()
run with:
uv run <file.py> --name "Eric Norbert"
Replace uv run with python once your environment is activated - if you don't use uv.
Contributing
[!Important] Sign your commits.
Clone the repository if you have direct right access or clone your fork:
git clone git@github.com:ThomasByr/nob.py nob
Then:
-
Install uv if you haven't already (or run
uv self update):Linux Bash
curl -LsSf https://astral.sh/uv/install.sh | sh
Windows Powershell
powershell -ExecutionPolicy ByPass -c "irm https://astral.sh/uv/install.ps1 | iex"
-
Install just:
cargo install --locked just just-lsp
List all available recipes by typing
just. -
Sync the codebase dependencies
Without explicit
--all-extrassyncing, some recipes will not evaluate on optional dependencies and functionalities.just sync
Run the following recipes before committing.
We (I) work with ruff, ty and pytest.
just format check ty test
[!TIP] Install pre-commit hooks:
just pc-install.
To keep hooks somewhat fast enough, they will only check (not forcibly fix) for typing and formatting.
TODOs
- workflow to publish to PyPI
- update the progress module to use human count and duration
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file nob_py-0.1.3.tar.gz.
File metadata
- Download URL: nob_py-0.1.3.tar.gz
- Upload date:
- Size: 19.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.16 {"installer":{"name":"uv","version":"0.11.16","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
015c1fde89474f3dd4b4b1856b4a4c503dab884be3dff9399508f8921d270497
|
|
| MD5 |
62bf64741e99f9ee401db5927c737372
|
|
| BLAKE2b-256 |
3b4db62a11fbd7ee83e53d1f66a66ca911d318897044876d4a961bfa650a4601
|
File details
Details for the file nob_py-0.1.3-py3-none-any.whl.
File metadata
- Download URL: nob_py-0.1.3-py3-none-any.whl
- Upload date:
- Size: 26.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.16 {"installer":{"name":"uv","version":"0.11.16","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5983e455975e0961497414de28d70f332352292be8d54c4095e4d4e39a349ee5
|
|
| MD5 |
972e9b0c905b12ccf87cb9eb660cae13
|
|
| BLAKE2b-256 |
390e2777be6f58403ff8e6d042cdd2459ca320d6bfc058a209cfea7b2cde218a
|