Skip to main content

A minimal library for smart Python imports with automatic path resolution

Project description

aimport

A minimal library for python: Adding support for smart imports with automatic path resolution.

Usage

import aimport

This automatically adds relevant directories to sys.path based on __aimport__ anchor files found in the directory tree.

Features

  • Smart path resolution: Automatically discovers project roots using __aimport__ anchor files
  • Anchor file content support: __aimport__ files can contain paths that will be used instead of the file location
  • Multiple paths support: NEW in v2.1.0: __aimport__ files can contain multiple paths, one per line
  • Fallback support: Falls back to __init__.py files when no __aimport__ files are found
  • Priority ordering: BREAKING CHANGE v2.0.0: New paths are now prepended to sys.path instead of appended, giving them higher import priority
  • Duplicate prevention: Avoids adding duplicate paths to sys.path
  • Automatic execution: Works immediately upon import

Breaking Changes in v2.0.0

⚠️ Import Priority Change: Starting with v2.0.0, discovered paths are prepended to sys.path instead of appended. This means modules in aimport-discovered directories will take precedence over existing sys.path entries. This change ensures that project-local modules are found before system or virtual environment modules.

New Features in v2.1.0

🎉 Multiple Paths Support: __aimport__ files can now contain multiple paths, one per line. This allows a single anchor file to reference multiple directories that should be added to the import path.

How It Works

  1. Anchor File Discovery: Searches upward from the starting directory for __aimport__ files
  2. Content Processing: If an __aimport__ file contains valid paths (one per line), those paths are used; otherwise the file's directory is used
  3. Multiple Path Support: Each line in an __aimport__ file is treated as a separate path - empty lines and whitespace-only lines are ignored
  4. Fallback Mechanism: If no __aimport__ files are found, falls back to searching for __init__.py files
  5. Path Priority: All discovered paths are added to the beginning of sys.path for higher import priority

Anchor File Format

__aimport__ files can contain:

  • Empty file: Uses the directory containing the file
  • Single path: Uses that path (absolute or relative)
  • Multiple paths: One path per line, uses all valid paths

Example __aimport__ file with multiple paths:

../lib
./vendor
/absolute/path/to/modules

Testing

The project includes comprehensive unit tests using pytest:

# Install development dependencies
uv sync --dev

# Run all tests
./test.sh

# Or run pytest directly
uv run pytest tests/ -v

Test Coverage

  • 23 comprehensive test cases
  • Full coverage of all functions and edge cases
  • Integration tests for complex directory structures
  • Behavior-focused testing (not implementation details)

Development

# Build distribution
python setup.py sdist

# Upload to PyPI
twine upload dist/*

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

aimport-2.1.0.tar.gz (8.8 kB view details)

Uploaded Source

Built Distribution

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

aimport-2.1.0-py3-none-any.whl (4.6 kB view details)

Uploaded Python 3

File details

Details for the file aimport-2.1.0.tar.gz.

File metadata

  • Download URL: aimport-2.1.0.tar.gz
  • Upload date:
  • Size: 8.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for aimport-2.1.0.tar.gz
Algorithm Hash digest
SHA256 a5f533c8c5d2be63422eba14ce34464d29da04dbd12577832755ed53b5b652c2
MD5 f27af141841e01a3503729447649a660
BLAKE2b-256 9145813e977d996163db52775d15cb370aec8bc1ea0a3eb33f3967b5aeb4ccf3

See more details on using hashes here.

File details

Details for the file aimport-2.1.0-py3-none-any.whl.

File metadata

  • Download URL: aimport-2.1.0-py3-none-any.whl
  • Upload date:
  • Size: 4.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for aimport-2.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 38ceb283bb2ced984a02ff428863e293416c03dea3429c08318d91e5c48bc6d2
MD5 07e69e882bc067771ff51d7a9ddb0a19
BLAKE2b-256 cb7e1ad43683dff19c8c42e1fa8eacef2afcf21e27bdd0c450651326ef4fbdc5

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