PF=test.db
-plan 17
+plan 20
td=test.addtopackage
rm -rf $td
echo foo > $td/foo
okexit 'making foo'
-rm -f zpmtest-1.0-1.zpm
+pkgid=zpmtest-1.0-1
+
+rm -f $pkgid.zpm
-require zpm add -C zpmtest $td/foo
+require zpm newpackage -C $pkgid
+require zpm add $pkgid $td/foo
h=$(zpm hash $td/foo)
require zpm extract zpmtest-1.0-1.zpm $h $td/foo2
h2=$(zpm hash $td/foo2)
okstreq "$4" "$td/foo" file foo in package
diag "$pkglist"
-rm zpmtest-1.0-1.zpm
+rm -f zpmtest-1.0-1.zpm
-require zpm add -C -f $PF zpmtest $td/foo
+rm -f $PF
+require zpm newpackage -f $PF -C $pkgid
+require zpm add -f $PF zpmtest $td/foo
rm -f $td/foo2
require zpm extract $PF $h $td/foo2
h2=$(zpm hash $td/foo2)
diag "$pkglist"
rm -f $PF
-require zpm add -C -f $PF -S "$td" zpmtest $td/foo
+require zpm newpackage -f $PF -C $pkgid
+require zpm add -f $PF -S "$td" zpmtest $td/foo
fn=$(zpm showpkg $PF | awk '{print $4}')
okstreq "$fn" "foo" file foo in package prefix striped
+rm -f $PF
finish
rm -rf $td
-rm -f $PF
-rm -f zpmtest-1.0-1.zpm
#!/bin/sh
-pkgver=${ZPMPKGVER:-1.0}
-pkgrel=${ZPMPKGREL:-1}
+# zpm add -f pkgfile pkgid [ files ]
+
+# no package file? take from ZPM_PACKAGE_FILE
+# no pkgid ? take from ZPM_PACKAGE_ID
+# no id impossible
die() {
echo $* 1>&2
}
tags=
-create=0
+isconfig=0
# option for "multipackage" just to let the system know that's what you meant
# option to take filenames from stdin
# parse package, version, release from file if not given
-while getopts :f:v:r:l:P:S:Ccu:g: opt; do
+while getopts :f:v:r:l:P:S:cu:g: opt; do
case $opt in
f) pkgfile="$OPTARG" ;;
- v) pkgver="$OPTARG" ;;
- r) pkgrel="$OPTARG" ;;
- l) licenses="$OPTARG" ;;
P) prefix="$OPTARG" ;;
S) strip=$(cleanpath "$OPTARG"); ;;
t) tags="$tags $OPTARG" ;;
- c) tags="$tags configuration" ;;
- C) create=1 ;;
+ c) isconfig=1 ;;
u) username="$OPTARG" ;;
g) groupname="$OPTARG" ;;
*) echo 'unknown option' $opt; exit 1 ;;
done
shift $((OPTIND - 1))
-package="$1"
+if [ $isconfig -eq 1 ]; then
+ tags="$tags configuration"
+fi
+
+pkgid="$1"
shift
-if [ -z "$package" ]; then
- die "must specify package"
+set -x
+eval $(zpm parse -E $pkgid)
+
+if [ -z "$pkgfile" ];
+ pkgfile=$ZPM_PACKAGE_FILE
+fi
+
+# look for a .zpm file here
+if [ -z "$pkgfile" ] && [ -n "$release" ] && [ -f "$pkgid.zpm" ];
+ pkgfile="$pkgid.zpm"
fi
-set -e
if [ -z "$pkgfile" ]; then
- pkgfile="$package-$pkgver-$pkgrel.zpm"
+ die "cannot determine package file"
fi
+set -e
+
# check for package file
if [ ! -f "$pkgfile" ]; then
- if [ $create -eq 1 ]; then
- echo creating $pkgfile
- zpm newpackage -I -f $pkgfile -v $pkgver -r $pkgrel $package || exit 1
- else
- echo $pkgfile does not exist
- exit 1
- fi
+ echo $pkgfile does not exist
+ exit 1
fi
zpm test -v $pkgfile
+if [ -z "$release" ]; then
+ pkgstr=$(zpm findpkg -f $pkgfile $pkgid)
+fi
+
+if [ -z "$pkgstr" ]; then
+ die "unable to find package id for $pkgid"
+fi
+pkgid=$pkgstr
+
#strip=$(cleanpath "$strip")
for path in $*; do
#echo adding $path