Skip to main content

Simplified invocation of typer apps from any directory.

Project description

typer-invoke

pypi Project License - MIT

Simplified invocation of typer apps from any directory.

The idea is that you place typer apps in a directory in your project and then you can invoke them from anywhere inside that project.

Example

  1. Place scripts anywhere in the project (ex admin directory).
  2. Make sure they're typer apps.
  3. Register them in pyproject.toml.
  4. Invoke them from anywhere in the project.

Ex:

inv --help
inv help-full
inv build deploy
inv test unit --pri1

In this project there's the admin directory with scripts actually used for managing the project and the sample directory with more samples on how to use this package.

Why?

The main use case is for project management that require custom scripts for various tasks.
Wrapping those scripts as typer apps makes them easier to use.
Making typer easier to use makes those scripts even easier to use.

An alternative to:

Versus Invoke

The main driver for this project is as a replacement for Invoke, which I've been using for a while and found the following limitations:

  • --help and --list options are clunky, in that they need to be placed right after the inv command, ex:
    inv --help some.task
    
    Here a more common pattern is used and --help acts as both help and list:
    inv some task --help
    
    There's also help-full, which lists all tasks recursively:
  • inv help-full
    
  • Output can be subdued.
    If you use tools that have colors in their output, often that output is stripped of colors and other formatting. There are settings you can play with, but often it doesn't work.
  • Lack of support.
    Some issues and features have been piling up for a while, and I'm not sure if they will ever be addressed. Seems like the project has had new development recently, though.
    Typer is widely used and has a lot of support.

Other advantages (in my opinion):

  • Prettier.
    Developer experience counts. Other than more common usage patterns, Typer supports rich and Markdown formatting.
    Including using rich for logging, which is done in this project.
  • No dot . namespace.
    Invoke uses a dot . namespace for tasks, which is not very common when running scripts.
    Typer follows a normal CLI pattern. Namespaces are Typer apps and are separated by a space.

Invoke is the inspiration for this project, hence the name typer-invoke and keeping the inv command name.

Cool things about Invoke

Invoke concepts and features I was using that are not native to this project, but the workarounds work well:

  • Task dependencies.
    In Invoke, it's easy to declare a task dependent on others and they will be executed in the correct order.
    While we don't have this feature, it's very easy to simply call other functions and end up with the same functionality.
  • Namespaces (task groups)
    You can declare namespaces and whatever tasks you want in them.
    The same is done in Typer by with apps. Each app added is the equivalent of a namespace.
    Usually, one app is in one file, but it's not a requirement.
  • Dry runs
    The --dry option in Invoke is very useful and available to all tasks.
    Typer doesn't have this feature, but it's easy to add. See the examples in this project, under the admin directory.

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

typer_invoke-0.5.0.tar.gz (33.0 kB view details)

Uploaded Source

Built Distribution

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

typer_invoke-0.5.0-py3-none-any.whl (10.6 kB view details)

Uploaded Python 3

File details

Details for the file typer_invoke-0.5.0.tar.gz.

File metadata

  • Download URL: typer_invoke-0.5.0.tar.gz
  • Upload date:
  • Size: 33.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.32.5

File hashes

Hashes for typer_invoke-0.5.0.tar.gz
Algorithm Hash digest
SHA256 b8c7485332c2163fdbc57dee2853f6bda0058a29d028ece535d0b21ba2d0862e
MD5 6e5a3bc6346243bc5fbdde5a621bc9b3
BLAKE2b-256 55971106a6cc321e7941a3b3348258046f5bac9a10a2acfbac03631e696010e4

See more details on using hashes here.

File details

Details for the file typer_invoke-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: typer_invoke-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 10.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.32.5

File hashes

Hashes for typer_invoke-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 25b3e8fbeb0b6fc2a84777007acfe49a7e62b1ae244887a87126e42edc9fa342
MD5 1bc7c00f5f33bcc9e4109b57e18efff4
BLAKE2b-256 b8b63bd622231e184ec85c89e96b1d875f809cbc94ed35cf08dffc240b3e87e6

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