Skip to main content

CLI to automate the development workflow.

Project description

logo

License PyPI GitHub Code Style CI codecov pre-commit.ci status Downloads

toil: "Long, strenuous or fatiguing labour"

help

What is it?

pytoil is a small, helpful CLI to take the toil out of software development!

pytoil is a handy tool that helps you stay on top of all your projects, remote or local. It's primarily aimed at python developers but you could easily use it to manage any project!

pytoil is:

  • Easy to use ✅
  • Easy to configure ✅
  • Safe (it won't edit your repos at all) ✅
  • Snappy (it's asynchronous from the ground up and as much as possible is done concurrently, clone all your repos in seconds!) 💨
  • Useful! (I hope 😃)

Say goodbye to janky bash scripts 👋🏻

Background

Like many developers I suspect, I quickly became bored of typing repeated commands to manage my projects, create virtual environments, install packages, fire off cURL snippets to check if I had a certain repo etc.

So I wrote some shell functions to do some of this for me...

And these shell functions grew and grew and grew.

Until one day I saw that the file I kept these functions in was over 1000 lines of bash (a lot of printf's so it wasn't all logic but still). And 1000 lines of bash is waaaay too much!

And because I'd basically hacked it all together, it was very fragile. If a part of a function failed, it would just carry on and wreak havoc! I'd have to do rm -rf all_my_projects... I mean careful forensic investigation to fix it.

So I decided to make a robust CLI with the proper error handling and testability of python, and here it is! 🎉

Installation

As pytoil is a CLI program, I'd recommend installing with pipx.

pipx install pytoil

pipx-install

You can always fall back to pip

pip-install

pytoil will install everything it needs in python to work. However, it's full feature set can only be accessed if you have the following external dependencies:

  • git
  • conda (if you work with conda environments)
  • A directory-aware editor e.g. VSCode etc. (if you want to use pytoil to automatically open your projects for you)
  • poetry (if you want to create poetry environments)
  • flit (if you want to create flit environments)

Quickstart

pytoil is super easy to get started with.

After you install pytoil, the first time you run it you'll get something like this.

setup

If you say yes, pytoil will walk you through a few questions and fill out your config file with the values you enter. If you'd rather not do this interactively, just say no and it will instead put a default config file in the right place for you to edit later.

Once you've configured it properly, you can do things like...

See your local and remote projects

show-local

See which ones you have on GitHub, but not on your computer

show-diff

Easily grab a project, regardless of where it is

This project is available on your local machine...

checkout-local

This one is on GitHub...

checkout-remote

Create a new project and virtual environment in one go

new-venv

(And include custom packages, see the docs)

And even do this from a cookiecutter template

new-cookie

And loads more!

pytoil's CLI is designed such that if you don't specify any arguments, it won't do anything! just show you the --help. This is called being a 'well behaved' unix command line tool.

This is true for any subcommand of pytoil so you won't accidentally break anything if you don't specify arguments 🎉

And if you get truly stuck, you can quickly open pytoil's documentation with:

docs

Check out the docs for more 💥

Contributing

pytoil is an open source project and, as such, welcomes contributions of all kinds 😃

Your best bet is to check out the contributing guide in the docs!

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

pytoil-0.36.0.tar.gz (3.7 MB view details)

Uploaded Source

Built Distribution

pytoil-0.36.0-py3-none-any.whl (56.3 kB view details)

Uploaded Python 3

File details

Details for the file pytoil-0.36.0.tar.gz.

File metadata

  • Download URL: pytoil-0.36.0.tar.gz
  • Upload date:
  • Size: 3.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.15

File hashes

Hashes for pytoil-0.36.0.tar.gz
Algorithm Hash digest
SHA256 d99b055790f62f768c25a84b5861bae296d0e3a39174be52f96f6f4d4ebf8bb2
MD5 5f439facb68ea7cb93675a057be2ee8b
BLAKE2b-256 15fbcee709356e1ef091ade974feb70616ca81fa3e1408e9fdab1efab7be9285

See more details on using hashes here.

File details

Details for the file pytoil-0.36.0-py3-none-any.whl.

File metadata

  • Download URL: pytoil-0.36.0-py3-none-any.whl
  • Upload date:
  • Size: 56.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.15

File hashes

Hashes for pytoil-0.36.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e44511e56d0ae049864a1f712fb72f4a19ebac891cc7d14fa6671e2fb09e9c8b
MD5 9caf268198adb8a7a107c8b9b90d6bd7
BLAKE2b-256 94b8fb9b1ebc4456cca051c657a08f26b58570ffb522e1677d165528652657b9

See more details on using hashes here.

Supported by

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