This repo attempts to standardize the structure of the Python-based project's repositories using modern Python packaging and configuration techniques. Using this blog post as inspiration, this repository serves as the base for all new Python projects and is mergeable in existing repositories as well.
git init my-new-repo
cd my-new-repo
git pull git@github.com:nexB/skeleton
# Create the new repo on GitHub, then update your remote
git remote set-url origin git@github.com:nexB/your-new-repo.git
From here, you can make the appropriate changes to the files for your specific project.
cd my-existing-project
git remote add skeleton git@github.com:nexB/skeleton
git fetch skeleton
git merge skeleton/main --allow-unrelated-histories
This is also the workflow to use when updating the skeleton files in any given repository.
More usage instructions can be found in docs/skeleton-usage.rst
.
- 2023-07-18:
- Add macOS-13 job in azure-pipelines.yml
- 2022-03-04:
- Synchronize configure and configure.bat scripts for sanity
- Update CI operating system support with latest Azure OS images
- Streamline utility scripts in etc/scripts/ to create, fetch and manage third-party dependencies There are now fewer scripts. See etc/scripts/README.rst for details
- 2021-09-03:
configure
now requires pinned dependencies via the use ofrequirements.txt
andrequirements-dev.txt
configure
can now accept multiple options at once- Add utility scripts from scancode-toolkit/etc/release/ for use in generating project files
- Rename virtual environment directory from
tmp
tovenv
- Update README.rst with instructions for generating
requirements.txt
andrequirements-dev.txt
, as well as collecting dependencies as wheels and generating ABOUT files for them.
- 2021-05-11:
- Adopt new configure scripts from ScanCode TK that allows correct configuration of which Python version is used.