X-Git-Url: https://pd.if.org/git/?p=zpackage;a=blobdiff_plain;f=zpm-newpackage;h=a92cea378c61c4032dfc904b40428c2d2ec09b08;hp=66044d942c2057f2ee34c1cbdc871b677cfbf9b7;hb=09c80a1f8918d888063f4d1a75921a99fe5f0b5c;hpb=f946d9f84d0a3747c5d9d573407f3858f42e777b diff --git a/zpm-newpackage b/zpm-newpackage index 66044d9..a92cea3 100755 --- a/zpm-newpackage +++ b/zpm-newpackage @@ -1,27 +1,20 @@ #!/bin/sh -pkgver=${ZPMPKGVER:-1.0} -pkgrel=${ZPMPKGREL:-1} - builddate=$(date '+%s') -# create a new package in: local, env, arg -# arg, then env, then local - -# the repo given via ZPMDB # the repo implied by the arguments -# the repo in /var/lib/zpm/local.db -while getopts :f:v:r:d:a:u:l:p:b:In: opt; do +create=0 + +# newpackage -f pkgfile $pkgid +while getopts :Cf:r:d:a:u:l:p:b:In: opt; do case $opt in f) pkgfile="$OPTARG" ;; - n) pkgname="$OPTARG" ;; - v) pkgver="$OPTARG" ;; - r) pkgrel="$OPTARG" ;; d) description="$OPTARG" ;; a) arch="$OPTARG" ;; u) url="$OPTARG" ;; l) licenses="$OPTARG" ;; + C) create=1 ;; p) packager="$OPTARG" ;; b) builddate="$OPTARG" ;; I) idempotent=1 @@ -34,29 +27,89 @@ die() { exit 1 } -package=$1 +pkgid=$1 shift -if [ -z "$package" ]; then - die "must specify package" +if [ -z "$pkgid" ]; then + die "must specify pkgid" fi +eval "$(zpm parse -E $pkgid)" + if [ -z "$pkgfile" ]; then - pkgfile="$package-$pkgver-$pkgrel.zpm" + pkgfile=$ZPM_PACKAGE_FILE fi -set -e +# cases C = create ok, R = full package id, F = specified package file -if [ ! -e $pkgfile ]; then - zpm init $pkgfile +# immediate error +# C-- 100 error, must specify something +# --- 000 error, must specify something +if [ -z "$release" ] && [ -z "$pkgfile" ]; then + die must specify package file or complete package id fi +# --F 001 error, wouldn't know which pkgid to create, could derive from file? +# C-F 101 error, since package wouldn't exist in file to find +if [ -z "$release" ]; then + die must specify complete package id +fi + +# set file from pkgid +# CR- 110 set file from pkgid, create if needed +# -R- 010 set file from pkgid, create in file, error if no file +if [ -z "$pkgfile" ]; then + pkgfile="$pkgid.zpm" +fi + +# will now be one of these +# CRF 111 create package in file given, create file if needed +# -RF 011 create package in file, error if file doesn't exist +if [ ! -f "$pkgfile" ]; then + if [ $create -eq 1 ]; then + zpm init $pkgfile + else + die $pkgfile does not exist + fi +fi + +set -e + if [ "$idempotent" = 1 ]; then idempotent='or ignore' fi +package=$(zpm quote "$name") +pkgver=$(zpm quote "$version") +pkgrel=$(zpm quote "$release") +if [ -n "$description" ]; then + description=$(zpm quote -q "$description") +else + description=NULL +fi + +if [ -n "$licenses" ]; then + licenses=$(zpm quote -q "$licenses") +else + licenses=NULL +fi + +if [ -n "$packager" ]; then + packager=$(zpm quote -q "$packager") +else + packager=NULL +fi +if [ -n "$url" ]; then + url=$(zpm quote -q "$url") +else + url=NULL +fi + zpm shell $pkgfile <