Skip to main content

A lightweight archive downloader for pre-built binary dependencies.

Project description

Poks

CI Status Test coverage percentage

uv Ruff pypeline pre-commit

PyPI Version Supported Python versions License


Source Code: https://github.com/cuinixam/poks


A lightweight, cross-platform archive downloader for pre-built binary dependencies. Inspired by Scoop, Poks provides a uniform way to install and manage developer tools using simple JSON manifests.

While Poks includes a CLI, its main purpose is to be used programmatically to manage dependencies in your Python projects and automation scripts.

Features

  • Programmatic API: First-class Python support for integrating into your tools
  • Cross-Platform: Works on Windows, Linux, and macOS
  • No Admin Rights: Installs tools in user space
  • Deterministic: Pin exact versions in manifests for reproducible builds
  • Relocatable: The apps directory is self-contained and portable

Installation

Install via pip (or your favorite package manager):

pip install poks

Programmatic Usage

Poks is designed to be easily integrated into your Python scripts.

Quick Start

from pathlib import Path
from poks.poks import Poks

# Initialize Poks with a root directory for apps/cache
poks = Poks(root_dir=Path("./.tools"))

# Install a specific application
# (Automatically searches configured buckets)
poks.install_app("cmake@3.28.1")

# Install from a configuration file (poks.json)
poks.install(Path("poks.json"))

# Uninstall
poks.uninstall(app_name="cmake", version="3.28.1")

CLI Usage

You can also use Poks from the command line.

Installation (CLI)

Install via pipx:

pipx install poks

Quick Start

Create a poks.json configuration file:

{
    "buckets": [
        {
            "name": "main",
            "url": "https://github.com/poks/main-bucket.git"
        }
    ],
    "apps": [
        {
            "name": "cmake",
            "version": "3.28.1",
            "bucket": "main"
        }
    ]
}

Install the defined tools:

poks install -c poks.json

CLI Reference

# Install tools from config file
poks install -c poks.json

# Install a specific tool
poks install zephyr-sdk@0.16.5-1 --bucket main

# Uninstall a specific version
poks uninstall zephyr-sdk@0.16.5-1

# Uninstall all versions of an app
poks uninstall zephyr-sdk

# Uninstall everything
poks uninstall --all

Documentation

For detailed specifications and manifest format, see docs/specs.md.

Contributing

We welcome contributions! Please see our development guidelines below.

Setup and Development

This project uses pypeline for build automation and uv for dependency management.

  1. Install Prerequisites: Ensure you have Python 3.10+ and uv installed. pypeline will automatically use uv to create virtual environments.

  2. Install Pypeline:

    uv tool install pypeline-runner
    
  3. Run the Pipeline: The pipeline handles environment setup, linting, and testing.

    # Run full pipeline (lint + tests)
    pypeline run
    
    # Run only linting (pre-commit hooks)
    pypeline run --step PreCommit
    
    # Run tests with specific Python version
    pypeline run --step CreateVEnv --step PyTest --single --input python_version=3.13
    

AI Agents

For AI agents contributing to this project, please explicitly read and follow AGENTS.md for detailed instructions on workflows, coding standards, and verification steps.

Credits

Copier

This package was created with Copier and the browniebroke/pypackage-template project template.

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

poks-0.3.0.tar.gz (19.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

poks-0.3.0-py3-none-any.whl (20.5 kB view details)

Uploaded Python 3

File details

Details for the file poks-0.3.0.tar.gz.

File metadata

  • Download URL: poks-0.3.0.tar.gz
  • Upload date:
  • Size: 19.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for poks-0.3.0.tar.gz
Algorithm Hash digest
SHA256 1823fee35927d1d34b182b7469f725e15c2cd2cb093dbd575616fc49bf86e66f
MD5 93b1af51db6a56cc21aa2ba56be92b8e
BLAKE2b-256 3b9d6521550349029b90efb3bf6d9f32674b4e1bceb0a74ea946b78ebffa8ca1

See more details on using hashes here.

Provenance

The following attestation bundles were made for poks-0.3.0.tar.gz:

Publisher: ci.yml on cuinixam/poks

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file poks-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: poks-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 20.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for poks-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b5b2b4aebb68d744264326ac4e8c8f339918b18c4dd9b52c5db11bfe67bd2fe6
MD5 a0de50b05e67a9f0d56abacb2658aee3
BLAKE2b-256 47a0148368a976a9045f3f87f4d43ede01dac962845f18b1a01d1c657ad810b5

See more details on using hashes here.

Provenance

The following attestation bundles were made for poks-0.3.0-py3-none-any.whl:

Publisher: ci.yml on cuinixam/poks

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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