An intelligent tool to map, analyze, and compile project source code into a single, context-optimized text file for Large Language Models (LLMs). Version 2 brings advanced dependency graph analysis, strict whitelist-based file inclusion, zero-dependency lightweight execution, and progress tracking!
- π€ Why ProjectScriber?
- β¨ Key Features
- π Quick Start
- πΎ Installation
- π₯οΈ Command-Line Usage
- βοΈ Configuration
- π€ Contributing & Development
When working with Large Language Models, providing the full context of a codebase is crucial for getting accurate analysis, documentation, or refactoring suggestions. However, blindly pasting an entire project wastes tokens and introduces noise.
ProjectScriber automates context building using a Whitelist-First philosophy and an Intelligent Scoring Engine. It analyzes your codebase's dependency graph (e.g., Python imports), determines which files are most relevant to the code you're working on, and bundles them into a single, clean markdown file, strictly respecting your token budgets and file-type configurations.
π Your Codebase β π¦ ProjectScriber β π LLM-Ready Context
| Feature | Description |
|---|---|
| π³ Smart Project Mapping | Generates a clear and intuitive tree view of your project's structure. |
| β‘ Native Rust Acceleration | Accelerates heavy I/O and directory scanning natively via a high-performance Rust backend. |
| π‘οΈ Whitelist Philosophy | By default, only recognized code and support files are included. Binary and lock files are automatically ignored. |
| π§ Intelligent Scoring Engine | Analyzes import graphs and file proximity to prioritize code modules that are directly related to your provided seed files. |
| π° Token Budgets | Set a hard limit on --max-tokens. Scriber will fit the most relevant files within your budget to save API costs. |
| π Live Progress & Stats | Built-in zero-dependency progress spinner and detailed statistics summary at the end of the run. |
-
Install Scriber:
pip install project-scriber
-
Navigate to your project's root and initialize config:
scriber --init
(This appends a
[tool.scriber]block to yourpyproject.toml. Use--forceto overwrite it.) -
Pack your context! Just point it to a file, folder, or let it scan the whole project:
scriber src/main.py --output context.md
-
Review your stats:
Scriber build completed. ---------------------------------------- Code files included: 15 Support files included: 4 Files omitted/skipped: 2 Estimated tokens: 12500 ---------------------------------------- Scriber pack written to: context.md
ProjectScriber distributes pre-compiled binary wheels for Linux, macOS, and Windows. A simple pip command is all you need:
pip install project-scriberOr if you use uv:
uv pip install project-scriberNote
If a pre-compiled wheel is not available for your platform/architecture, the package will automatically build from source, which requires a Rust compiler toolchain (Rust 1.70+) installed on your machine.
- Scan the current directory:
scriber . - Scan a specific file and its dependencies:
scriber src/my_module.py
- Interactive Setup: Create/Append a default configuration in
pyproject.toml(use--forceto overwrite it).scriber --init
| Option | Description |
|---|---|
paths |
Project file/folder paths used as seeds. Defaults to current directory. |
--profile |
Preset configuration profile. |
--config |
Path to pyproject.toml. Its parent directory becomes the project root. |
--path-base |
Base directory for relative paths when --config is used. |
--format |
Output format. |
--output |
Output file path, relative to project root unless absolute. Use '-' for stdout. |
--only-tree |
Render only scored tree/map, without file contents. |
--modules |
Enable automatic related module selection. |
--no-modules |
Disable automatic related module selection. |
--support |
Enable support files. |
--no-support |
Disable support files. |
--support-content |
Override default support file content policy. |
--max-files |
Maximum number of files in the pack. |
--max-tokens |
Approximate token budget for included file contents. 0 disables budget. |
--min-score |
Minimum score for non-seed files. |
--init |
Append a default [tool.scriber] config to pyproject.toml and exit. |
--force |
Allow --init to append even if [tool.scriber] already exists. |
--project |
Force project snapshot mode. |
--explain, --explain-selection |
Explain reason for file selection in detail. |
--explain-graph |
Print relation graph statistics and relations. |
--why |
Print exactly which rules/edges pulled the specified file into the pack. |
--graph-json |
Export the RelationGraph as a JSON file to the specified path. |
--validate-config |
Validate pyproject.toml scriber config. |
--dry-run |
Perform a dry run without saving the pack file. |
--open |
Open the output file automatically after creation. |
--timings |
Show execution timings for each phase. |
--version |
Show version information and exit. |
ProjectScriber comes with several preset profiles to quickly bias the file scoring and inclusion criteria:
| Profile | Description |
|---|---|
default |
Standard scoring behavior. |
audit |
Boosts tests, config files, CI environments, and dependency files. Assumes full support content inclusion. |
debug |
Boosts direct/reverse dependencies, tests, runtime support, and files close to the seed path. |
refactor |
Boosts files within the same package, related tests, and direct dependencies. |
docs |
Heavily boosts documentation files while suppressing test and code file scores. Assumes tree_only support content by default. |
You can integrate ProjectScriber directly into PyCharm's right-click context menu to quickly generate LLM context packs for any selected file or folder!
- Open Settings / Preferences β Tools β External Tools.
- Click the
+button to add a new tool. - Configure it as follows:
- Name:
Scriber - Group:
External Tools - Description:
Runs ProjectScriber on the selected directory and copies output to clipboard - Program:
scriber(or the absolute path to yourscriber.exee.g.,C:\Tools\Python\Python313\Scripts\scriber.exe) - Arguments:
"$FilePath$" --config $ProjectFileDir$/pyproject.toml - Working directory:
$ProjectFileDir$
Now, you can simply right-click any file or directory in your Project tree, select External Tools β Scriber, and the context pack will be generated instantly based on your project configuration!
ProjectScriber 2.1.0 configures itself through the standard pyproject.toml using the [tool.scriber] table.
Generate the default block using:
scriber --initNote
This is a minimal example. Run scriber --init to generate the full default configuration.
[tool.scriber]
format = "md"
max_tokens = 0 # 0 means unlimited
max_files = 0 # 0 means unlimited
only_tree = false # If true, file contents are omitted
allow_external_paths = false
[tool.scriber.modules]
enabled = true
content_min_score = 50
[tool.scriber.tokens]
estimator = "chars"
chars_per_token = 4
[tool.scriber.code_files]
# Only files matching these are considered "Code"
patterns = [
"**/*.py",
"**/*.js",
"**/*.ts",
"**/*.tsx"
]
[tool.scriber.support_files]
enabled = true
# Only files matching these are considered "Support"
patterns = [
"pyproject.toml",
"Dockerfile",
"**/*.svg"
]
[tool.scriber.support_files.content]
default = "auto"
auto_max_bytes = 10000
full = [
"pyproject.toml",
"requirements.txt",
"README.md"
]
tree_only = [
"**/*.svg"
]
[tool.scriber.hard_ignore]
# Folders ignored entirely during the initial scan
patterns = [
".git/**",
"__pycache__/**",
"node_modules/**",
".venv/**"
]ProjectScriber 2.1.0 uses a strict whitelist approach:
- Files must match either a
code_patternor asupport_patternto be considered. - Unrecognized extensions and binary files are automatically excluded, keeping your LLM context safe from binary garbage.
- Lock files are included in the tree by default, but their contents are omitted to save tokens.
- Support files can be marked as
tree_only(e.g.,**/*.svg), meaning they'll show up in the project map but their contents won't be read.
Contributions are welcome!
-
Clone the Repository:
git clone https://github.com/SunneV/ProjectScriber.git cd ProjectScriber -
Install Dependencies & Compile Extension (using
uvis recommended):uv sync --all-extras
(This synchronizes the virtual environment and compiles the native Rust extension automatically!)
-
Run Tests:
uv run pytest