From 3ae1da2fee7f0843ca19fb42894446e7e99b7c6c Mon Sep 17 00:00:00 2001 From: Mohamed Tarek Date: Tue, 5 Nov 2024 04:18:50 +0200 Subject: [PATCH] Update README --- README.md | 126 ++++++++++++++++++++++++++++++++---------------------- 1 file changed, 76 insertions(+), 50 deletions(-) diff --git a/README.md b/README.md index 5efad8d..8ae9524 100644 --- a/README.md +++ b/README.md @@ -41,8 +41,7 @@ Replace with the version number or tag of the release you want to inst now you should be able to run `idkmng` in your terminal! ## Creating a template 📜 - Default templates path is `~/.config/idkmng/templates`
-> [!NOTE] -> You can use -c option to override the config path if you needed to. - The template structure is like the following: ```toml [info] @@ -68,40 +62,29 @@ author = "" path="/path/to/file1" content=""" +Content of file 1 + """ [[files]] # file2 path="/path/to/file2" content=""" -#etc... -""" -``` - -> [!TIP] -> Info section is not required and can be ignored - -> [!NOTE] -> You can use -q (quiet) option to hide template information even if it is provided in the template - - +Content of file 2 ---- +""" -| **Field** | **Description** | -|-----------|-----------------| -| **`path`** | The path of the file where content will be saved. | -| **`content`** | The content to be written to the file. | -| **`keywords/placeholders`** | `idkmng` recognizes default keywords and placeholders, such as `{{$HOME}}` or `{{$CURRENTDIR}}`. Some keywords, like `{{$PROJECTNAME}}`, may prompt for user input. | -| **Multiple Files** | You can include as many files as needed, each with its own `path` and `content`. | +#etc... +``` ---- +> [!INFO] +> Info section is not required and can be removed -Here is a table of defualt keyword for idkmng: +placeholders have a generic format of `{{$keyword}}` | Keyword/placeholder | Value | Example | |--------------- | --------------- | --------------- | -| PROJECTNAME | | | +| PROJECTNAME | Asks for project name | | | CURRENTDIR | Current directory | pwd=/foo/bar => `bar`| | HOME | Home directory | `/home/user/` | | YYYY | Current Year in YYYY format| 2024 | @@ -111,7 +94,10 @@ Here is a table of defualt keyword for idkmng: | NOW | Current date and time | `2024-02-23 22:22:38.151417626 +00:00` | | NOW_UTC | Current date and time in UTC | `2024-02-23 22:21:17.897444668 UTC` | -you can have keywords/placeholder that asks for user input to take as a value by using the following format `{{$%s:f}}` this already works with `{{$PROJECTNAME}}`. but you can have your own...
+--- +### Functions +you can enhance the functionality of your templates by using special placeholders that prompt for user input or retrieve values from environment variables. These placeholders follow the format `{{$keyword:function}}` + Example: ```toml # --snip @@ -127,17 +113,29 @@ Functions supported by idkmng: | read | Asks for user input to replace placeholder with | `{{$TEST:read}}` | | env | Replace with value from environment variables | `{{$PATH:env}}` | -also keep in mind that once a function gets called on a keyword you can use `{{$TEST:read}}` or `{{$TEST}}` both are going to work and value will be replaced for both of them. +also keep in mind that once a function gets called on a keyword you can use `{{$TEST:read}}` or `{{$TEST}}` both are going to be replaced with the value that the function returned. + +## Git Support 🐙 +Initialize Git during project creation by using: + +```console +$ idkmng /path/to/template --git +``` + +Or include Git option in the template itself: + +```toml +[options] +git=true +project_root="{{$PROJECTNAME}}" +``` ### Example Templates -I have a private personal templates repo that I may share soon, but for now I can only provide a few examples +Here are a few examples:
Neovim Plugin [Click to expand] - Now this one overhere is just for basic neovim plugin structure I use to create nvim plugins for my personal use - also I have another one to create the docs for the plugin (just basic files not autogenerate docs) - ```toml [info] name = "Neovim Plugin" @@ -174,8 +172,7 @@ require("{{$PROJECTNAME}}")
Jekyll new blogpost [Click to expand] -I am starting a Blog (still underconstruction 🏗️) but anyway I use this template to create a new post in my blog -directly from CLI,This one here uses more keywords and includes a private BLOGPATH placeholder that it's value is loaded from config file. +I use this template to create a new post in my blog directly from CLI,This one here uses more keywords and includes a private BLOGPATH placeholder that it's value is loaded from config file. ```toml [info] @@ -201,7 +198,7 @@ tags: {{$Tags:read}}
Browser (Chrome) Extension [Click to expand] -This one is just for creating a really BASIC chrome extension with no icon or anything else, I use it because I like it to be minimal, still can add more placeholders but since this is for private use I don't really care, about version etc... +This one is just for creating a really BASIC chrome extension. ```toml [info] # Generated using `idkmng new` btw @@ -234,7 +231,8 @@ console.log("Hello world!") ``` -*TIP 💡 *: Info section can have any additional values, it won't get printed but maybe usefull if sharing the template or just as a reference for docs like I did here +> [!TIP] +> Info section can have any additional values, it won't get printed but maybe usefull when sharing the template or just as a reference for docs like I did here
@@ -321,25 +319,53 @@ Example! 5 ff.html With this integration, you can create dynamic and flexible templates that combine the strengths of both `idkmng` and Liquid. -## Git Support 🐙 -Initialize Git during project creation by using: +## Automated Template generation 🚀 +Also there is one more time saving way! if you have some files in `/foo/bar/` you can just run `idkmng init` and it will create a template for you with directory name `bar.toml` and it will have all your files in it! 🌸 ```console -$ idkmng /path/to/template --git +$ tree +. +├── lua +│   └── test123 +│   └── init.lua +└── plugin + └── init.lua + +4 directories, 2 files + +$ idkmng init +Creating Template: test123.toml ``` -Or include Git support in the template itself: +```console +$ cat test123.toml -```toml -[options] -git=true -project_root="{{$PROJECTNAME}}" -``` +[[files]] +path = 'plugin/init.lua' +content = ''' +require("test123") +''' -## Automated Template generation 🚀 -Also there is one more time saving way! if you have some files in `/foo/bar/` you can just run `idkmng init` and it will create a template for you with directory name `bar.toml` and it will have all your files in it! 🌸 +[[files]] +path = 'lua/test123/init.lua' +content = ''' +local M = {} + +M.config = {} + +M.setup = function () + if config ~= nil then + M.config = config + end + +end + +return M +''' + +``` -## Special Keywords 🔧 +## Config Keywords ⚙️ You can have your own Keywords for idkmng to replace with desired values! Idkmng finds them stored in $HOME/.config/idkmng/config.toml Or the config path you specified using -c/--config option 🦀