Creating a script to specify command aliases
For the most part of the programming projects I am working, I like to specify some aliases for common terminal commands. Them problem is… I have never been satisfied on how to specify such aliases. On JavaScript projects with Node, it is possible to user the package.json
scripts property, but this approach is obviously language-specific and cannot be used on other types of projects.
On other languages, I usually make the use of GNU Make, which can be not ideal for some specific cases, like when it is needed to specify arguments. In fact, it is possible to pass arguments, but it is still not the best solution for me, because I don’t have the control over which parameters are allowed to be passed. I even tried to use Python with argparse library directly one time, but they are totally overkill for this task.
Moreover, it would be nice to be able to see a help description with the scripts and which arguments can be passed. Because of that, I created a very simple script named Meta.
Meta #
Meta is very straightforward. At first, it user the PyYAML library to load the YAML config file from the current directory into a Python dictionary. This is an example of a config file that can be specified:
hello: echo "Hello, $USER"
add:
args: ['a', 'b']
command: expr {{a}} + {{b}}
install:
command: cp meta.py $HOME/.local/bin/meta
help: "Install the script into $HOME/.local/bin/meta"
After this step, it parses the config dictionary based on the the following structure, that later is used to run the specified script:
@dataclass
class Arg:
name: str
@dataclass
class Script:
command: str
args: list[Arg]
help: Optional[str] = None
@dataclass
class Meta:
scripts: dict[Script]
Finally, the Meta
instance is used to match the arguments passed to the Meta script (available in Python via the sys.argv
list) and run the correct command by providing the script command with the correct argument values. This means that the arguments must be passed to the Meta script in the same order as specified in the config file.
The complete implementation can be found here.
Considerations and further work #
I started to write this script just to help me organize the commands of the repository for this new blog I’m starting. Futhermore, It was made in Python because I was planning to use the argparse library as a back-end to specify the commands, but I choose to not use it because I wanted to have more control over how it works. Because of this, I still have to write better error messages and improve the help description.
In the future, I plan to evaluate if handling the arguments as positional is the best option, because I want a way to specify them through their names.