argparse.sh
contains bash functions that streamlines the management of command-line arguments in Bash scripts, enhancing the robustness and user-friendliness of your code. Its syntax is intentionally designed to be familiar to those who have experience with argument parsing libraries, providing a smooth and intuitive scripting experience.
- Easy Integration: Simply source
argparse.sh
in your script to start using. - Supports Various Argument Types: Handles required, optional, and boolean flag arguments.
- Default Values: Define default values for optional arguments.
- Automatic Help Generation: Generates a help message based on defined arguments.
- Error Handling: Provides user-friendly error messages for missing or incorrect arguments.
clone the script repository.
git clone https://github.com/yaacov/argparse-sh.git
You can now source argparse.sh
in your Bash scripts to leverage its argument parsing capabilities.
source /path/to/argparse.sh
# Your code here
The define_arg
function allows you to define a new command-line argument. The syntax is:
define_arg "arg_name" ["default"] ["help text"] ["action"] ["required"]
Parameter | Description | Optional | Default |
---|---|---|---|
arg_name | Name of the argument | No | |
default | Default value for the argument | Yes | "" |
help text | Description of the argument for the help message | Yes | "" |
action | Type of the argument (string or store_true for flags) | Yes | "string" |
required | Whether the argument is required (true or false) | Yes | "false" |
The optional set_description
function sets a description for your script, which appears at the top of the automatically generated help message. Usage is straightforward:
set_description "Your script description here"
When not set, the help text will show without a description text.
After defining your arguments, use the parse_args
function to parse the command-line inputs. Simply pass "$@"
(the array of command-line arguments) to this function:
parse_args "$@"
This function will process the inputs based on the defined arguments and handle errors or help message requests automatically.
Here's a simple example of a script using argparse.sh:
#!/bin/bash
# Source the argparse script
source ./argparse.sh
# [Optional] Set script description
set_description "This is a simple script that greets the user."
# Define an argument
define_arg "name" "" "Name of the user" "string" "true"
# [Optional] Check for -h and --help
check_for_help "$@"
# Parse the arguments
parse_args "$@"
# Main script logic
echo "Hello, $name!"
Run this script using:
./yourscript.sh --name Alice
We warmly welcome contributions to argparse.sh
. If you have an idea for an improvement or have spotted an issue, feel free to contribute. Start by forking the repository and cloning your fork to your local machine. Create a new branch for your feature or fix. Once you've made your changes, commit them with a clear and descriptive message. After committing your changes, push them to your fork on GitHub. Finally, submit a pull request from your branch to the main repository. We appreciate your efforts in enhancing argparse.sh
and look forward to your valuable input!
This project is licensed under the MIT License.