Skip to main content

A CLI tool for extracting and outlining the structure of Python code.

Project description

PyCodeMap

Version: 1.0.2

Description

PyCodeMap is a command-line tool to extract and outline the structure of Python code. It helps developers visualize the organization of classes, methods, functions, and attributes in their projects, providing a clear and detailed overview.

Installation

You can install PyCodeMap directly from PyPI:

pip install pycodemap

Usage

After installation, you can run the tool using the pycodemap command.

You can also use python -m pycodemap to run the tool from the command line.

Note that if pip installs the package into directory that is not in the PATH, you will need to add the directory to the PATH or use python -m pycodemap.

To add the directory to the PATH, you can run the following command or add it to your .bashrc or .zshrc file:

export PATH="$PATH:/path/to/pycodemap/directory"

Basic Commands

  • Analyze the current directory:

    pycodemap .
    python -m pycodemap .
    
  • Save the output to a file:

    pycodemap . -o structure.txt
    pycodemap . --output structure.txt
    
  • Show only functions:

    pycodemap . -c
    pycodemap . --functions-only
    
  • Show only classes:

    pycodemap . -c
    pycodemap . --classes-only
    
  • Exclude attributes from the output:

    pycodemap . -a
    pycodemap . --no-attributes
    
  • Minimalistic output:

    pycodemap . -m
    pycodemap . --minimalistic
    
  • Exclude specific directories or files:

    pycodemap . -i "dir_to_ignore|file_to_ignore"
    pycodemap . --ignore "dir_to_ignore|file_to_ignore"
    

You can combine multiple options to get the desired output.

pycodemap . -cam -i "dir_to_ignore|file_to_ignore"
pycodemap . --classes-only --no-attributes --minimalistic --ignore "dir_to_ignore|file_to_ignore"

Contributing

How to contribute

Follow these steps to set up your development environment and submit your changes:

  1. Fork the repository:

  2. Clone your forked repository:

    git clone https://github.com/your_username/PyCodeMap.git
    cd PyCodeMap
    
  3. Install pycodemap in editable mode from source code:

    pip install -e .
    

    Now you can develop and test your changes locally by running pycodemap. All changes will be automatically reflected in your local installation.

  4. Create a new branch for your feature or bugfix:

    git checkout -b your-feature-branch
    
  5. Set up pre-commit to ensure code quality:

    pip install pre-commit
    pre-commit install
    

    Before committing your changes, pre-commit checks your code for formatting. If issues are found, the commit process halts, and pre-commit automatically resolves them. You'll need to stage these changes and try to commit again.

  6. Make your changes and write tests.

  7. Run all tests:

    pytest
    
  8. Commit your changes and push them to your forked repository:

    git push origin your-feature-branch
    
  9. Create a pull request:

    • Go to the original PyCodeMap repository.
    • Click "Pull Requests" and then "New Pull Request."
    • Select your branch from your forked repository and create the pull request.

Guidelines

  • Ensure your code is formatted with black.
  • Use isort for imports and autoflake to remove unused imports.
  • Check your code with pylint using configuration from .pylintrc.
  • Write tests for any new features or bug fixes.
  • Provide a clear description of the changes in your pull request.

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

pycodemap-1.0.2.tar.gz (6.8 kB view details)

Uploaded Source

Built Distribution

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

pycodemap-1.0.2-py3-none-any.whl (7.7 kB view details)

Uploaded Python 3

File details

Details for the file pycodemap-1.0.2.tar.gz.

File metadata

  • Download URL: pycodemap-1.0.2.tar.gz
  • Upload date:
  • Size: 6.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.10.12

File hashes

Hashes for pycodemap-1.0.2.tar.gz
Algorithm Hash digest
SHA256 8cd4b45870d028c9a94084ad29ecb5b3f2326aeed6e4fb9e36b9c3310a50b497
MD5 16fbed6af3f4b9b5c79f83a85dfe0d73
BLAKE2b-256 873c7a2ed3776bb14f9e859612140457ec77da217ed2a1355bdd1890446f2564

See more details on using hashes here.

File details

Details for the file pycodemap-1.0.2-py3-none-any.whl.

File metadata

  • Download URL: pycodemap-1.0.2-py3-none-any.whl
  • Upload date:
  • Size: 7.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.10.12

File hashes

Hashes for pycodemap-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 89d9fd526cfed80c4a0b0b5992959bb7e876ad754b5d89ef4d79c8ad35d8fdfe
MD5 86b3e69f6a668bf2aac62d3e514c8cd0
BLAKE2b-256 9dfb420380e5056d68758d19b3562338c93cdfbebd36e770b37ea366656c6dd2

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