Skip to main content

A Python Project Template for Long-Term Maintainability.

Project description

Serious Scaffold Python

A Python Project Template for Long-Term Maintainability.

CI CommitLint DevContainer Release Renovate Semantic Release Coverage Release PyPI PyPI - Python Version GitHub

pdm-managed pre-commit Checked with mypy Ruff Conventional Commits Pydantic v2 Copier Serious Scaffold Python Open in Dev Containers

[!WARNING] Serious Scaffold Python is in the Alpha phase. Frequent changes and instability should be anticipated. Any feedback, comments, suggestions and contributions are welcome!

Serious Scaffold Python

Serious Scaffold Python is crafted for long-term, maintainable Python projects. It includes GitHub Actions and GitLab CI/CD, automated dependency updates via Renovate, and comprehensive linting, testing, and documentation. Key integrations like pdm for environment and dependency management, typer for CLI development, and pydantic for configuration enhance project robustness. With copier’s easy project setup and continuous updating, your project stays aligned with best practices for sustainable development. Pre-configured dev containers and cross-platform CI support ensure maintainability from the start.

If you find this helpful, please consider sponsorship.

🛠️ Features

🔧 Prerequisites

pipx is required to manage the standalone tools used across the development lifecycle. Please refer to pipx's installation instructions here. Once pipx is set up, install the copier for project generation using the following command:

pipx install copier==9.4.1

🚀 Quickstart

  1. Generate the project.

    copier copy gh:serious-scaffold/ss-python /path/to/project
    
  2. Navigate to the project directory and initialize a git repository.

    cd /path/to/project
    git init
    
  3. Install standalone tools.

    make prerequisites
    
  4. Set up the development environment.

    make dev
    
  5. Commit the initialized project.

    git add .
    git commit -m "Initialize from serious-scaffold."
    
  6. That's it! Feel free to focus on the coding within src folder.

📜 License

MIT License, for more details, see the LICENSE file.

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

ss_python-0.0.57.tar.gz (502.8 kB view details)

Uploaded Source

Built Distribution

ss_python-0.0.57-py3-none-any.whl (6.3 kB view details)

Uploaded Python 3

File details

Details for the file ss_python-0.0.57.tar.gz.

File metadata

  • Download URL: ss_python-0.0.57.tar.gz
  • Upload date:
  • Size: 502.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: pdm/2.20.1 CPython/3.12.3 Linux/6.8.0-1017-azure

File hashes

Hashes for ss_python-0.0.57.tar.gz
Algorithm Hash digest
SHA256 1baa892c42b2f75ba6f099fc4d082827b469b3e0c5a199c38799178fe6c9edf7
MD5 3e9336ec7c1f2f8940fd23289c739cac
BLAKE2b-256 7aa91ea0f157f598622fcee6edbced30f103cfd49bf3892cbc4d4a2dc24f09a5

See more details on using hashes here.

File details

Details for the file ss_python-0.0.57-py3-none-any.whl.

File metadata

  • Download URL: ss_python-0.0.57-py3-none-any.whl
  • Upload date:
  • Size: 6.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: pdm/2.20.1 CPython/3.12.3 Linux/6.8.0-1017-azure

File hashes

Hashes for ss_python-0.0.57-py3-none-any.whl
Algorithm Hash digest
SHA256 bf3d0f36c3275f79c6114c7a3cd31a1744efeae53763729b1340f053995f370a
MD5 3c54043862ff49dcef0023107d51ab58
BLAKE2b-256 261ae87660449e9fa681c240e0272f2928c00cbcf27355b3d645836b8a28dffc

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