GitXplorerGitXplorer
R

fs-make

public
16 stars
1 forks
0 issues

Commits

List of commits on branch master.
Verified
71ebc60b0ce9a42fe04086aa47822a34b06fe976

Create FUNDING.yml

RRaisinTen committed 8 months ago
Unverified
b72c4767b6deb19186d796442363fb3d1f9592a9

📝 Description update

RRaisinTen committed 4 years ago
Verified
f3f3ec78cd6ca2ceac96f574eb822c4f4ab764cc

Merge pull request #26 from RaisinTen/readme-improvements

RRaisinTen committed 4 years ago
Unverified
47025924fb82f9b3ad66631ef6b847de3015a97d

📝 Minor modification about configure script

RRaisinTen committed 4 years ago
Unverified
d82b0682b746940f0be2023536e864b2038dbc37

📝 Removed redundant example

RRaisinTen committed 4 years ago
Unverified
d20709aef8962ecdaea3669f3cc94f25841a7392

📝 Usage section updated

RRaisinTen committed 4 years ago

README

The README file for this repository.

fs-make logo

CI LICENSE MIT


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

example

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

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

Windows

Install the Windows Subsystem for Linux or Cygwin and make sure that you have APT installed.

Linux

Make sure that you have APT installed.

Building

Clone the repo with:

$ git clone https://github.com/RaisinTen/fs-make.git
$ cd fs-make

Update your package lists and build fs-make using:

$ ./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:
    $ fs-make <description-file-name> <script-file-name>
  3. Run the script to generate the folder structure:
    $ . <script-file-name>
  4. To view it:
    $ tree -a <directory-name>

Code of Conduct

Please refer to the code of conduct for the rules for interacting with this project.

Contributing

Please go through the contributing documentation to contribute to this project.

License

This project is licensed under the MIT License.