@sprungg/code-mapper
v1.3.0
Published
JavaScript/TypeScript project structure analyzer
Downloads
31
Readme
@sprungg/code-mapper
Description
@sprungg/code-mapper
is a JavaScript/TypeScript project structure analyzer that helps you visualize and understand the structure of your codebase. It analyzes file structures and Abstract Syntax Trees (ASTs) to provide insights into your project's architecture.
Features
- Analyze JavaScript/TypeScript project structures
- Visualize file and folder hierarchies
- Detect and display import/export relationships
- Generate project statistics
Installation
npm install @sprungg/code-mapper
Usage
Programmatic API
You can also use it programmatically in your Node.js applications:
import { mapProject, logStats } from '@sprungg/code-mapper';
async function analyzeProject() {
const projectPath = './path/to/your/project';
const graph = await mapProject(projectPath);
logStats(graph, projectPath);
}
analyzeProject();
Output Example
When you run @sprungg/code-mapper
, it generates a structured output of your project. Here's an example of what the output might look like:
The projectGraph
object returned by mapProject
is structured as follows:
{
"nodes": [
{
"id": "src/index.ts",
"type": "FILE",
"name": "index.ts",
"path": "src/index.ts",
"metadata": {
"extension": ".ts"
}
},
{
"id": "src/analyzers",
"type": "FOLDER",
"name": "analyzers",
"path": "src/analyzers"
}
],
"relationships": [
{
"id": "rel-1",
"type": "IMPORTS",
"sourceId": "src/index.ts",
"targetId": "src/analyzers/fileAnalyzer.ts"
}
]
}
logStat
formats the output to a more readable format:
=== Project Structure Analysis ===
📁 Files and Folders:
📂 src
📄 src/index.ts
📂 src/analyzers
📄 src/analyzers/fileAnalyzer.ts
📄 src/analyzers/astAnalyzer.ts
🔗 Dependencies:
src/index.ts → src/analyzers/fileAnalyzer.ts
src/index.ts → src/analyzers/astAnalyzer.ts
📊 Statistics:
Total Files: 3
Total Folders: 2
Total Import Dependencies: 2
CLI Usage
You can use code-mapper directly from the command line:
npx @sprungg/code-mapper [project-path] [format] [output-file]
Options:
- project-path: Path to your project (default: current directory)
- format: Output format - 'json' or 'text' (default: text)
- output-file: Optional file path to save the output
Examples:
# Analyze current directory and display text output
npx @sprungg/code-mapper .
# Analyze specific directory and save JSON output
npx @sprungg/code-mapper ./my-project json output.json
# Analyze and save text output
npx @sprungg/code-mapper . text output.txt
CLI Usage with Git Plugin
The Git plugin can be enabled with various options:
# Basic usage with git information
npx @sprungg/code-mapper --git
# Exclude commit messages from git info
npx @sprungg/code-mapper --git-no-message
# Specify number of commits to include in history
npx @sprungg/code-mapper --git-history=5
# Combined with other options
npx @sprungg/code-mapper /path/to/project --git --format json -o output.json
Git plugin options:
--git
: Enable git information collection--git-no-message
: Exclude commit messages from git info--git-history=N
: Include N most recent commits (default: 1)
Contributing
Contributions are welcome! Please read the CONTRIBUTING.md for guidelines on how to contribute to this project.
License
This project is licensed under the MIT License - see the LICENSE file for details.
Contact
For any questions or feedback, please open an issue on GitHub.