Project

dirfy

0.0
No release in over 3 years
Create directory/file structures from ASCII/Unicode tree diagrams
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 13.0
>= 0
 Project Readme

Dirfy

Build Status
Gem Version
License
Ruby β‰₯2.7
Issues

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 / touch commands
  • 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.

  1. Read our CONTRIBUTING.md for setup instructions, code style, and the PR process.

  2. Fork the repo, branch off main, and open a PR.

  3. Run tests locally:

    bundle install
    bundle exec rake
  4. Ensure your code follows our style (via rake lint) and has adequate test coverage.

  5. 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.