Skip to main content

CLI to automate the development workflow.

Project description

logo

License PyPI GitHub Code Style Hatch project Ruff 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.38.2.tar.gz (3.7 MB view details)

Uploaded Source

Built Distribution

pytoil-0.38.2-py3-none-any.whl (56.9 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for pytoil-0.38.2.tar.gz
Algorithm Hash digest
SHA256 8c256c4157212f179e6d846f2bbe8f4bdde433b7aad34d4f57698f9f99c816ea
MD5 7c233ecc0a657aa07472aa3469d7d6d0
BLAKE2b-256 e79285709bb1af29b820d70e79839a64a4f4467dd9505325a124f9230cca9e8d

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for pytoil-0.38.2-py3-none-any.whl
Algorithm Hash digest
SHA256 ce847e9d5572d7ec82247ffde0c5a3737589b45ea07f9d24b00c78ee0680a6dd
MD5 a7076b4ed2717de64a355cbe1617f67f
BLAKE2b-256 11c821c0800d7c6165bee43f9e94e55812de8bd3b23912f185e67ccf168850b4

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