Skip to main content

Run and handle the output of multiple executables in pyallel (as in parallel)

Project description

Pyallel

Run and handle the output of multiple executables in pyallel (as in parallel)

https://github.com/Danthewaann/pyallel/assets/22531177/8685eb92-aac5-440a-9170-30fd1460c53f

Requires Python >=3.8

Tested on Linux and MacOS only

Quick start

pyallel can be installed using pip:

pip install pyallel

Once installed, you can run pyallel to see usage information, like so:

usage: pyallel [-h] [-t] [-n] [-V] [-v] [--colour {yes,no,auto}] [commands ...]

Run and handle the output of multiple executables in pyallel (as in parallel)

positional arguments:
  commands              list of quoted commands to run e.g "mypy ." "black ."

                        can provide environment variables to each command like so:

                             "MYPY_FORCE_COLOR=1 mypy ."

options:
  -h, --help            show this help message and exit
  -t, --no-timer        don't time how long each command is taking
  -n, --non-interactive
                        run in non-interactive mode
  -V, --verbose         run in verbose mode
  -v, --version         print version and exit
  --colour {yes,no,auto}
                        colour terminal output, defaults to "auto"

Currently you can provide a variable number of commands to run to pyallel, like so:

[!IMPORTANT] If you need to provide arguments to a command, you must surround the command and it's arguments in quotes!

pyallel "MYPY_FORCE_COLOR=1 mypy ." \
        "black --check --diff ." \
        "pytest ."

TODOs

  • Allow output for all provided commands to be streamed to stdout (this will require a re-work of how we print command output as we currently just print output once the command finishes)
  • Add CI checks to run the tests and linters against Python versions > 3.8
  • Add command mode arguments to support things like only tailing the last 10 lines of a command whilst it is running e.g. "tail=10 :: pytest ."
  • Add visual examples of pyallel in action
  • Fix bug in non-interactive streamed mode where all commands share the same amount of time taken as the longest running command
  • Fix bug in non-interactive streamed mode where calling readline doesn't account for EOF (if we are at EOF we shouldn't append a newline as more output could be appended to the current line)
  • Fix bug in streamed mode where we should use the number of terminal columns when determining when to truncate the line to fit within the screen (or properly handle wrapped lines)
  • Provide a way to set environment variables for each command to run with
  • Add test suite
  • Improve error handling when parsing provided commands (check they are valid executables)
  • Maybe make tail mode followed by an optional dump of all the command output once it finishes the default behaviour?
  • Add graceful Ctrl-C interrupt handling to streamed modes
  • Add a --colour flag to configure pyallel print colours
  • Setup build system to convert pyallel into a single file executable for ease of use and distribution
  • Add custom parsing of command output to support filtering for errors (like vim's errorformat)
  • Allow list of files to be provided to supply as input arguments to each command
  • Allow input to be piped into pyallel via stdin to supply as standard input to each command

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

pyallel-0.16.0.tar.gz (9.3 kB view details)

Uploaded Source

Built Distribution

pyallel-0.16.0-py3-none-any.whl (10.0 kB view details)

Uploaded Python 3

File details

Details for the file pyallel-0.16.0.tar.gz.

File metadata

  • Download URL: pyallel-0.16.0.tar.gz
  • Upload date:
  • Size: 9.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.12.0

File hashes

Hashes for pyallel-0.16.0.tar.gz
Algorithm Hash digest
SHA256 5b0fd785d5131b479848b55dea704fcca819cfda0834ceaf0cb0458348c2f900
MD5 5cc4e9de1dad7ec0e41d081f8579e5d1
BLAKE2b-256 3a42fc9e56b9944071383b1030cf7b1e0a727343a312c7f2e1cc1f7aeb4df582

See more details on using hashes here.

File details

Details for the file pyallel-0.16.0-py3-none-any.whl.

File metadata

  • Download URL: pyallel-0.16.0-py3-none-any.whl
  • Upload date:
  • Size: 10.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.12.0

File hashes

Hashes for pyallel-0.16.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b91503845153b89ed67fc5b4d5e6abee3e5b12b4fc1130cddf92d420208bfaa3
MD5 d18f4464c2a26fc9e5a6ac5fa01b4e33
BLAKE2b-256 b3ba7e0f6a69b0947fc391b464526271d4c9511bbb52bf1bc87388d16ab64610

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