Skip to content

DeezNutzHimself/pip-chronos

Repository files navigation

pip-chronos

pip-chronos is a command-line tool that automatically updates your requirements.txt files with the latest package versions from PyPI. Like the Greek god Chronos who governs time, this tool helps keep your dependencies up to date.

Features

  • Simple to Use: Run with a single command to update all requirements
  • Parallel Processing: Checks multiple packages concurrently for better performance
  • Flexible: Update a specific file or search directories for requirements files
  • Version Constraint Awareness: Handles all version specifiers (==, >=, <=, etc.)
  • Dependency Validation: Validates that updated dependencies can be installed together
  • Dry Run Mode: Preview changes without modifying files
  • Smart Detection: Preserves comments and formatting in requirements files

Installation

Install from PyPI:

pip install pip-chronos

Usage

Update all requirements files in the current directory and subdirectories:

pip-chronos

Update a specific requirements file:

pip-chronos path/to/requirements.txt

Run in dry-run mode (show changes without modifying files):

pip-chronos --dry-run

Exclude packages with version ranges (>=, <=, etc.):

pip-chronos --no-update-ranges

Use a custom pattern to find requirements files:

pip-chronos --pattern="**/requirements*.txt"

Skip dependency validation:

pip-chronos --no-validate

Options

positional arguments:
  path                  Directory or specific requirements file path (default: current directory)

options:
  -h, --help            show this help message and exit
  --pattern PATTERN     Glob pattern for finding requirements files (default: **/requirements.txt)
  --sequential          Run updates sequentially (no parallel processing)
  --no-update-ranges    Do not update packages with range operators (>=, <=, etc.)
  --no-validate         Skip validation of dependencies
  --dry-run             Show what would be updated without making changes
  --max-workers MAX_WORKERS
                        Maximum number of worker threads (default: 10)

Examples

Update all requirements files in the project:

pip-chronos

Update only a specific service subdirectory:

pip-chronos services/api-service/

Preview updates without making changes:

pip-chronos --dry-run

Exclude packages with version ranges (>=, <=, etc.):

pip-chronos --no-update-ranges

Use a custom pattern to find requirements files:

pip-chronos --pattern="**/requirements*.txt"

Skip dependency validation:

pip-chronos --no-validate

How It Works

  1. Finds all requirements.txt files in the specified directory (or uses a single file if provided)
  2. For each package with a version specification, it checks for the latest available version using pip index versions
  3. If a newer version is available, it updates the line in the requirements file
  4. By default, all packages with version specifiers are updated
  5. Validates that the updated dependencies can be installed together (unless --no-validate is specified)
  6. Preserves all comments and formatting in the requirements files

License

MIT

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages