Skip to main content

a PDM build hook for Polylith

Project description

PDM Build Hook for Polylith

A plugin for PDM and the Polylith Architecture.

This build hook will look for Polylith bricks in pyproject.toml and optionally re-write the imports made in the source code.

Installation

[build-system]
requires = ["pdm-backend", "pdm-polylith-bricks"]
build-backend = "pdm.backend"

The main usage of the build hook is to identify the included Polylith bricks from the pyproject.toml, and hand them over to the PDM build process. Bricks are added to a project with relative paths, from the bases and components folders in a Polylith Workspace. The hook will copy the bricks into the temporary .pdm-build folder that is created by the pdm build command. This will make the built wheel and sdist include proper paths to the source code.

Polylith Bricks are defined in the tool.polylith.bricks section of the pyproject.toml:

[tool.polylith.bricks]
"../../bases/my_namespace/my_base" = "my_namespace/my_base"
"../../components/my_namespace/my_component" = "my_namespace/my_component

Polylith documentation

the Python tools for the Polylith Architecture

The build hook also add support for building Python libraries by re-writing source code with a custom top namespace.

Why re-write code?

Building libraries is supported in the Python tools for the Polylith Architecture, but you will need to consider that code will share the same top namespace with any other library built from the same monorepo.

This can be a problem when more than one of your libraries are installed into the same virtual environment. Python libraries by default are installed in a "flat" folder structure, two libraries with the same top namespace will collide.

A Solution: add a custom top namespace during packaging of the library with PDM and this build hook.

How is this done?

The code in this repo uses AST (Abstract Syntax Tree) parsing to modify source code. The Python built-in ast module is used to parse and un-parse Python code.

What's the output from this plugin?

Without any custom namespace in the configuration: no changes in the code. Building and packaging as-is.

With a Top Namespace configuration

[tool.polylith.build]
top-namespace = "my_custom_namespace"
my_custom_namespace/
    my_namespace/
        /my_package
           __init__.py
           my_module.py

Before:

from my_namespace.my_package import my_function

After:

from my_custom_namespace.my_namespace.my_package import my_function

Polylith Documentation

the Python tools for the Polylith Architecture

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

pdm_polylith_bricks-1.3.7.tar.gz (9.0 kB view details)

Uploaded Source

Built Distribution

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

pdm_polylith_bricks-1.3.7-py3-none-any.whl (15.3 kB view details)

Uploaded Python 3

File details

Details for the file pdm_polylith_bricks-1.3.7.tar.gz.

File metadata

  • Download URL: pdm_polylith_bricks-1.3.7.tar.gz
  • Upload date:
  • Size: 9.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.1

File hashes

Hashes for pdm_polylith_bricks-1.3.7.tar.gz
Algorithm Hash digest
SHA256 38c4a0eedebff7e4e729aee30c9f80670bfdcac081b4c2bc589c93d6ee68ef23
MD5 182c32e69d75bcce79e4b1d19246d852
BLAKE2b-256 395a4a06c594e3100e5783d13a9b1b5f5e9927876137b7525b71d659c376710b

See more details on using hashes here.

File details

Details for the file pdm_polylith_bricks-1.3.7-py3-none-any.whl.

File metadata

File hashes

Hashes for pdm_polylith_bricks-1.3.7-py3-none-any.whl
Algorithm Hash digest
SHA256 853611424e437c4007d09f33fa208147dddaceea5ad4af4b459932d554c3ea9c
MD5 01ca3a3782531a96a78e8e89f7c7f29e
BLAKE2b-256 e2fba1c1da2475e5331f86285b47222985f990cde3ce10ab0580cdd59d1c0c02

See more details on using hashes here.

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