Socket
Socket
Sign inDemoInstall

mdpydoc

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

mdpydoc

This package is under construction. A stable version should be release soon as 1.0.0


Maintainers
1

MDPyDoc Logo

MDPyDoc 📝🐍

MDPyDoc is a powerful and flexible Python documentation generator that automatically creates markdown documentation from your Python source code. It analyzes the Abstract Syntax Tree (AST) of your Python files to extract docstrings, function signatures, and class structures, generating comprehensive and well-formatted documentation.

Features ✨

  • 📄 Generates markdown documentation for Python modules, classes, and functions
  • 🛠️ Supports both standard logging for enhanced logging capabilities
  • 📜 Includes source code in the documentation (optional)
  • ⚡ Utilizes parallel processing for faster documentation generation of large projects
  • 🎊 Provides colored console output for better readability during the generation process
  • 🔧 Supports custom logging levels
  • 🏷️ Automatically detects and documents class inheritance
  • 📊 Generates parameter tables for functions and methods

Installation 🚀

You can install MDPyDoc using pip:

pip install mdpydoc

Usage 🖥️

You can use MDPyDoc either as a command-line tool or integrate it into your Python scripts.

Command-line Usage 💻

python -m mdpydoc /path/to/source /path/to/docs --show-code --log-level DEBUG --max-workers 4
Arguments:
• src_directory: Source directory containing Python files
• docs_directory: Target directory for generated documentation
• --show-code: Include source code in documentation (optional)
• --log-level: Set the logging level (DEBUG, INFO, WARNING, ERROR, CRITICAL)
• --max-workers: Maximum number of worker threads (positive integer or 'None')

Python Script Usage 📜


from mdpydoc.doc_generator import DocGenerator

doc_generator = DocGenerator(
    show_code=True,
    log_level="INFO",
    max_workers=4
)

doc_generator.process_directory("/path/to/source", "/path/to/docs")

Components 🧩

MDPyDoc consists of several key components:

• DocGenerator: The main class that orchestrates the documentation generation process.
• MarkdownGenerator: Responsible for converting AST nodes into formatted Markdown.
• ASTParser: Parses the Abstract Syntax Tree of Python files.
• DocStringParser: Extracts and parses docstrings from AST nodes.
• FileProcessor: Processes individual Python files.
• AppLogger: A versatile logger.

Customization 🎨

MDPyDoc is designed to be extensible. You can customize the documentation generation process by subclassing and overriding methods in the MarkdownGenerator class.

Contributing 🤝

Contributions to MDPyDoc are welcome! Please feel free to submit a Pull Request.

License 📜

This project is licensed under the MIT License - see the LICENSE file for details.

Acknowledgments 🙏

Thanks to all contributors who have helped to improve MDPyDoc. Special thanks to the Python community for providing excellent tools and libraries that made this project possible.

TODO 📝

• Add support for generating documentation in different output formats (e.g., HTML, PDF)
• Implement a progress bar for large projects
• Add an option to exclude specific files or directories from documentation
• Implement cross-referencing between documented elements
• Add support for custom documentation templates

Support 📞

If you encounter any problems or have any questions, please open an issue on the GitHub repository.

FAQs


Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc