Skip to main content

A simple tool for analyzing your codebase architecture

Project description

treeline

Treeline Logo

A Python toolkit for analyzing and visualizing code structure, dependencies, and generating directory trees. treeline helps developers understand codebases through ASCII tree representations, interactive dependency graphs, and structural diff visualizations.

Screenshot

Installation

pip install treeline

Usage

As a python module

from treeline import treeline

# Generate and print tree structure
print(treeline("/path/to/directory"))

# Generate tree and save to markdown file
treeline("/path/to/directory", create_md=True)

# Advanced code analysis
from treeline.dependency_analyzer import ModuleDependencyAnalyzer
from treeline.diff_visualizer import DiffVisualizer
from pathlib import Path

# Analyze code dependencies
analyzer = ModuleDependencyAnalyzer()
analyzer.analyze_directory(Path("."))

# Generate interactive visualization
with open("dependencies.html", "w", encoding="utf-8") as f:
    f.write(analyzer.generate_html_visualization())

# Compare code structure between git commits
visualizer = DiffVisualizer()
diff_html = visualizer.generate_structural_diff("HEAD^", "HEAD")
with open("code_diff.html", "w", encoding="utf-8") as f:
    f.write(diff_html)

In terminal

Basic commands

# Show current directory tree
treeline
# Show specific directory tree
treeline /path/to/dir
# Create markdown file + report in html format (tree.md)
treeline -m
# Ignore specific patterns
treeline -i ".pyc,.git"
# Show help message
treeline -h

Visualization Options

# Hide all code structure details
treeline --hide-structure
# Hide function parameters
treeline --no-params

Configuration

.treeline-ignore

the .treeline-ignore will ignore whatever is in the folder.

Place .treeline-ignore in any directory to apply rules to that directory and its subdirectories.

# Ignore all .pyc files
*.pyc

# Ignore specific directories
__pycache__
.git
.venv

# Ignore specific files
config.local.py
secrets.py

Analysis configuration

Create a treeline.config.json to customize analysis settings:

{
  "complexity_threshold": 10,
  "ignore_patterns": [".pyc", ".git"],
  "relationship_types": ["imports", "calls", "contains"],
  "visualization": {
    "layout": "force-directed",
    "theme": "light"
  }
}

Contributing

  1. Fork the repository
  2. Create your feature branch (git checkout -b branch)
  3. Commit your changes (git commit -m 'cool stuff')
  4. Push to the branch (git push origin branch)
  5. Open a Pull Request

Sources for best practices

  1. https://peps.python.org/
  2. https://peps.python.org/pep-0008/
  3. https://google.github.io/styleguide/pyguide.html

Author

Oha

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

treeline-0.1.3.tar.gz (24.8 kB view details)

Uploaded Source

Built Distribution

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

treeline-0.1.3-py3-none-any.whl (27.2 kB view details)

Uploaded Python 3

File details

Details for the file treeline-0.1.3.tar.gz.

File metadata

  • Download URL: treeline-0.1.3.tar.gz
  • Upload date:
  • Size: 24.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.11.1

File hashes

Hashes for treeline-0.1.3.tar.gz
Algorithm Hash digest
SHA256 69edd7adf9314e8aeb6a9bc6c39c3fa58c4fdf5ba65cc887cf188e7154fba611
MD5 8ae0afb4a1960f14dd583d2793430671
BLAKE2b-256 8294d4f78a8ca5d854d59295106640de43afa23f74d83437e291889b6ec1ab7e

See more details on using hashes here.

File details

Details for the file treeline-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: treeline-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 27.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.11.1

File hashes

Hashes for treeline-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 6b859bceb92b6c9d30be2d90191a466ceca8031adb555595ff9f07c4e07322a2
MD5 9ece7282d7e6731985138851c2a20e9e
BLAKE2b-256 e92731a5406e1395ed0c47f9bd743b245293e454351394756a0905e5abed6d35

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