Dirfy
Instantly scaffold directory & file structures from any ASCII/Unicode “tree” diagram 🚀
📋 Problem Statement
Modern AI code generators (ChatGPT, Copilot, etc.) excel at producing code snippets—but often describe project layouts as ASCII or Unicode “tree” diagrams. Manually translating those diagrams into a real folder/file structure is:
- Time-consuming & error-prone when projects are large or deeply nested
- Tedious to type out dozens or hundreds of
mkdir -p/touchcommands - Prone to typos and forgotten directories
Dirfy automates the entire process: feed it any tree diagram (text or file), and it creates the exact structure—no matter how big—in seconds.
✨ Features
- Parse ASCII & Unicode tree diagrams
- Dry-run mode (
-d,--dry-run) to preview changes without writing - Verbose logging (
-v,--verbose) for full action reports - Custom indent support (
-i N,--indent=N) for non-standard tree outputs - Path prefixing (
-p DIR/,--prefix=DIR/) to scaffold under any base folder - Live progress bar and clear success/failure summary
- Zero external dependencies (pure Ruby ≥ 2.7)
🚀 Installation
# via RubyGems
gem install dirfy
# or from source
git clone https://github.com/ahmedmelhady7/dirfy.git
cd dirfy
bundle install
rake install
💡 Usage
From a file
dirfy path/to/tree.txt
Via pipe
cat tree.txt | dirfy
Common Options
| Flag | Description |
|---|---|
-d, --dry-run |
Preview actions without creating files/directories |
-v, --verbose |
Show each create/skip/fail action |
-i N, --indent=N |
Set spaces per tree level (default: 4) |
-p DIR/, --prefix= |
Prepend DIR/ to every generated path |
-h, --help |
Display help and exit |
🛠️ Examples
Given a file myapp_tree.txt:
my_app/
├── lib/
│ └── my_app.rb
├── spec/
│ └── my_app_spec.rb
└── README.md
Run:
dirfy -d -v myapp_tree.txt
Output (dry-run):
🔍 Detected 4 items to create.
DRY-RUN Dir: my_app/
DRY-RUN Dir: my_app/lib/
DRY-RUN File: my_app/lib/my_app.rb
DRY-RUN Dir: my_app/spec/
DRY-RUN File: my_app/spec/my_app_spec.rb
DRY-RUN File: my_app/README.md
Remove -d to actually scaffold.
🤝 Contributing
We ❤️ pull-requests, issues, code-reviews, and — most importantly — your ideas to make dirfy even better.
- Read our CONTRIBUTING.md for setup instructions, code style, and the PR process.
- Fork the repo, branch off
main, and open a PR. - Run tests locally:
bundle install
bundle exec rake
- Ensure your code follows our style (via
rake lint) and has adequate test coverage. - Celebrate 🎉 — once your PR is merged, add yourself to
AUTHORS.md!
Happy scaffolding! 🚀
📝 License
MIT © Ahmed Elhady
Built with ❤️ to make AI-generated project scaffolding a breeze.