Build a package¶
Python packaging is slowly evolving. To all agree on the way forward, together, a PEP is needed.
The issue¶
When python -m build
runs, the build front end calls the build
backend in a subprocess. Somewhere along the way, neglected to clearly
specify how to pass arguments along so they are available within the subprocess.
We are in that weird interm period. Waiting for a PEP to appear so open discussions on how to handle this situation can occur
How to¶
If setuptools worked as expected, this would be the build command
python -m build -C--kind="1.0.0" -C--set-lock="0"
This would build the package with version 1.0.0 and dependencies unlocked.
Good news and bad news
The good news is this works for building drain-swamp
Bad news is all other packages will need to use an interm workaround.
Create an environment variable holding the absolute path to a .toml
file
containing the config_settings
export DS_CONFIG_SETTINGS=/tmp/setuptools-build.toml
cat <<-EOF > "$DS_CONFIG_SETTINGS"
[project]
name = "whatever"
version = "99.99.99a1.dev6"
[tool.config-settings]
kind="1.0.0"
set-lock="0"
EOF
python -m build
The project section is so the .toml
file is valid.
Note all user input, from the command line, are str. So within the
.toml
, only str data type is acceptable
Build process walk through¶
If techno babble is not your thing or will lead to a brain hemorrhage, skip this section
python -m build
calls setuptools, which delegates to a build
front end, within a subprocess calls a build back end, neglects to
pass thru the command line arguments, and finally drain-swamp.
Which is left scratching it’s head thinking, but but but where are the command line arguments (aka config_settings)?
For now, it’s accessible by looking for the environment variable,
DS_CONFIG_SETTINGS
, and from there the .toml
file.
If not found, the entire build process will exit, with an explanation exactly how to resolve the issue.
If found, drain-swamp plugin manager runs build plugins. That deals with the package version and creating/refreshing dependency locks symlink
After drain-swamp, setuptools-scm stuff runs, since, in our
pyproject.toml
, there is no [tool.setuptools-scm] section,
setuptools-scm version stuff is not run.
The setuptools-scm file finders does not require [tool.setuptools-scm] section and therefore is run.
Your build plugins¶
Learn how to write a (build) plugin
Check out the pluggy [docs] [example]
plugin specs, drain_swamp.monkey.hooks.specs
- ds_before_version_infer(config_settings: dict[str, typing.Any]) -> str | None:
- ds_on_version_infer(config_settings: dict[str, typing.Any]) -> str | None:
- ds_after_version_infer(config_settings: dict[str, typing.Any]) -> str | None:
These plugin hooks indicates to the plugin manager when to run your plugin.
When plugins are run revolves around when the package version is set. before on or after.
For example, the refresh dependency locks symlink plugin runs, before. Cuz it’s package version agnostic (doesn’t care one way or the other)