Work in progress
This repository is a collection of posix compliant shell scripts. The library management script libmgmt.sh provides a convenient method to load shell libraries. It assures that a library gets loaded only once also if it gets included multiple times. Therefore it is possible that two librarys can depend on each other without creating an endless loading loop.
For more information please refer to the source code of the libraries. Every function has a header which explains its purpose and how to use it.
Contains functions to manage posix compliant shell script libraries
Contains functions to check for dependencies needed by other scripts and installs them if they are missing
Library to interact with the user. It tries to use dialog, but defaults shell builtins if dialog is not available.
Contains common function to work with Windows Subsystem for Linux (WSL)
- Install the libraries you want to use from the lib folder to the system on which you want to run the script or bundle them directly with your script. At the moment the following locations are valid: -- ./lib/ -- ../lib/ -- ~/.local/lib -- /usr/local/lib/ Make sure to also install the dependencies of the libraries you want to use, because some libraries depend on other libraries.
- Bundle the library management script and source it with
. libmgmt.sh
or include the code from libmgmt.sh directly within your script. - Now you can load the libraries you want to use with
libmgmt__load <lib_name>
If you want to contribute please use the Google Shelle Style Guide as a coding standard with the following modifications:
- Functions should be prefixed by the library name separated by
__
from the function name - Global variables should be prefixed by the library name written all upper case and separated by
_
from the variable name - Variables used locally in functions should be prefixed by the library library name written all lower case and separated by
_
from the variable name - Variables used locally in a function should be unset before returning