What is the correct way, or convention, to specify and parse command line arguments, for example? How should I package my tool? What is the best way to handle deployment of the various aspects of my tool, for example the man page, or configuration settings? How should I handle the upgrade process?
Smaller details, like should I store my source code in the repo with execute permissions turned on, or should I only turn on those permissions when the files are deployed on the user's machine? What group should I set as the default for my executable files?
Does anyone know any great resources out there that address these issues?
I often use variations of this pattern:
version=1.0.0
usage() {
cat << EOF
USAGE: $0 {{-f|--file} }
Some description.
OPTIONS
-h, --help
Display this help.
-v, --version
Display version.
-f , --file
Specify input file.
EOF
}
while (( $# )); do
case "$1" in
-h|--help)
usage
exit
;;
-v|--version)
printf "%s\n" "$version"
exit
;;
-f|--file)
input_file="$2"
shift
;;
*)
>&2 printf "Unknown option: %s\n" "$1"
>&2 usage
exit 1
;;
esac
shift
done
There are standard guidelines[1][2].[1] https://www.gnu.org/prep/standards/standards.html#Command_00...
[2] https://cli-guide.readthedocs.io/en/latest/design/guidelines...