Skip to main content

Reasonable defaults for Click CLI applications.

Project description

Nob.py

Reasonable defaults for Click CLI applications with rich logging...
... and additional goodies.

  1. Installation
  2. Usage
  3. Contributing
  4. TODOs

Installation

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

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"

Get more usage examples in the Wiki.

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:

  1. 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"
    
  2. Install just:

    cargo install --locked just just-lsp
    

    List all available recipes by typing just.

  3. Sync the codebase dependencies

    Without explicit --all-extras syncing, 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

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

nob_py-0.1.0.tar.gz (18.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

nob_py-0.1.0-py3-none-any.whl (24.8 kB view details)

Uploaded Python 3

File details

Details for the file nob_py-0.1.0.tar.gz.

File metadata

  • Download URL: nob_py-0.1.0.tar.gz
  • Upload date:
  • Size: 18.5 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

Hashes for nob_py-0.1.0.tar.gz
Algorithm Hash digest
SHA256 b3a38d485f4419fd17c5a00ad548be803a69c2a27c4ed9ddd6d9be80597f4308
MD5 08b885d6d7c33e111b59cd495d95f829
BLAKE2b-256 ccd877717ec498eebd01e23a4c8e0d0bbfcd9b8314005e43f5439e5ca7f0f84b

See more details on using hashes here.

File details

Details for the file nob_py-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: nob_py-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 24.8 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

Hashes for nob_py-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 064f7bb44383dbba88acb76fe69f487ad96af66564ca9d64f8181c802e2c3783
MD5 911f77b7c7396aa8f3efe2d4b2d39949
BLAKE2b-256 dd2048bafd3aafe2d9ab1e254db5922ab001484953a3967584517329c4ad8dec

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page