Some changes I have done for the past hour.
Added some flags: -C To clean the builddir after package is built. -b Only build the package. Cleaned up variable naming conventions and multiple bugfixes, among others now the required vars in tmpl files are properly checked. --HG-- extra : convert_revision : f0cb010b7308756cd562871b26f2b399d8d85a29
This commit is contained in:
parent
a8bb291a08
commit
3ec5d465e4
1 changed files with 177 additions and 131 deletions
308
pkgfs.sh
308
pkgfs.sh
|
@ -1,6 +1,6 @@
|
||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
#
|
#
|
||||||
# pkgfs - Packages from source distribution files.
|
# pkgfs - Builds source distribution files.
|
||||||
#
|
#
|
||||||
# A GNU's Stow alike approach, with some ideas from Gobolinux'
|
# A GNU's Stow alike approach, with some ideas from Gobolinux'
|
||||||
# Compile and maybe others.
|
# Compile and maybe others.
|
||||||
|
@ -35,7 +35,7 @@
|
||||||
# Multiple URLs to download source distribution files.
|
# Multiple URLs to download source distribution files.
|
||||||
# Support GNU/BSD-makefile style source distribution files.
|
# Support GNU/BSD-makefile style source distribution files.
|
||||||
# Actually do the symlink dance (stow/unstow).
|
# Actually do the symlink dance (stow/unstow).
|
||||||
# Fix PKGFS_{C,CXX}FLAGS, aren't passed to the make environment.
|
# Fix PKGFS_{C,CXX}FLAGS, aren't passed to the environment yet.
|
||||||
#
|
#
|
||||||
#
|
#
|
||||||
# Default path to configuration file, can be overriden
|
# Default path to configuration file, can be overriden
|
||||||
|
@ -44,27 +44,30 @@
|
||||||
: ${PKGFS_CONFIG_FILE:=/usr/local/etc/pkgfs.conf}
|
: ${PKGFS_CONFIG_FILE:=/usr/local/etc/pkgfs.conf}
|
||||||
|
|
||||||
# Global private stuff
|
# Global private stuff
|
||||||
: ${_progname:=$(basename $0)}
|
: ${progname:=$(basename $0)}
|
||||||
: ${_TOP:=$(/bin/pwd -P 2>/dev/null)}
|
: ${topdir:=$(/bin/pwd -P 2>/dev/null)}
|
||||||
: ${_FETCH_CMD:=/usr/bin/ftp -a}
|
: ${fetch_cmd:=/usr/bin/ftp -a}
|
||||||
: ${_CKSUM_CMD:=/usr/bin/cksum -a rmd160}
|
: ${cksum_cmd:=/usr/bin/cksum -a rmd160}
|
||||||
: ${_AWK_CMD:=/usr/bin/awk}
|
: ${awk_cmd:=/usr/bin/awk}
|
||||||
: ${_MKDIR_CMD:=/bin/mkdir -p}
|
: ${mkdir_cmd:=/bin/mkdir -p}
|
||||||
: ${_TAR_CMD:=/usr/bin/tar}
|
: ${tar_cmd:=/usr/bin/tar}
|
||||||
: ${_UNZIP_CMD:=/usr/pkg/bin/unzip}
|
: ${unzip_cmd:=/usr/pkg/bin/unzip}
|
||||||
|
: ${rm_cmd:=/bin/rm}
|
||||||
|
|
||||||
_SFILE=
|
usage()
|
||||||
_EXTRACT_CMD=
|
{
|
||||||
|
|
||||||
usage() {
|
|
||||||
cat << _EOF
|
cat << _EOF
|
||||||
$_progname: [-cef] <target> <file>
|
$progname: [-bCef] [-c <config_file>] <target> <tmpl>
|
||||||
|
|
||||||
Targets
|
Targets
|
||||||
build Build package from <file>.
|
build Build source distribution from <tmpl>.
|
||||||
info Show information about <file>.
|
info Show information about <tmpl>.
|
||||||
|
stow Create symlinks from <tmpl> in master directory.
|
||||||
|
unstow Remove symlinks from <tmpl> in master directory.
|
||||||
|
|
||||||
Options
|
Options
|
||||||
|
-b Only build the source distribution file(s).
|
||||||
|
-C Clean build directory after successful build.
|
||||||
-c Path to global configuration file.
|
-c Path to global configuration file.
|
||||||
If not specified /usr/local/etc/pkgfs.conf is used.
|
If not specified /usr/local/etc/pkgfs.conf is used.
|
||||||
-e Only extract the source distribution file(s).
|
-e Only extract the source distribution file(s).
|
||||||
|
@ -76,7 +79,7 @@ _EOF
|
||||||
|
|
||||||
check_path()
|
check_path()
|
||||||
{
|
{
|
||||||
eval orig="$1"
|
eval local orig="$1"
|
||||||
|
|
||||||
case "$orig" in
|
case "$orig" in
|
||||||
/)
|
/)
|
||||||
|
@ -85,16 +88,16 @@ check_path()
|
||||||
orig="${orig%/}"
|
orig="${orig%/}"
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
orig="${_TOP}/${orig%/}"
|
orig="$topdir/${orig%/}"
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
_SFILE="$orig"
|
path_fixed="$orig"
|
||||||
}
|
}
|
||||||
|
|
||||||
show_info_from_local_tmpl()
|
info_tmpl()
|
||||||
{
|
{
|
||||||
echo "Template build file definitions:"
|
echo "pkgfs template source distribution:"
|
||||||
echo
|
echo
|
||||||
echo " pkgname: $pkgname"
|
echo " pkgname: $pkgname"
|
||||||
for i in "${distfiles}"; do
|
for i in "${distfiles}"; do
|
||||||
|
@ -102,16 +105,68 @@ show_info_from_local_tmpl()
|
||||||
done
|
done
|
||||||
echo " URL: $url"
|
echo " URL: $url"
|
||||||
echo " maintainer: $maintainer"
|
echo " maintainer: $maintainer"
|
||||||
[ -n "${checksum}" ] && echo " checksum: $checksum"
|
[ -n $checksum ] && echo " checksum: $checksum"
|
||||||
echo " build_style: $build_style"
|
echo " build_style: $build_style"
|
||||||
echo " short_desc: $short_desc"
|
echo " short_desc: $short_desc"
|
||||||
echo "$long_desc"
|
echo "$long_desc"
|
||||||
echo
|
}
|
||||||
|
|
||||||
|
check_build_dirs()
|
||||||
|
{
|
||||||
|
check_path "$PKGFS_CONFIG_FILE"
|
||||||
|
. $path_fixed
|
||||||
|
|
||||||
|
if [ ! -f "$PKGFS_CONFIG_FILE" ]; then
|
||||||
|
echo -n "*** ERROR: cannot find global config file: "
|
||||||
|
echo "'$PKGFS_CONFIG_FILE' ***"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -z "$PKGFS_DESTDIR" ]; then
|
||||||
|
echo -n "*** ERROR: PKGFS_DESTDIR not set in configuration"
|
||||||
|
echo " file ***"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -z "$PKGFS_BUILDDIR" ]; then
|
||||||
|
echo -n "*** ERROR PKGFS_BUILDDIR not set in configuration"
|
||||||
|
echo " file ***"
|
||||||
|
exit 1;
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ! -d "$PKGFS_DESTDIR" ]; then
|
||||||
|
$mkdir_cmd "$PKGFS_DESTDIR"
|
||||||
|
if [ "$?" -ne 0 ]; then
|
||||||
|
echo -n "*** ERROR: couldn't create PKGFS_DESTDIR "
|
||||||
|
echo "directory, aborting ***"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ! -d "$PKGFS_BUILDDIR" ]; then
|
||||||
|
$mkdir_cmd "$PKGFS_BUILDDIR"
|
||||||
|
if [ "$?" -ne 0 ]; then
|
||||||
|
echo -n "*** ERROR: couldn't create PKFS_BUILDDIR "
|
||||||
|
echo "directory, aborting ***"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -z "$PKGFS_SRC_DISTDIR" ]; then
|
||||||
|
echo "*** ERROR: PKGFS_SRC_DISTDIR is not set, aborting ***"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
$mkdir_cmd "$PKGFS_SRC_DISTDIR"
|
||||||
|
if [ "$?" -ne 0 ]; then
|
||||||
|
echo "*** ERROR couldn't create PKGFS_SRC_DISTDIR, aborting ***"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
check_build_vars()
|
check_build_vars()
|
||||||
{
|
{
|
||||||
local dfile=
|
local dfile=""
|
||||||
|
|
||||||
if [ -z "$distfiles" ]; then
|
if [ -z "$distfiles" ]; then
|
||||||
dfile="$pkgname$extract_sufx"
|
dfile="$pkgname$extract_sufx"
|
||||||
|
@ -124,27 +179,27 @@ check_build_vars()
|
||||||
|
|
||||||
dfile="$PKGFS_SRC_DISTDIR/$dfile"
|
dfile="$PKGFS_SRC_DISTDIR/$dfile"
|
||||||
|
|
||||||
REQ_VARS="pkgname extract_sufx url build_style checksum"
|
REQ_VARS="pkgname extract_sufx url build_style"
|
||||||
|
|
||||||
# Check if required vars weren't set.
|
# Check if required vars weren't set.
|
||||||
for i in "${REQ_VARS}"; do
|
for i in ${REQ_VARS}; do
|
||||||
eval i=\""$$i\""
|
eval val="\$$i"
|
||||||
if [ -z "$i" ]; then
|
if [ -z "$val" -o -z "$i" ]; then
|
||||||
echo -n "*** ERROR: $i not set (incomplete build"
|
echo -n "*** ERROR: $i not set (incomplete template"
|
||||||
echo " file), aborting ***"
|
echo " build file), aborting ***"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
case "$extract_sufx" in
|
case "$extract_sufx" in
|
||||||
.tar.bz2|.tar.gz|.tgz|.tbz)
|
.tar.bz2|.tar.gz|.tgz|.tbz)
|
||||||
_EXTRACT_CMD="${_TAR_CMD} xvfz $dfile -C $PKGFS_BUILDDIR"
|
extract_cmd="$tar_cmd xvfz $dfile -C $PKGFS_BUILDDIR"
|
||||||
;;
|
;;
|
||||||
.tar)
|
.tar)
|
||||||
_EXTRACT_CMD="${_TAR_CMD} xvf $dfile -C $PKGFS_BUILDDIR"
|
extract_cmd="$tar_cmd xvf $dfile -C $PKGFS_BUILDDIR"
|
||||||
;;
|
;;
|
||||||
.zip)
|
.zip)
|
||||||
_EXTRACT_CMD="${_UNZIP_CMD} -x $dfile -C $PKGFS_BUILDDIR"
|
extract_cmd="$unzip_cmd -x $dfile -C $PKGFS_BUILDDIR"
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
echo -n "*** ERROR: unknown 'extract_sufx' argument in build "
|
echo -n "*** ERROR: unknown 'extract_sufx' argument in build "
|
||||||
|
@ -168,7 +223,7 @@ check_rmd160_cksum()
|
||||||
|
|
||||||
origsum="$checksum"
|
origsum="$checksum"
|
||||||
dfile="$PKGFS_SRC_DISTDIR/$dfile"
|
dfile="$PKGFS_SRC_DISTDIR/$dfile"
|
||||||
filesum="$(${_CKSUM_CMD} $dfile | ${_AWK_CMD} '{print $4}')"
|
filesum="$($cksum_cmd $dfile | $awk_cmd '{print $4}')"
|
||||||
if [ "$origsum" != "$filesum" ]; then
|
if [ "$origsum" != "$filesum" ]; then
|
||||||
echo "*** WARNING: checksum doesn't match (rmd160) ***"
|
echo "*** WARNING: checksum doesn't match (rmd160) ***"
|
||||||
return 1
|
return 1
|
||||||
|
@ -177,9 +232,10 @@ check_rmd160_cksum()
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
fetch_source_distfiles()
|
fetch_tmpl_sources()
|
||||||
{
|
{
|
||||||
local file=
|
local file=""
|
||||||
|
local file2=""
|
||||||
|
|
||||||
if [ -z "$distfiles" ]; then
|
if [ -z "$distfiles" ]; then
|
||||||
file="$pkgname"
|
file="$pkgname"
|
||||||
|
@ -188,110 +244,79 @@ fetch_source_distfiles()
|
||||||
fi
|
fi
|
||||||
|
|
||||||
for f in "$file"; do
|
for f in "$file"; do
|
||||||
if [ -f "$PKGFS_SRC_DISTDIR/$f$extract_sufx" ]; then
|
file2="$f$extract_sufx"
|
||||||
|
if [ -f "$PKGFS_SRC_DISTDIR/$file2" ]; then
|
||||||
check_rmd160_cksum $f
|
check_rmd160_cksum $f
|
||||||
if [ "$?" -eq 0 ]; then
|
if [ "$?" -eq 0 ]; then
|
||||||
if [ -n "${only_fetch}" ]; then
|
if [ -n "$only_fetch" ]; then
|
||||||
echo
|
echo "=> checksum ok"
|
||||||
echo -n "=> checksum ok"
|
|
||||||
echo " (only_fetch set)"
|
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
return 0
|
return 0
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
echo "*** Fetching $f ***"
|
|
||||||
cd "$PKGFS_SRC_DISTDIR" && \
|
echo "*** Fetching source distribution file '$file2' ***"
|
||||||
${_FETCH_CMD} $url/$f$extract_sufx
|
|
||||||
|
cd $PKGFS_SRC_DISTDIR && $fetch_cmd $url/$file2
|
||||||
if [ "$?" -ne 0 ]; then
|
if [ "$?" -ne 0 ]; then
|
||||||
echo -n "*** ERROR: there was an error fetching "
|
if [ ! -f $PKGFS_SRC_DISTDIR/$file2 ]; then
|
||||||
echo "'$f', aborting ***"
|
echo -n "*** ERROR: couldn't fetch '$file2', "
|
||||||
|
echo "aborting ***"
|
||||||
|
else
|
||||||
|
echo -n "*** ERROR: there was an error "
|
||||||
|
echo "fetching '$file2', aborting ***"
|
||||||
|
fi
|
||||||
exit 1
|
exit 1
|
||||||
else
|
else
|
||||||
if [ -n "${only_fetch}" ]; then
|
if [ -n "$only_fetch" ]; then
|
||||||
echo
|
echo "=> checksum ok"
|
||||||
echo "=> checksum ok (only_fetch set)"
|
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
check_build_dirs()
|
extract_tmpl_sources()
|
||||||
{
|
{
|
||||||
check_path "${PKGFS_CONFIG_FILE}"
|
echo "***"
|
||||||
. ${_SFILE}
|
echo "*** Extracting source distribution from $pkgname ***"
|
||||||
|
echo "***"
|
||||||
|
|
||||||
if [ ! -f "${PKGFS_CONFIG_FILE}" ]; then
|
$extract_cmd
|
||||||
echo -n "*** ERROR: cannot find global config file: "
|
|
||||||
echo "'${PKGFS_CONFIG_FILE}' ***"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "${PKGFS_DESTDIR}" ]; then
|
|
||||||
echo -n "*** ERROR: PKGFS_DESTDIR not set in configuration"
|
|
||||||
echo " file ***"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "${PKGFS_BUILDDIR}" ]; then
|
|
||||||
echo -n "*** ERROR PKGFS_BUILDDIR not set in configuration"
|
|
||||||
echo " file ***"
|
|
||||||
exit 1;
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ ! -d "$PKGFS_DESTDIR" ]; then
|
|
||||||
${_MKDIR_CMD} "$PKGFS_DESTDIR"
|
|
||||||
if [ "$?" -ne 0 ]; then
|
|
||||||
echo -n "*** ERROR: couldn't create PKGFS_DESTDIR "
|
|
||||||
echo "directory, aborting ***"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ ! -d "$PKGFS_BUILDDIR" ]; then
|
|
||||||
${_MKDIR_CMD} "$PKGFS_BUILDDIR"
|
|
||||||
if [ "$?" -ne 0 ]; then
|
|
||||||
echo -n "*** ERROR: couldn't create PKFS_BUILDDIR "
|
|
||||||
echo "directory, aborting ***"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ -z "$PKGFS_SRC_DISTDIR" ]; then
|
|
||||||
echo "*** ERROR: PKGFS_SRC_DISTDIR is not set, aborting ***"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
${_MKDIR_CMD} "$PKGFS_SRC_DISTDIR"
|
|
||||||
if [ "$?" -ne 0 ]; then
|
|
||||||
echo "*** ERROR couldn't create PKGFS_SRC_DISTDIR, aborting ***"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
build_pkg()
|
|
||||||
{
|
|
||||||
echo "*** Extracting package: $pkgname ***"
|
|
||||||
${_EXTRACT_CMD}
|
|
||||||
if [ "$?" -ne 0 ]; then
|
if [ "$?" -ne 0 ]; then
|
||||||
echo -n "*** ERROR: there was an error extracting the "
|
echo -n "*** ERROR: there was an error extracting the "
|
||||||
echo "distfile, aborting *** "
|
echo "distfile, aborting *** "
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
[ -n "${only_extract}" ] && exit 0
|
[ -n "$only_extract" ] && exit 0
|
||||||
|
}
|
||||||
|
|
||||||
|
build_tmpl_sources()
|
||||||
|
{
|
||||||
|
local pkg_builddir=""
|
||||||
|
|
||||||
echo "*** Building package: $pkgname ***"
|
|
||||||
if [ -z "$wrksrc" ]; then
|
if [ -z "$wrksrc" ]; then
|
||||||
if [ -z "$distfiles" ]; then
|
if [ -z "$distfiles" ]; then
|
||||||
cd $PKGFS_BUILDDIR/$pkgname
|
pkg_builddir=$PKGFS_BUILDDIR/$pkgname
|
||||||
else
|
else
|
||||||
cd $PKGFS_BUILDDIR/$distfiles
|
pkg_builddir=$PKGFS_BUILDDIR/$distfiles
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
cd $PKGFS_BUILDDIR/$wrksrc
|
pkg_builddir=$PKGFS_BUILDDIR/$wrksrc
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [ ! -d "$pkg_builddir" ]; then
|
||||||
|
echo "*** ERROR: build directory does not exist, aborting ***"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "***"
|
||||||
|
echo "*** Building binary distribution from $pkgname ***"
|
||||||
|
echo "***"
|
||||||
|
|
||||||
|
cd $pkg_builddir
|
||||||
#
|
#
|
||||||
# Packages using GNU autoconf
|
# Packages using GNU autoconf
|
||||||
#
|
#
|
||||||
|
@ -300,7 +325,7 @@ build_pkg()
|
||||||
[ -n "$i" ] && export "$i"
|
[ -n "$i" ] && export "$i"
|
||||||
done
|
done
|
||||||
|
|
||||||
./configure --prefix="${PKGFS_DESTDIR}" "${configure_args}"
|
./configure --prefix="$PKGFS_DESTDIR" "$configure_args"
|
||||||
if [ "$?" -ne 0 ]; then
|
if [ "$?" -ne 0 ]; then
|
||||||
echo -n "*** ERROR building (configure state)"
|
echo -n "*** ERROR building (configure state)"
|
||||||
echo " $pkgname ***"
|
echo " $pkgname ***"
|
||||||
|
@ -312,8 +337,7 @@ build_pkg()
|
||||||
MAKE_CMD="$make_cmd"
|
MAKE_CMD="$make_cmd"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
/usr/bin/env CFLAGS="$PKGFS_CFLAGS" CXXFLAGS="$PKGFS_CXXFLAGS" \
|
${MAKE_CMD} ${make_build_args}
|
||||||
${MAKE_CMD} ${make_build_args}
|
|
||||||
if [ "$?" -ne 0 ]; then
|
if [ "$?" -ne 0 ]; then
|
||||||
echo "*** ERROR building (make stage) $pkgname ***"
|
echo "*** ERROR building (make stage) $pkgname ***"
|
||||||
exit 1
|
exit 1
|
||||||
|
@ -326,20 +350,36 @@ build_pkg()
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "*** SUCCESSFUL build for $pkgname ***"
|
echo "***"
|
||||||
|
echo "*** binary distribution built for $pkgname ***"
|
||||||
|
|
||||||
|
if [ -d "$pkg_builddir" -a -n "$clean_builddir" ]; then
|
||||||
|
$rm_cmd -rf $pkg_builddir
|
||||||
|
[ "$?" -eq 0 ] && echo "*** removed build directory"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "***"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
build_pkg_from_source()
|
build_tmpl()
|
||||||
{
|
{
|
||||||
save_path="$PATH"
|
local save_path="$PATH"
|
||||||
|
|
||||||
export PATH="/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin"
|
export PATH="/bin:/sbin:/usr/bin:/usr/sbin:$PKGFS_DESTDIR/bin:$PKGFS_DESTDIR/sbin"
|
||||||
|
|
||||||
check_build_dirs
|
check_build_dirs
|
||||||
check_build_vars
|
check_build_vars
|
||||||
fetch_source_distfiles
|
|
||||||
build_pkg
|
if [ "$only_build" ]; then
|
||||||
|
build_tmpl_sources
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
fetch_tmpl_sources
|
||||||
|
extract_tmpl_sources
|
||||||
|
build_tmpl_sources
|
||||||
|
build_tmp_symlinks
|
||||||
|
|
||||||
export PATH="$save_path"
|
export PATH="$save_path"
|
||||||
}
|
}
|
||||||
|
@ -347,12 +387,18 @@ build_pkg_from_source()
|
||||||
#
|
#
|
||||||
# main()
|
# main()
|
||||||
#
|
#
|
||||||
args=$(getopt c:ef $*)
|
args=$(getopt bCc:ef $*)
|
||||||
[ "$?" -ne 0 ] && usage
|
[ "$?" -ne 0 ] && usage
|
||||||
|
|
||||||
set -- $args
|
set -- $args
|
||||||
while [ "$#" -gt 0 ]; do
|
while [ "$#" -gt 0 ]; do
|
||||||
case "$1" in
|
case "$1" in
|
||||||
|
-b)
|
||||||
|
only_build=yes
|
||||||
|
;;
|
||||||
|
-C)
|
||||||
|
clean_builddir=yes
|
||||||
|
;;
|
||||||
-c)
|
-c)
|
||||||
PKGFS_CONFIG_FILE="$2"
|
PKGFS_CONFIG_FILE="$2"
|
||||||
shift
|
shift
|
||||||
|
@ -373,32 +419,32 @@ done
|
||||||
|
|
||||||
[ "$#" -gt 2 ] && usage
|
[ "$#" -gt 2 ] && usage
|
||||||
|
|
||||||
_target="$1"
|
target="$1"
|
||||||
if [ -z "${_target}" ]; then
|
if [ -z "$target" ]; then
|
||||||
echo "*** ERROR missing target ***"
|
echo "*** ERROR missing target ***"
|
||||||
usage
|
usage
|
||||||
fi
|
fi
|
||||||
|
|
||||||
_buildfile="$2"
|
tmplfile="$2"
|
||||||
if [ -z "${_buildfile}" -o ! -f "${_buildfile}" ]; then
|
if [ -z "$tmplfile" -o ! -f "$tmplfile" ]; then
|
||||||
echo "*** ERROR: invalid template file '${_buildfile}', aborting ***"
|
echo "*** ERROR: invalid template file '$tmplfile', aborting ***"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
check_path "${_buildfile}"
|
check_path "$tmplfile"
|
||||||
. ${_SFILE}
|
. $path_fixed
|
||||||
|
|
||||||
|
|
||||||
# Main switch
|
# Main switch
|
||||||
case "${_target}" in
|
case "$target" in
|
||||||
build)
|
build)
|
||||||
build_pkg_from_source
|
build_tmpl
|
||||||
;;
|
;;
|
||||||
info)
|
info)
|
||||||
show_info_from_local_tmpl
|
info_tmpl
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
echo "*** ERROR invalid target '${_target}' ***"
|
echo "*** ERROR invalid target '$target' ***"
|
||||||
usage
|
usage
|
||||||
esac
|
esac
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue