Skip to main content

A build backend for Odoo modules supporting multiple versions

Project description

Polytropos

Polytropos logo

Polytropos is a Python build backend for Odoo modules that enables writing code once and using it across multiple Odoo releases.

Features

  • Multi-release support: Write your module once, target multiple Odoo releases
  • Conditional manifests: Configure different manifest values per Odoo release, to let you include or exclude data files per release
  • Editable installs: Develop in editable is supported
  • PEP 517 compliant: Works with any PEP 517 compatible frontend

Quick Example

Replace your module's __manifest__.py with this pyproject.toml file:

[build-system]
requires = ["polytropos[build]"]
build-backend = "polytropos.build"

[project]
name = "odoo-addon-my-module"
version = "1.0.0"
dependencies = [
    # Specify supported Odoo versions here
    "odoo>=17"
]

# All versions have this data
[[tool.polytropos.manifest]]
depends = ["base"]
data = ["data/views.xml"]

# This section is only for Odoo 18+
[[tool.polytropos.manifest]]
releases = ">=18"
data = ["security/ir.model.access.csv"]

Then, inside the module folder:

# Don't forget the module must be a Python package
touch __init__.py

# Build wheels for different odoo releases
uv build --sdist
uv build --wheel --config-setting odoo_release=17.0
uv build --wheel --config-setting odoo_release=18.0
uv build --wheel --config-setting odoo_release=19.0

# List artifacts
ls -1 dist/
my_module-1.0.0.tar.gz
odoo_addon_my_module-17.0.1.0.0-py3-none-any.whl
odoo_addon_my_module-18.0.1.0.0-py3-none-any.whl
odoo_addon_my_module-19.0.1.0.0-py3-none-any.whl

Single branch, single code, multiple releases! 🤯

Installation

Python will auto-install the build backend when you build a module.

But yes, you can install a small CLI with:

pip install polytropos[cli]

For development, the recommended tool you need is uv. Then:

uvx polytropos[cli] --help-all

Why Polytropos?

Odoo modules traditionally require separate codebases or branches for each release. Polytropos solves this by generating release-specific code at build time, allowing you to maintain a single codebase.

So, it will help you or not depending on your product vision:

What is your product? What does that mean? Is Polytropos for you?
Odoo + its release + all addons in that release Customers that want new features must upgrade to newer Odoo releases. ⛔ No
Addons that should work always the same way Customers need new features and cannot wait for the upgrade to the next Odoo release; but when they upgrade, they expect the same features they have now ✅ Yes

Examples

Check out the examples folder for real-world modules with views, models, and tests that exercise the conditional logic.

Credits

Moduon logo

Polytropos is developed and maintained by Moduon. Need a professional Odoo partner? Contact us.

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

polytropos-3.2.2.tar.gz (128.1 kB view details)

Uploaded Source

Built Distribution

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

polytropos-3.2.2-py3-none-any.whl (17.5 kB view details)

Uploaded Python 3

File details

Details for the file polytropos-3.2.2.tar.gz.

File metadata

  • Download URL: polytropos-3.2.2.tar.gz
  • Upload date:
  • Size: 128.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.30 {"installer":{"name":"uv","version":"0.9.30","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for polytropos-3.2.2.tar.gz
Algorithm Hash digest
SHA256 61465e5508deeab9a4ef1eafc5bb5c3dc932be2db15c922ab9f9c6a2256af5a8
MD5 c5c346577e895a94e31e74b7a1a55dcc
BLAKE2b-256 bd11ff547aa1e50ecd5d15d185f84a90c43974ae4b76fb1ffa3f0a2a12f61b64

See more details on using hashes here.

File details

Details for the file polytropos-3.2.2-py3-none-any.whl.

File metadata

  • Download URL: polytropos-3.2.2-py3-none-any.whl
  • Upload date:
  • Size: 17.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.30 {"installer":{"name":"uv","version":"0.9.30","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":null,"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for polytropos-3.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 d368955af5240c8f6c96960a38c51f3803f406117b3076960bb01aa0340fe1aa
MD5 f22840b13adcbcf325a7942f6119fa64
BLAKE2b-256 90a79fe4de9a8f74cae201bf19e40e667f1fedd19749f84e6a37d9404392ce6b

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