forked from DRMTalks/devine
2.2 KiB
2.2 KiB
Development
This project is managed using Poetry, a fantastic Python packaging and dependency manager. Install the latest version of Poetry before continuing. Development currently requires Python 3.9+.
Set up
Starting from Zero? Not sure where to begin? Here's steps on setting up this Python project using Poetry. Note that Poetry installation instructions should be followed from the Poetry Docs: https://python-poetry.org/docs/#installation
- While optional, It's recommended to configure Poetry to install Virtual environments within project folders:
This makes it easier for Visual Studio Code to detect the Virtual Environment, as well as other IDEs and systems. I've also had issues with Poetry creating duplicate Virtual environments in the default folder for an unknown reason which quickly filled up my System storage.poetry config virtualenvs.in-project true
- Clone the Repository:
git clone https://github.com/devine-dl/devine cd devine
- Install the Project with Poetry:
This creates a Virtual environment and then installs all project dependencies and executables into the Virtual environment. Your System Python environment is not affected at all.poetry install
- Now activate the Virtual environment:
Note:poetry shell
- You can alternatively just prefix
poetry run
to any command you wish to run under the Virtual environment. - I recommend entering the Virtual environment and all further instructions will have assumed you did.
- JetBrains PyCharm has integrated support for Poetry and automatically enters Poetry Virtual environments, assuming the Python Interpreter on the bottom right is set up correctly.
- For more information, see: https://python-poetry.org/docs/basic-usage/#using-your-virtual-environment
- You can alternatively just prefix
- Install Pre-commit tooling to ensure safe and quality commits:
pre-commit install
Building Source and Wheel distributions
poetry build
You can optionally specify -f
to build sdist
or wheel
only.
Built files can be found in the /dist
directory.