CLI tool to help you easily set up a folder(s) and file(s) structure for your project.
npm install -g egusi
You create a text file with the .egusi
extension (the template file) specifying the hierarchy of the file(s) and folder(s) for your project. Egusi reads and parses the content of this template file and create the file(s) and folder(s) for you.
Egusi displays helpful error messages for unrecognised options. Always refer to the inbuilt help menu if not clear on available options and commands.
- Find Template file
egusi find [template_dir]
This command searches for an existing template file in the current directory. You can specify a directory to search in, relative to the current path.
- Create a Template file
egusi create [template_name]
Creates a template file with the .egusi extension. You can optionally create the template file with a name (named template file) by entering a name (without the .egusi). Unnamed template files are of the form .egusi, without a name
Note that when you create a named template file, you must use the -t option when running the build command, specifying the full name of the template file. See build command below.
- Remove Template file
egusi remove
Removes all .egusi template file(s) in the current working directory.
- Build from Template file
# use with unnamed template file: .egusi
egusi build
OR
# use with named template file: [name].egusi
egusi build -t example.egusi
Build the boilerplate for your project in the current working directory as specified in template.
Options:
-
Specify the location of the template file if it doesn't exist in the current working directory.
-t, --template
egusi build -t <template_dir>
-
Specify an output directory for the boilerplate.
-o, --output
egusi build --output <output_dir>
OR
egusi build -t <template_dir> --output <output_dir>
Note: Egusi will automatically create the output directory if it doesn't exist.
The template file from which egusi parses the file(s) and folder(s) names to be created is simply a text file with a .egusi file extension. An example template file is shown below:
doe:
pi:
xmas:
/app:
/louie.txt
/pit:
//example.txt
//source:
///app.ts
partridges:
/count:
/location:
turtledoves:
In Egusi, we specify file(s) and folder(s) hierarchy using the concept of depth. This depth is specified by the number of forward slash ( / ) preceeding the file/folder name on a particular line.
Folder(s) and File(s) directly created in the output directory (the current working directory or the specified output) have a depth of zero and therefore have no / preceeding their file names.
Subfolders of these "depth zero" folder(s) have a depth of one and is therefore preceeded with a single /. Other subfolders of these folders have double forward slash // and so on.
Note: As you already know, files cannot have "subfiles" or "subfolders" within them. Hence, a file of depth n should not have a file/folder of depth n+1 directly beneath it. If a sub is placed directly under a file, Egusi automatically searches for the nearest parent folder in the hierarchy and places this sub (the subfile or subfolder) inside it.
For example, the template file below will create the "pit" folder inside of the "app" folder since a folder cannot exist within the "louie.txt" file and the "app" folder is the nearest parent in the hierarchy.
xmas:
/app:
/louie.txt
//pit:
partridges:
Note: As you know, while navigating filesystems, we can only move n+1 or n-1 at a time, where n is the depth of the current directory. We cannot navigate inside an empty directory by moving n+2. Instead, we first create a folder within the current directory and then move n+1 into the new directory before performing another action.
TLDR: The direct parent of any file/folder must be of depth n-1, where n is the depth of the file/folder.
In essence, we therefore cannot have a folder structure as shown in the template file below:
doe:
pi:
//bin:
////source:
partridges:
turtledoves:
Egusi will automatically convert the folder structure above into:
doe:
pi:
/bin:
//source:
partridges:
turtledoves:
placing folder "bin" inside the nearest parent (which is folder "pi") and placing folder "source" inside its nearest parent (which is folder "bin").
Note that specifying the structure below, will result in a modified template similar to that shown above.
doe:
pi:
//bin:
partridges:
////source:
turtledoves:
This is because, the nearest parent of folder "source" is still "bin" and not "partridges".
To avoid any confusion with these scenarios, only move n+1 or n-1 in the filesystem
To create a folder from the template, write it's name followed by a colon ( : ) withouth whitespace between name and column.
To create a file from the template, write it's full name(including the extension) without adding a colon ( : ) to the end of the name and line.
Making use of the standard format of a JSON file type would require that every created folder has either a file or folder within it as we cannot have keys without values in JSON.
Future release would have functionality to allow users specify any text file type.
- Ability to populate created files with data from template.
- Populate created files from external data source.
- Ability to specify delimiter used for resolving file/folder depth.
- Entering comments in template file.
Don't Forget to leave a star* on GitHub