Multipurpose shell scripts and dotfiles
Go to file
2025-01-21 00:06:37 +08:00
dotfiles
helpers
install
packs
tools
uninstall
upgrade
.editorconfig
.gitignore
gen-makefile
helpers.sh
LICENSE
Makefile
README.md
TODO.md

My shell environment

make-ready bunch of scripts for easily (de)installation of different software and bunch of useful handy functions for custom scripting.

Requirements

  • Ubuntu >= 20.04 (not tested with version < 20)
  • bash, zsh or other sh-compatible shell
  • make (optional but recommended)
  • wget (required for some scripts)
  • git (required for some scripts)

If some dependecies are missed for some of these scripts it is enougth to run ./install/apt in most cases, otherwise script will suggest (or even install) them.

Usage

# with git
git clone git@git.axenov.dev:anthony/my-env.git --depth=1 --single-branch

# without git
wget -qO - https://git.axenov.dev/anthony/my-env/archive/master.tar.gz | tar -zxf -

# get full list of `make` goals
cd my-env && make

How to add my script?

  1. Create a new shell script in ./install, ./upgrade or ./uninstall directory.
    At the beggining of a file you must write these two lines:
    #!/usr/bin/env bash
    ##makedesc: Your description for Makefile
    
  2. Make this script executable, e.g.:
    sudo chmod a+x ./install/myscript
    
  3. Test your script
  4. Run make self to generate new ./Makefile

How to create a pack?

You can create new file inside ./packs dir.

Syntax is same as classic makefile. It is important to add a comment with short description:

##mypack1: Pack description
mypack1: goal1 goal2 goalX ...
   ...

##mypackX: Pack description
mypackX: goalA goalB
   @cp file1 file2
   ...
...

where:

  • mypack* is the pack name of your choice
  • goal* are script names in ./install

License

WTFPLv2 but other licences are also possible.