Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/raisinten/fs-make

Make a folder structure from its description
https://github.com/raisinten/fs-make

bison flex grammar lex parser productivity project yacc

Last synced: 3 months ago
JSON representation

Make a folder structure from its description

Awesome Lists containing this project

README

        



fs-make logo




CI


LICENSE MIT

---

Make your folder structure from its description with **`fs-make (folder structure make)`**!

![example](https://github.com/RaisinTen/fs-make/raw/master/fs-make-demo.png)

## Syntax

Note that this is **not JSON** but a similar data-format. Here's what the Abstract Syntax Tree looks like.

* Files are represented by the file name placed between a pair of double quotes (`"`):
```
"file-name"
```

* Directories are represented by the directory name in double quotes (`"`) followed by a colon (`:`) and a comma-separated (`,`) set of file and directory representations between a pair of braces (`{}`):
```
"src": {
"main.cpp",
"CMakeLists.txt",
"build": {
"Makefile",
"boink"
},
"includes": {
}
}
```
When a directory contains only a single entity, the braces aren't necessary:
```
"i have one file": "one file"
```

* The input file content can be like any of these:
* a file
```
"just a file"
```
* a directory
```
"lonely directory": {
"stuff"
}
```
* an unnamed set of entities like this:
```
{}
```

Here's what the Abstract Syntax Tree looks like:

![grammar graph](https://github.com/RaisinTen/fs-make/raw/master/graphviz.svg)

## Getting Started

### Dependencies

The dependencies are:
* `gcc`
* `g++`
* `flex`
* `bison`
* `tree`

No manual installation is required. The `configure` script installs the dependencies using a package manager. If you are using:

#### macOS

Make sure that you have [Homebrew](https://brew.sh/) installed.

#### Windows

Install the [Windows Subsystem for Linux](https://docs.microsoft.com/en-us/windows/wsl/install-win10) or [Cygwin](https://cygwin.com/install.html) and make sure that you have [APT](https://salsa.debian.org/apt-team/apt) installed.

#### Linux

Make sure that you have [APT](https://salsa.debian.org/apt-team/apt) installed.

### Building

Clone the repo with:
```sh
$ git clone https://github.com/RaisinTen/fs-make.git
$ cd fs-make
```

Update your package lists and build **`fs-make`** using:
```sh
$ ./configure
$ make
$ make install
```

## Try it out

1. Create a file describing the structure of your folder.
2. Use `fs-make` to build the script:
```sh
$ fs-make
```
3. Run the script to generate the folder structure:
```sh
$ .
```
4. To view it:
```sh
$ tree -a
```

## Code of Conduct

Please refer to the [code of conduct](CODE_OF_CONDUCT.md) for the rules for interacting with this project.

## Contributing

Please go through the [contributing](CONTRIBUTING.md) documentation to contribute to this project.

## License

This project is licensed under the [MIT License](LICENSE).