diff options
author | Oliver Smith <ollieparanoid@bitmessage.ch> | 2018-03-13 00:41:54 +0100 |
---|---|---|
committer | Natanael Copa <ncopa@alpinelinux.org> | 2018-06-21 15:30:58 +0000 |
commit | a68354ebc50f60369ce465d0d59020cdf081bf22 (patch) | |
tree | 276aee2952d208b56a9cd3fe017ccbd358fdd768 | |
parent | 0bb0bd8498d9898f2ef2b003ddb25a1a378f5268 (diff) | |
download | abuild-a68354ebc50f60369ce465d0d59020cdf081bf22.tar.gz abuild-a68354ebc50f60369ce465d0d59020cdf081bf22.tar.bz2 abuild-a68354ebc50f60369ce465d0d59020cdf081bf22.tar.xz abuild-a68354ebc50f60369ce465d0d59020cdf081bf22.zip |
newapkbuild: check arguments and improve usage()
Changes:
* argument sanity checks:
* `PKGNAME[-PKGVER] | SRCURL`
* check if missing
* check if specified more than once (see below)
* specifying more than one buildtype flag
* `-n` (set pkgname) without using SRCURL as last argument
* `-s` (sourceforge source) without using PKGNAME as last argument
* Typo fix: exist -> exists
* `usage()`:
* always print PKGNAME and PKGDESC (instead of NAME and DESC,
NAME was used in one place and PKGNAME in another)
* link to <https://spdx.org/licenses/>
* `-m` (meson) flag was missing in short usage line at the top
* indicate that the buildtypes are exclusive
* `-c` flag: remove "to new directory" wording to make the
message shorter (this should be obvious)
* remove empty line at the end
NOTE: Before this commit, the `PKGNAME[-PKGVER] | SRCURL` was allowed
to be specified more than once, and the code looped over the arguments.
But this was not documented in `usage()` and had unexpected results:
```
$ newapkbuild first second third
$ tree
.
___ first
___ APKBUILD
___ first
___ ___ APKBUILD
___ ___ first
___ ___ ___ APKBUILD
___ ___ ___ src
___ ___ src
___ src
```
-rw-r--r-- | newapkbuild.in | 62 |
1 files changed, 44 insertions, 18 deletions
diff --git a/newapkbuild.in b/newapkbuild.in index 77d1a8b..b84dd6d 100644 --- a/newapkbuild.in +++ b/newapkbuild.in @@ -344,13 +344,14 @@ __EOF__ usage() { cat >&2 <<-__EOF__ $program $program_version - generate a new APKBUILD - Usage: $program [-n NAME] [-d DESC] [-l LICENSE] [-u URL] - [-aCpy] [-s] [-cfh] - PKGNAME[-PKGVER]|SRCURL + Usage: $program [-n PKGNAME] [-d PKGDESC] [-l LICENSE] [-u URL] + [-a | -C | -m | -p | -y] [-s] [-c] [-f] [-h] + PKGNAME[-PKGVER] | SRCURL Options: - -n Set package name to NAME - -d Set package description (pkgdesc) to DESC - -l Set package license to LICENSE + -n Set package name to PKGNAME (only use with SRCURL) + -d Set package description to PKGDESC + -l Set package license to LICENSE, use identifiers from: + <https://spdx.org/licenses/> -u Set package URL -a Create autotools package (use ./configure ...) -C Create CMake package (Assume cmake/ is there) @@ -358,33 +359,58 @@ usage() { -p Create perl package (Assume Makefile.PL is there) -y Create python package (Assume setup.py is there) -s Use sourceforge source URL - -c Copy a sample init.d, conf.d, and install script to new directory - -f Force even if directory already exist + -c Copy a sample init.d, conf.d, and install script + -f Force even if directory already exists -h Show this help - __EOF__ } +set_buildtype() { + if [ -n "$buildtype" ]; then + error "More than one buildtype flag specified ($buildtype and $1)" + exit 1 + fi + buildtype="$1" +} + +check_arguments() { + if [ $# -eq 0 ]; then + error "Missing required argument: PKGNAME[-PKGVER] | SRCURL" + exit 1 + fi + if [ $# -gt 1 ]; then + shift + error "Unrecognized arguments: $*" + exit 1 + fi + if ! is_url "$1" && [ -n "$pkgname" ]; then + error "-n is only allowed when using SRCURL as last argument" + exit 1 + fi + if is_url "$1" && [ -n "$sourceforge" ]; then + error "-s is only allowed when using PKGNAME as last argument" + exit 1 + fi +} + while getopts "acCmd:fhl:n:pyu:s" opt; do case $opt in - 'a') buildtype="autotools";; + 'a') set_buildtype "autotools";; 'c') cpinitd=1;; - 'C') buildtype="cmake";; - 'm') buildtype="meson";; + 'C') set_buildtype "cmake";; + 'm') set_buildtype "meson";; 'd') pkgdesc="$OPTARG";; 'f') force=1;; 'h') usage; exit;; 'l') license="$OPTARG";; 'n') pkgname="$OPTARG";; - 'p') buildtype="perl";; - 'y') buildtype="python";; + 'p') set_buildtype "perl";; + 'y') set_buildtype "python";; 'u') url="$OPTARG";; 's') sourceforge=1;; esac done shift $(( $OPTIND - 1 )) -while [ $# -gt 0 ]; do - newaport $1 || exit 1 - shift -done +check_arguments "$@" +newaport $1 |