Software Module Outline & Organization Summary Helper
Project description
smoosh: Software Module Outline & Organization Summary Helper
smoosh is a Python tool that helps developers understand and work with Python packages by generating LLM-optimized summaries of package structure, dependencies, and patterns. It creates compressed yet meaningful representations that can be effectively used in LLM prompts for package understanding and troubleshooting.
Features
- Intelligent Package Analysis: Parse and analyze Python packages using AST to understand structure, relationships, and patterns
- Smart Compression: Generate compact package representations while preserving essential information
- LLM-Optimized Output: Create summaries specifically formatted for effective use with Language Models
- Flexible Output Formats: Export summaries in JSON, YAML, Markdown, or custom LLM formats
- Command Line Interface: Easy-to-use CLI for quick package analysis
Installation
pip install smoosh
Quick Start
Analyze a Python package and generate a summary:
smoosh /path/to/package
Generate a focused API summary:
smoosh /path/to/package --focus api
Export to specific format:
smoosh /path/to/package --format json --output summary.json
Configuration
Create a smoosh.yaml in your project root:
analysis:
exclude_patterns: ['tests/*', '**/__pycache__/*']
max_depth: 3
focus: ['api', 'structure', 'patterns']
compression:
level: medium # low, medium, high
custom_patterns:
df_ops: "standard pandas operations"
api_call: "external service request/response"
output:
format: json
include_schema: true
max_tokens: 1000
Key Components
Code Analyzer
- AST-based Python file parsing
- Function and class relationship mapping
- Dependency analysis
- Pattern detection
Compression Engine
- Intelligent type abbreviation
- Pattern reference system
- Call chain compression
- Reference deduplication
Summary Generator
- Multiple output format support
- Customizable summary types
- LLM-optimized formatting
CLI Options
Options:
--focus TEXT Analysis focus (api, structure, patterns)
--format TEXT Output format (json, yaml, markdown, llm)
--output FILE Output file path
--compression-level Compression level (low, medium, high)
--to-clipboard Copy output to clipboard
--help Show this message and exit
Example Output
package:
name: "example_pkg"
structure:
modules: ["core", "utils", "api"]
patterns:
p1: "DataFrame processor"
p2: "Data validation"
api:
core:
- "process_data(df: DataFrame) -> DataFrame"
- "validate_input(D[s, Any]) -> bool"
utils:
- "load_config(path: s) -> Config"
Development
- Clone the repository:
git clone https://github.com/yourusername/smoosh.git
cd smoosh
- Create a virtual environment:
python -m venv venv
source venv/bin/activate # or `venv\Scripts\activate` on Windows
- Install development dependencies:
pip install -e ".[dev]"
- Run tests:
pytest
Contributing
- Fork the repository
- Create your feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'Add amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
License
This project is licensed under the MIT License - see the LICENSE file for details.
Acknowledgments
- Built with Python's ast module for code analysis
- Inspired by the need for better LLM-based code understanding tools
Roadmap
Future developments may include:
- Snakemake pipeline analysis
- Error pattern detection
- IDE integration
- Documentation generation
- Learning path creation
Support
For questions and support, please open an issue in the GitHub repository.
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file smoosh-0.1.0.tar.gz.
File metadata
- Download URL: smoosh-0.1.0.tar.gz
- Upload date:
- Size: 22.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.13.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0634605f14357bdaf5680cdb44e6d619b099f16836414ab3dc4693f58746d244
|
|
| MD5 |
9586907fa8be53d2811984cce7e74c42
|
|
| BLAKE2b-256 |
9b4b8369e91d667b68db68fe4ecca43d9c0e097f7ec952434316d85e418fb26e
|
File details
Details for the file smoosh-0.1.0-py3-none-any.whl.
File metadata
- Download URL: smoosh-0.1.0-py3-none-any.whl
- Upload date:
- Size: 19.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.13.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1d0af10ff13a83e3a8aef244356ed60bbc3660606c343d0fea8b1867f0e8897e
|
|
| MD5 |
a3a4a3aa4f4c5655a95c3a5a212b4cfe
|
|
| BLAKE2b-256 |
220dbcb0144b8c180f17729b636093811f92caf2702d2b1e73b7e3ad68512319
|