Creating custom command in your terminal

Creating you own terminal commands Did you know that you can create your own custom commands to run in the terminal? Similar to how you use cd, ls and so on... Why bother? Sure you can live without it but once you get tired of repetitive commands you have to type in the terminal again and again you might appreciate the benefits if it. For example, every day I clone student's projects and have to install node modules and then start the app. If it's a client, I do: npm i npm start Once i got tired of typing that i created my own command istart which executes both of the above mentioned commands and starts a client after installing all the node modules. How? On most systems, there's a file like .bash_profile, .bashrc, or .zshrc depending on your shell in the root folder which can help us to do so. First we need to find this file on your system. On Mac Go to the root folder by running cd without anything else in the terminal. Check with pwd if you are in the right place. The output is something like /Users/YourUserName where YourUserName is your username on your Mac. Run ls -a to see the hidden files and scroll to see if you have a file named .bash_profile. Note: macOS now uses the zsh shell by default, so instead of .bash_profile, you might want to use .zshrc. To check which shell you're using, run: echo $SHELL Open it in your code editor or create it if you do not have it. In this file you might see something like: export PATH=/usr/local/bin:$PATH export PATH=/Applications:$PATH export REACT_APP_EDITOR=code export PATH="$HOME/.composer/vendor/bin:$PATH" On Windows (with GitBash) Locate or create your .bashrc file -- GitBash uses the .bashrc file to load custom configurations and aliases. Open GitBash and navigate to your home directory by running: cd ~ Check if the .bashrc file exists: ls -a If it's not there, you can create it with: touch .bashrc Open .bashrc in your code editor. Both systems: adding aliases This is where we are going to create our custom commands. The format is: alias YourCustomCommand="what to do for this command" Let's test it by making a new line after all the code you already have in this file and adding this: alias test="echo 'hello'" Now save the file, go to the terminal and run source ~/.bash_profile for Mac or source ~/.bashrc for Windows for the changes to take effect. Try if it works by running test command which should print "hello" in the terminal. If it works -- success! Now for our case where we want to create istart which will install node modules and start the client app we will add a new line with the following code: alias istart="npm i && npm start" Since it executes 2 commands in sequence we can use logical && to run them one after another. Anoher case is for pushing to GitHub again and again: alias pushgh="git add . && git commit -m "updates" && git push" Now by running pushgh you will add the current folder to a commit and push it to GitHub. However, it will always push with the same commit description -- "updates". This is not ideal. If you want to do a step further you can use the shell scripts to make it dynamic. Create a new file called "autopush.sh" in the same root user's folder. Open it in code editor and put the following code there: str="$*" echo $str git add . git commit -m "$str" git push It will take a string argument for the commit's decription and use it in git commit command. Now back in you .bash_profile add an alias to run this script: alias apush="sh ~/autopush.sh" And now we can run apush 'actual commit description' which will use sh to run the shell script 'autopush.sh' and it will pass the 'actual commit description' to be used as a description of the current commit! Isn't it wonderful? Your truly, GK

Apr 3, 2025 - 13:24
 0
Creating custom command in your terminal

Creating you own terminal commands

Did you know that you can create your own custom commands to run in the terminal? Similar to how you use cd, ls and so on...
Mac terminal prompt

Why bother?

Sure you can live without it but once you get tired of repetitive commands you have to type in the terminal again and again you might appreciate the benefits if it.

For example, every day I clone student's projects and have to install node modules and then start the app.

If it's a client, I do:

npm i
npm start

Once i got tired of typing that i created my own command istart which executes both of the above mentioned commands and starts a client after installing all the node modules.

How?

On most systems, there's a file like .bash_profile, .bashrc, or .zshrc depending on your shell in the root folder which can help us to do so.

First we need to find this file on your system.

On Mac

Go to the root folder by running cd without anything else in the terminal.

Check with pwd if you are in the right place. The output is something like /Users/YourUserName where YourUserName is your username on your Mac.

Run ls -a to see the hidden files and scroll to see if you have a file named .bash_profile.

Note: macOS now uses the zsh shell by default, so instead of .bash_profile, you might want to use .zshrc. To check which shell you're using, run:

echo $SHELL

Open it in your code editor or create it if you do not have it.

In this file you might see something like:

export PATH=/usr/local/bin:$PATH
export PATH=/Applications:$PATH
export REACT_APP_EDITOR=code
export PATH="$HOME/.composer/vendor/bin:$PATH"

On Windows (with GitBash)

Locate or create your .bashrc file -- GitBash uses the .bashrc file to load custom configurations and aliases.

Open GitBash and navigate to your home directory by running:

cd ~

Check if the .bashrc file exists:

ls -a

If it's not there, you can create it with:

touch .bashrc

Open .bashrc in your code editor.

Both systems: adding aliases

This is where we are going to create our custom commands. The format is:

alias YourCustomCommand="what to do for this command"

Let's test it by making a new line after all the code you already have in this file and adding this:

alias test="echo 'hello'"

Now save the file, go to the terminal and run source ~/.bash_profile for Mac or source ~/.bashrc for Windows for the changes to take effect.

Try if it works by running test command which should print "hello" in the terminal.

If it works -- success!

Now for our case where we want to create istart which will install node modules and start the client app we will add a new line with the following code:

alias istart="npm i && npm start"

Since it executes 2 commands in sequence we can use logical && to run them one after another.

Anoher case is for pushing to GitHub again and again:

alias pushgh="git add . && git commit -m "updates" && git push"

Now by running pushgh you will add the current folder to a commit and push it to GitHub.

However, it will always push with the same commit description -- "updates".

This is not ideal. If you want to do a step further you can use the shell scripts to make it dynamic.

Create a new file called "autopush.sh" in the same root user's folder. Open it in code editor and put the following code there:

str="$*"
echo $str
git add .
git commit -m "$str"
git push

It will take a string argument for the commit's decription and use it in git commit command.

Now back in you .bash_profile add an alias to run this script:

alias apush="sh ~/autopush.sh"

And now we can run apush 'actual commit description' which will use sh to run the shell script 'autopush.sh' and it will pass the 'actual commit description' to be used as a description of the current commit!

Isn't it wonderful?

Your truly,
GK