Create file system structures from ASCII tree diagrams with style! tree-shaker is a Deno-powered CLI tool that transforms text-based directory trees into real file system structures.
- Convert ASCII tree diagrams into real directories and files
- Smart depth detection for nested structures
- Command-line interface with customizable input/output paths
- Zero dependencies (besides Deno standard library)
- Simple and lightweight
# Install directly from GitHub
deno install --allow-read --allow-write https://raw.githubusercontent.com/peterbenoit/tree-shaker/main/super-shake.ts
git clone https://github.com/peterbenoit/tree-shaker.git
cd tree-shaker
deno run --allow-read --allow-write super-shake.ts --input=./examples/tree.txt --output=./my-project
Download the latest release from our releases page.
chmod +x tree-shaker
mv tree-shaker /usr/local/bin/
Download the latest binary for your platform: https://github.com/peterbenoit/tree-shaker/releases
USE AT YOUR OWN RISK
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
By using tree-shaker you acknowledge:
- This is experimental software
- Files and directories will be created on your system
- No responsibility is taken for lost or damaged files
- Always verify generated directory structures
- Back up important data before use
- Use in production environments at your own risk
Create a tree file (tree.txt):
my-project/
├── src/
│ ├── main.ts
│ └── utils/
│ └── helper.ts
├── tests/
│ └── main.test.ts
└── README.md
Run tree-shaker:
tree-shaker --input=tree.txt --output=./my-project
- Fork the repository
- Create your feature branch (git checkout -b feature/amazing-feature)
- Commit your changes (git commit -m 'Add amazing feature')
- Push to the branch (git push origin feature/amazing-feature)
- Open a Pull Request
📄 License MIT © Peter Benoit