Skip to main content

Check for the presence of prerequisite commands and returns their paths.

Project description

DevelopersToolbox logo
Github Build Status License Created
Release Released Commits since release

Overview

When you write a script or tool which uses subprocess to execute shell commands, you want to know if the commands are installed or not. This is particularly important if you are running multiple commands which rely on each other.

You can of course catch the exceptions through using check=True but if you need to know they all exist before you start your execution run then this doesn't help you as it only handled the failure it currently has.

This little package assist with that problem by taking a list of commands that must be installed and available and verifies that list at the start to ensure all of them are available.

Installation

pip install wolfsoftware.prereqs

Usage

import sys

from wolfsoftware.prereqs import check_prerequisite, PrerequisiteCheckError

prerequisites: list[str] = ["python", "git"]

try:
    command_paths: dict = check_prerequisite(prerequisites)
except PrerequisiteCheckError as err:
    print("Prerequisite check failed:")
    for error in err.errors:
        print(error)
    sys.exit(0)

print(command_paths['python'])

Once the checks have completed, you now have a dict of commands and their associated paths which you can then utilise to ensure you are executing your subprocesses with the full path.


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

wolfsoftware_prereqs-0.1.5.tar.gz (8.4 kB view details)

Uploaded Source

Built Distribution

wolfsoftware.prereqs-0.1.5-py3-none-any.whl (6.9 kB view details)

Uploaded Python 3

File details

Details for the file wolfsoftware_prereqs-0.1.5.tar.gz.

File metadata

  • Download URL: wolfsoftware_prereqs-0.1.5.tar.gz
  • Upload date:
  • Size: 8.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.4

File hashes

Hashes for wolfsoftware_prereqs-0.1.5.tar.gz
Algorithm Hash digest
SHA256 f0e4e54508e2440dd92a2a7c3f5394f07b78d13c7791e0574240b734419eb590
MD5 718cc07bd86e4ea5bec19c47fd856242
BLAKE2b-256 d4f09301834900202d97858c34be9b7278960a29667431cef39ad431777b2132

See more details on using hashes here.

File details

Details for the file wolfsoftware.prereqs-0.1.5-py3-none-any.whl.

File metadata

File hashes

Hashes for wolfsoftware.prereqs-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 25dba49a0b9599457f449414c7c474ae808cfe05ca7ec86fa668b8b0ef59f0a5
MD5 954ec2551317827ebf8ab59804628e54
BLAKE2b-256 43dec1be0999b2114b22e7c976e8313ca3f55eb33e2d243b387258e3cbd3cd85

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