Skip to main content

Create the ultimate Odoo addons_path constructor

Project description

odoo-addons-path

PyPI version Python 3.10+ Tests

Automatically detect and construct Odoo addons_path for various project layouts.

Problem

Different Odoo project frameworks use different directory structures:

  • Trobz, Camptocamp, Odoo.sh, Doodba each have unique layouts
  • Manual configuration is error-prone and time-consuming
  • Developers need consistent addons_path across team projects

Solution

odoo-addons-path auto-detects your project layout and generates the correct configuration:

$ odoo-addons-path /home/project
/home/project/odoo/addons,/home/project/addons/repo1,/home/project/addons/repo2

Installation

pip install odoo-addons-path

Quick Start

CLI Usage

# Auto-detect layout (detector runs)
odoo-addons-path /path/to/your/odoo/project

# With verbose output (categorized paths)
odoo-addons-path /path/to/project --verbose

# Manual addon paths - detector SKIPPED (uses explicit path only)
odoo-addons-path /path/to/project --addons-dir "./addons/*/18.0, ./custom"

# Manual Odoo path - detector SKIPPED (uses explicit path only)
odoo-addons-path /path/to/project --odoo-dir /opt/odoo

# Both explicit - detector SKIPPED (uses both paths)
odoo-addons-path /path/to/project --odoo-dir /opt/odoo --addons-dir "./custom"

# Use environment variable with auto-detection
export CODEBASE=/home/project
odoo-addons-path

Detector Skip Behavior: Detector is skipped if ANY explicit path is provided (--addons-dir or --odoo-dir). This ensures predictable behavior with explicit configuration.

Programmatic Usage

from pathlib import Path
from odoo_addons_path import get_addons_path

# Auto-detect layout
paths = get_addons_path(Path("/path/to/project"))
print(paths)
# Output: /path/to/project/addons,/path/to/project/enterprise

# With options
paths = get_addons_path(
    codebase=Path("/home/project"),
    addons_dir=[Path("/home/project/custom")],
    verbose=True
)

Supported Layouts

Auto-detects these Odoo project organizational patterns:

Layout Marker Detection Status
Trobz .trobz/ directory Explicit marker ✓ Supported
Camptocamp (C2C) Dockerfile with label File content ✓ Supported
Odoo.sh 4-dir structure Directory check ✓ Supported
Doodba .copier-answers.yml YAML config ✓ Supported
Generic Any __manifest__.py Recursive search ✓ Fallback

See tests/data/ directory for layout examples.

Features

  • Zero Configuration: Works out-of-the-box for standard layouts
  • Multiple Interfaces: CLI tool and Python library
  • Flexible Input: Glob patterns, comma-separated paths, environment variables
  • Type Safe: Full Python type hints
  • Well Tested: 5 real-world layout patterns covered
  • Production Ready: Used in multiple Odoo teams

Documentation

Development

Setup

uv sync
uv run pre-commit install

Testing

# Single version
make test

# All supported versions (3.10-3.13)
tox

# Quality checks
make check

Release

Releases are automated via semantic versioning on merge to main:

git commit -m "feat: add new feature"  # Creates MINOR version
git commit -m "fix: bug fix"           # Creates PATCH version
git commit -m "feat!: breaking change" # Creates MAJOR version

Requirements

  • Python 3.10+
  • pyyaml
  • typer >= 0.19.2

License

MIT

Contributing

Contributions welcome! See CONTRIBUTING.md for guidelines.

Status

v1.0.0 - Stable release (Nov 25, 2025)

See CHANGELOG.md for version history.

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

odoo_addons_path-1.0.1.tar.gz (67.5 kB view details)

Uploaded Source

Built Distribution

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

odoo_addons_path-1.0.1-py3-none-any.whl (19.5 kB view details)

Uploaded Python 3

File details

Details for the file odoo_addons_path-1.0.1.tar.gz.

File metadata

  • Download URL: odoo_addons_path-1.0.1.tar.gz
  • Upload date:
  • Size: 67.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.5

File hashes

Hashes for odoo_addons_path-1.0.1.tar.gz
Algorithm Hash digest
SHA256 8c9920af7e3ebf4ac530a8a43d717c216d5972253e991dce7cb5819126386074
MD5 7faf45c3ed14995ea88425c196ab8838
BLAKE2b-256 3b7b4a04973a116e1ef96b9f56f9c49c2080692239988d4efa25322898197629

See more details on using hashes here.

File details

Details for the file odoo_addons_path-1.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for odoo_addons_path-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 b59f6b0c12e2c06d450ec2cede989a0669d518aa11d91be0b4417a6f7f019890
MD5 fbc6579eee95c1b1a6d30fd08c45b003
BLAKE2b-256 1549b6cb07ec3956f205eeeeed0d30c5f4ec15397641d11875700ee38e56d78a

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