Skip to main content

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

Project description

PyCodeMap

Version: 1.0.4

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.4.tar.gz (6.9 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.4-py3-none-any.whl (7.8 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: pycodemap-1.0.4.tar.gz
  • Upload date:
  • Size: 6.9 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.4.tar.gz
Algorithm Hash digest
SHA256 dbbfba86ec73411c15aa0e9bf6129a036c2615014138da12477f0e94368b393c
MD5 6639d58395f32976ff416df7629b300f
BLAKE2b-256 b66dcd48f00551ce3971fbf9792dfb09aeb6c4e8f3152d663e2f4c91fd266494

See more details on using hashes here.

File details

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

File metadata

  • Download URL: pycodemap-1.0.4-py3-none-any.whl
  • Upload date:
  • Size: 7.8 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.4-py3-none-any.whl
Algorithm Hash digest
SHA256 28c09b8eddf56aff675e38c9a9b7a5e0d2a30269e5ffbfb93ee0a5fe8af31590
MD5 8085d8e57d5d189b403b94adfbe3aa5b
BLAKE2b-256 637a25e230d7ab3df73ef377a5b2c3094cb2e56f90cae742acfc489ba97e1252

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