Skip to main content

midir is a Python library designed to handle relative module dependencies by

Project description

midir

A library for resolving relative module dependencies.

Description

midir is a Python library designed to handle relative module dependencies by resolving directory paths in an intelligent and system-agnostic way. This library can be used to introspect the file structure of your project and manipulate Python's sys.path, allowing for dynamic module imports based on directory hierarchy. It is especially helpful for larger projects where file structure can become complex and static imports cumbersome to manage.

Features

  1. midir(path: str) -> str: Returns the directory name of the given file or directory path.

  2. get_caller() -> str: Returns the name of the file or the location (directory) where the current execution point is present.

  3. mipath(path: str = None) -> str: Returns the canonical (absolute) path of the current execution point or a provided path.

  4. midir(path: str = None) -> str: Returns the directory name where the current execution point is or from a provided path.

  5. root_levels(levels: int = 1) -> None: Makes directories available for import by adding them to sys.path. It starts from directory of the caller file and move up the directory hierarchy. The number of levels up to move is determined by input argument.

  6. root_suffix(suffix: str) -> None: Similar to root_levels, but instead of moving up a certain number of directories, it continues to move up until it finds a directory whose name ends with the provided suffix and adds that directory to sys.path.

  7. lsdir(path: str) -> List[str]: This function retrieves a sorted list of file and/or folder names from a specified directory path. Whether it returns file or folder names depends on the parameters set. It returns the full path of these files/folders if requested. Custom filter conditions can be applied. Raises errors if path isn't found or if no output requirements are specified. A warning is given if both file and folder parameters are set to true while a custom filter function is also specified.

Exceptions

  1. FolderNotFoundError: Custom exception raised when no folder matching the required conditions (in root_suffix) is found in the directory hierarchy.

Build instructions

  1. Building the package before uploading: 'python -m build' (from "midir").
  2. Upload the package to pypi: 'python -m twine upload --repository pypi dist/*'
  3. Install the package from pypi: 'python -m pip install midir'
  4. If any dependencies are required, edit the pyproject.toml file, "[project]" field, and add a dependencies key with a List\[str\] value, where each string is a pip-readable dependency.

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

midir-1.2.0.tar.gz (5.1 kB view details)

Uploaded Source

Built Distribution

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

midir-1.2.0-py3-none-any.whl (4.5 kB view details)

Uploaded Python 3

File details

Details for the file midir-1.2.0.tar.gz.

File metadata

  • Download URL: midir-1.2.0.tar.gz
  • Upload date:
  • Size: 5.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.1

File hashes

Hashes for midir-1.2.0.tar.gz
Algorithm Hash digest
SHA256 67c88444d1bde789a4ccf42a9a03da058ae2a955547d7c2ed64c6676679e8f07
MD5 c6a67d73e90b7412d6bcd876cd497b3f
BLAKE2b-256 3a9f52648a36160f1cd07fbe0f7c29a0f0d00d654afd363ae71b60f8c8592345

See more details on using hashes here.

File details

Details for the file midir-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: midir-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 4.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.1

File hashes

Hashes for midir-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a856a03c2695316298dbcc4d39073416b46fa185645efb1740afbe37059ebb2d
MD5 7298dc5ea60c441551e13dd5e81850c8
BLAKE2b-256 afbc91aa3a366b797a37aa5aa36394f773c00610e2cb45894c371a95296571f0

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