2014-11-09 11:04:44 +01:00
|
|
|
#!/bin/sh
|
|
|
|
|
2017-01-05 18:02:21 +01:00
|
|
|
# Copyright (c) 2014-2017 Franco Fichtner <franco@opnsense.org>
|
2016-05-05 16:50:04 +02:00
|
|
|
# Copyright (c) 2010-2011 Scott Ullrich <sullrich@gmail.com>
|
2014-11-09 11:04:44 +01:00
|
|
|
#
|
|
|
|
# Redistribution and use in source and binary forms, with or without
|
|
|
|
# modification, are permitted provided that the following conditions
|
|
|
|
# are met:
|
|
|
|
#
|
|
|
|
# 1. Redistributions of source code must retain the above copyright
|
|
|
|
# notice, this list of conditions and the following disclaimer.
|
2014-11-09 11:06:26 +01:00
|
|
|
#
|
2014-11-09 11:04:44 +01:00
|
|
|
# 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
# notice, this list of conditions and the following disclaimer in the
|
|
|
|
# documentation and/or other materials provided with the distribution.
|
|
|
|
#
|
|
|
|
# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
|
|
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
# SUCH DAMAGE.
|
|
|
|
|
|
|
|
set -e
|
|
|
|
|
2017-01-12 08:22:37 +01:00
|
|
|
OPTS="a:B:b:C:c:d:E:e:F:f:G:g:K:k:L:l:m:n:o:P:p:R:S:s:T:t:U:u:v:V:"
|
2016-12-23 16:55:19 +01:00
|
|
|
SCRUB_ARGS=":"
|
2015-05-16 12:48:14 +02:00
|
|
|
|
2016-12-23 16:55:19 +01:00
|
|
|
while getopts ${OPTS} OPT; do
|
2015-05-16 11:35:18 +02:00
|
|
|
case ${OPT} in
|
2016-07-17 15:38:10 +02:00
|
|
|
a)
|
2017-01-05 18:55:46 +01:00
|
|
|
export PRODUCT_TARGET=${OPTARG%%:*}
|
|
|
|
export PRODUCT_ARCH=${OPTARG##*:}
|
|
|
|
export PRODUCT_HOST=$(uname -p)
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
2016-07-17 15:38:10 +02:00
|
|
|
;;
|
2016-12-23 16:55:19 +01:00
|
|
|
B)
|
|
|
|
export PORTSBRANCH=${OPTARG}
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
|
|
|
b)
|
|
|
|
export SRCBRANCH=${OPTARG}
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
2015-06-09 10:14:37 +02:00
|
|
|
C)
|
|
|
|
export COREDIR=${OPTARG}
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
2016-05-23 22:06:57 +02:00
|
|
|
c)
|
|
|
|
export PRODUCT_SPEED=${OPTARG}
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
2016-05-06 06:55:01 +02:00
|
|
|
d)
|
2016-05-06 07:07:24 +02:00
|
|
|
export PRODUCT_DEVICE=${OPTARG}
|
2016-05-06 06:55:01 +02:00
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
2016-12-23 16:55:19 +01:00
|
|
|
E)
|
|
|
|
export COREBRANCH=${OPTARG}
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
|
|
|
e)
|
|
|
|
export PLUGINSBRANCH=${OPTARG}
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
2017-01-12 08:22:37 +01:00
|
|
|
F)
|
|
|
|
export PRODUCT_KERNEL=${OPTARG}
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
2015-05-16 11:35:18 +02:00
|
|
|
f)
|
|
|
|
export PRODUCT_FLAVOUR=${OPTARG}
|
2015-05-16 12:48:14 +02:00
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
2015-05-16 11:35:18 +02:00
|
|
|
;;
|
2017-01-12 08:22:37 +01:00
|
|
|
G)
|
|
|
|
export PORTSREFBRANCH=${OPTARG}
|
2016-12-26 11:08:46 +01:00
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
|
|
|
g)
|
|
|
|
export TOOLSBRANCH=${OPTARG}
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
2016-02-01 18:07:20 +01:00
|
|
|
K)
|
2016-07-05 08:55:27 +02:00
|
|
|
if [ -n "${OPTARG}" ]; then
|
|
|
|
export PRODUCT_PUBKEY=${OPTARG}
|
|
|
|
fi
|
2016-02-01 18:07:20 +01:00
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
2015-10-30 07:22:22 +01:00
|
|
|
k)
|
2016-07-05 08:55:27 +02:00
|
|
|
if [ -n "${OPTARG}" ]; then
|
|
|
|
export PRODUCT_PRIVKEY=${OPTARG}
|
|
|
|
fi
|
2015-10-30 07:22:22 +01:00
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
2016-02-17 22:04:20 +01:00
|
|
|
L)
|
|
|
|
if [ -n "${OPTARG}" ]; then
|
|
|
|
export PRODUCT_SIGNCMD=${OPTARG}
|
|
|
|
fi
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
|
|
|
l)
|
|
|
|
if [ -n "${OPTARG}" ]; then
|
|
|
|
export PRODUCT_SIGNCHK=${OPTARG}
|
|
|
|
fi
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
2016-02-02 20:51:03 +01:00
|
|
|
m)
|
|
|
|
export PRODUCT_MIRROR=${OPTARG}
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
|
|
|
n)
|
|
|
|
export PRODUCT_NAME=${OPTARG}
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
2016-02-28 22:57:54 +01:00
|
|
|
o)
|
|
|
|
if [ -n "${OPTARG}" ]; then
|
|
|
|
export STAGEDIRPREFIX=${OPTARG}
|
|
|
|
fi
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
2015-06-09 10:14:37 +02:00
|
|
|
P)
|
|
|
|
export PORTSDIR=${OPTARG}
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
2015-07-09 14:32:50 +02:00
|
|
|
p)
|
|
|
|
export PLUGINSDIR=${OPTARG}
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
2015-06-10 08:46:59 +02:00
|
|
|
R)
|
|
|
|
export PORTSREFDIR=${OPTARG}
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
2015-06-09 10:14:37 +02:00
|
|
|
S)
|
|
|
|
export SRCDIR=${OPTARG}
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
2015-06-12 08:01:54 +02:00
|
|
|
s)
|
|
|
|
export PRODUCT_SETTINGS=${OPTARG}
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
2015-06-09 10:14:37 +02:00
|
|
|
T)
|
|
|
|
export TOOLSDIR=${OPTARG}
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
2015-09-09 15:54:26 +02:00
|
|
|
t)
|
|
|
|
export PRODUCT_TYPE=${OPTARG}
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
2016-07-12 07:22:57 +02:00
|
|
|
U)
|
|
|
|
case "${OPTARG}" in
|
|
|
|
''|-stable|-devel)
|
|
|
|
export PRODUCT_SUFFIX=${OPTARG}
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
echo "SUFFIX wants empty string, -stable or -devel" >&2
|
|
|
|
exit 1
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
;;
|
2016-07-11 08:50:39 +02:00
|
|
|
u)
|
|
|
|
if [ "${OPTARG}" = "yes" ]; then
|
|
|
|
export PRODUCT_UEFI=${OPTARG}
|
|
|
|
fi
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
2015-05-16 11:35:18 +02:00
|
|
|
v)
|
|
|
|
export PRODUCT_VERSION=${OPTARG}
|
2015-05-16 12:48:14 +02:00
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
2015-05-16 11:35:18 +02:00
|
|
|
;;
|
2017-01-05 18:02:21 +01:00
|
|
|
V)
|
|
|
|
export PRODUCT_ADDITIONS=${OPTARG}
|
|
|
|
SCRUB_ARGS=${SCRUB_ARGS};shift;shift
|
|
|
|
;;
|
2015-05-16 11:35:18 +02:00
|
|
|
*)
|
2016-12-23 16:55:19 +01:00
|
|
|
echo "${0}: Unknown argument '${OPT}'" >&2
|
|
|
|
exit 1
|
2015-05-16 11:35:18 +02:00
|
|
|
;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
2015-06-09 10:14:37 +02:00
|
|
|
if [ -z "${PRODUCT_NAME}" -o \
|
2015-09-09 15:54:26 +02:00
|
|
|
-z "${PRODUCT_TYPE}" -o \
|
2016-07-17 15:38:10 +02:00
|
|
|
-z "${PRODUCT_ARCH}" -o \
|
2015-06-09 10:14:37 +02:00
|
|
|
-z "${PRODUCT_FLAVOUR}" -o \
|
|
|
|
-z "${PRODUCT_VERSION}" -o \
|
2015-06-12 08:01:54 +02:00
|
|
|
-z "${PRODUCT_SETTINGS}" -o \
|
2016-02-02 20:51:03 +01:00
|
|
|
-z "${PRODUCT_MIRROR}" -o \
|
2016-05-06 06:55:01 +02:00
|
|
|
-z "${PRODUCT_DEVICE}" -o \
|
2016-05-23 22:06:57 +02:00
|
|
|
-z "${PRODUCT_SPEED}" -o \
|
2016-12-26 11:08:46 +01:00
|
|
|
-z "${PRODUCT_KERNEL}" -o \
|
2016-12-23 16:55:19 +01:00
|
|
|
-z "${PLUGINSBRANCH}" -o \
|
2015-07-09 14:32:50 +02:00
|
|
|
-z "${PLUGINSDIR}" -o \
|
2016-12-23 16:55:19 +01:00
|
|
|
-z "${PORTSBRANCH}" -o \
|
2015-06-09 10:14:37 +02:00
|
|
|
-z "${PORTSDIR}" -o \
|
2015-06-10 08:46:59 +02:00
|
|
|
-z "${PORTSREFDIR}" -o \
|
2016-12-26 11:08:46 +01:00
|
|
|
-z "${TOOLSBRANCH}" -o \
|
2016-12-23 16:55:19 +01:00
|
|
|
-z "${TOOLSDIR}" -o \
|
|
|
|
-z "${COREBRANCH}" -o \
|
2015-06-09 10:14:37 +02:00
|
|
|
-z "${COREDIR}" -o \
|
2016-12-23 16:55:19 +01:00
|
|
|
-z "${SRCBRANCH}" -o \
|
2015-06-09 10:14:37 +02:00
|
|
|
-z "${SRCDIR}" ]; then
|
2016-12-23 16:55:19 +01:00
|
|
|
echo "${0}: Missing argument" >&2
|
|
|
|
exit 1
|
2015-05-12 11:07:47 +02:00
|
|
|
fi
|
|
|
|
|
2014-11-09 13:14:07 +01:00
|
|
|
# misc. foo
|
2015-05-07 14:07:03 +02:00
|
|
|
export CPUS=$(sysctl kern.smp.cpus | awk '{ print $2 }')
|
2015-05-07 08:11:21 +02:00
|
|
|
export CONFIG_XML="/usr/local/etc/config.xml"
|
2016-07-19 08:02:59 +02:00
|
|
|
export ABI_FILE="/usr/lib/crt1.o"
|
2015-05-07 08:11:21 +02:00
|
|
|
export LABEL=${PRODUCT_NAME}
|
2016-07-18 08:38:36 +02:00
|
|
|
export ENV_FILTER="env -i USER=${USER} LOGNAME=${LOGNAME} HOME=${HOME} \
|
|
|
|
SHELL=${SHELL} BLOCKSIZE=${BLOCKSIZE} MAIL=${MAIL} PATH=${PATH} \
|
|
|
|
TERM=${TERM} HOSTTYPE=${HOSTTYPE} VENDOR=${VENDOR} OSTYPE=${OSTYPE} \
|
|
|
|
MACHTYPE=${MACHTYPE} PWD=${PWD} GROUP=${GROUP} HOST=${HOST} \
|
2016-07-19 16:39:54 +02:00
|
|
|
EDITOR=${EDITOR} PAGER=${PAGER} ABI_FILE=${ABI_FILE}"
|
2014-11-09 11:04:44 +01:00
|
|
|
|
2016-05-21 10:53:24 +02:00
|
|
|
# define build and config directories
|
2015-06-12 08:01:54 +02:00
|
|
|
export CONFIGDIR="${TOOLSDIR}/config/${PRODUCT_SETTINGS}"
|
2016-07-19 08:39:00 +02:00
|
|
|
export STAGEDIR="${STAGEDIRPREFIX}${CONFIGDIR}/${PRODUCT_FLAVOUR}:${PRODUCT_ARCH}"
|
2016-05-06 06:55:01 +02:00
|
|
|
export DEVICEDIR="${TOOLSDIR}/device"
|
2015-06-12 08:01:54 +02:00
|
|
|
export PACKAGESDIR="/.pkg"
|
2015-05-07 09:00:32 +02:00
|
|
|
|
2016-05-21 10:53:24 +02:00
|
|
|
# define and bootstrap target directories
|
|
|
|
export IMAGESDIR="/tmp/images"
|
|
|
|
export SETSDIR="/tmp/sets"
|
|
|
|
mkdir -p ${IMAGESDIR} ${SETSDIR}
|
2015-05-07 09:00:32 +02:00
|
|
|
|
2016-07-05 08:55:27 +02:00
|
|
|
# automatically expanded product stuff
|
|
|
|
export PRODUCT_PRIVKEY=${PRODUCT_PRIVKEY:-"${CONFIGDIR}/repo.key"}
|
|
|
|
export PRODUCT_PUBKEY=${PRODUCT_PUBKEY:-"${CONFIGDIR}/repo.pub"}
|
|
|
|
export PRODUCT_SIGNCMD=${PRODUCT_SIGNCMD:-"${TOOLSDIR}/scripts/pkg_sign.sh ${PRODUCT_PUBKEY} ${PRODUCT_PRIVKEY}"}
|
|
|
|
export PRODUCT_SIGNCHK=${PRODUCT_SIGNCHK:-"${TOOLSDIR}/scripts/pkg_fingerprint.sh ${PRODUCT_PUBKEY}"}
|
|
|
|
export PRODUCT_RELEASE="${PRODUCT_NAME}-${PRODUCT_VERSION}-${PRODUCT_FLAVOUR}"
|
2016-07-12 07:22:57 +02:00
|
|
|
export PRODUCT_PKGNAMES="${PRODUCT_TYPE} ${PRODUCT_TYPE}-stable ${PRODUCT_TYPE}-devel"
|
|
|
|
export PRODUCT_PKGNAME="${PRODUCT_TYPE}${PRODUCT_SUFFIX}"
|
2016-07-05 08:55:27 +02:00
|
|
|
|
2017-01-12 02:17:33 +01:00
|
|
|
if [ "${SELF}" != print -a "${SELF}" != info -a "${SELF}" != update ]; then
|
|
|
|
if [ -z "${PRINT_ENV_SKIP}" ]; then
|
|
|
|
export PRINT_ENV_SKIP=1
|
|
|
|
env | sort
|
|
|
|
fi
|
|
|
|
echo ">>> Running build step: ${SELF}"
|
2016-07-19 08:39:00 +02:00
|
|
|
fi
|
2015-05-12 11:07:47 +02:00
|
|
|
|
2015-06-09 09:05:10 +02:00
|
|
|
git_checkout()
|
2014-11-09 11:04:44 +01:00
|
|
|
{
|
|
|
|
git -C ${1} clean -xdqf .
|
2015-06-09 09:05:10 +02:00
|
|
|
REPO_TAG=${2}
|
|
|
|
if [ -z "${REPO_TAG}" ]; then
|
|
|
|
git_tag ${1} ${PRODUCT_VERSION}
|
|
|
|
fi
|
|
|
|
git -C ${1} reset --hard ${REPO_TAG}
|
2014-11-09 11:04:44 +01:00
|
|
|
}
|
2014-11-09 11:15:01 +01:00
|
|
|
|
2015-06-10 08:46:59 +02:00
|
|
|
git_update()
|
|
|
|
{
|
2017-01-16 07:37:06 +01:00
|
|
|
git -C ${1} fetch --all --prune
|
|
|
|
|
2015-06-10 08:46:59 +02:00
|
|
|
if [ -n "${2}" ]; then
|
2017-01-12 08:22:37 +01:00
|
|
|
git -C ${1} checkout ${2}
|
|
|
|
git -C ${1} pull
|
2015-06-10 08:46:59 +02:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2014-12-11 15:23:35 +01:00
|
|
|
git_describe()
|
|
|
|
{
|
2016-03-16 11:38:45 +01:00
|
|
|
HEAD=${2:-"HEAD"}
|
|
|
|
|
|
|
|
VERSION=$(git -C ${1} describe --abbrev=0 --always ${HEAD})
|
|
|
|
REVISION=$(git -C ${1} rev-list --count ${VERSION}..${HEAD})
|
|
|
|
COMMENT=$(git -C ${1} rev-list --max-count=1 ${HEAD} | cut -c1-9)
|
2016-12-23 16:27:48 +01:00
|
|
|
BRANCH=$(git -C ${1} rev-parse --abbrev-ref ${HEAD})
|
2016-03-16 11:38:45 +01:00
|
|
|
REFTYPE=$(git -C ${1} cat-file -t ${HEAD})
|
2016-03-14 09:22:56 +01:00
|
|
|
|
2014-12-11 15:23:35 +01:00
|
|
|
if [ "${REVISION}" != "0" ]; then
|
|
|
|
# must construct full version string manually
|
|
|
|
VERSION=${VERSION}_${REVISION}
|
|
|
|
fi
|
|
|
|
|
|
|
|
export REPO_VERSION=${VERSION}
|
|
|
|
export REPO_COMMENT=${COMMENT}
|
2016-03-16 11:08:27 +01:00
|
|
|
export REPO_REFTYPE=${REFTYPE}
|
2016-12-23 16:27:48 +01:00
|
|
|
export REPO_BRANCH=${BRANCH}
|
|
|
|
}
|
|
|
|
|
|
|
|
git_branch()
|
|
|
|
{
|
|
|
|
# only check for consistency
|
2017-01-11 07:31:06 +01:00
|
|
|
if [ -z "${2}" ]; then
|
|
|
|
return
|
|
|
|
fi
|
|
|
|
|
|
|
|
BRANCH=$(git -C ${1} rev-parse --abbrev-ref HEAD)
|
|
|
|
|
|
|
|
if [ "${2}" != "${BRANCH}" ]; then
|
2016-12-23 16:27:48 +01:00
|
|
|
echo ">>> ${1} does not match expected branch: ${2}"
|
2017-01-11 07:31:06 +01:00
|
|
|
echo ">>> To continue anyway set ${3}=${BRANCH}"
|
2016-12-23 16:27:48 +01:00
|
|
|
exit 1
|
|
|
|
fi
|
2014-12-11 15:23:35 +01:00
|
|
|
}
|
|
|
|
|
2015-06-09 09:05:10 +02:00
|
|
|
git_tag()
|
|
|
|
{
|
|
|
|
# Fuzzy-match a tag and return it for the caller.
|
|
|
|
|
|
|
|
POOL=$(git -C ${1} tag | grep ^${2}\$ || true)
|
|
|
|
if [ -z "${POOL}" ]; then
|
|
|
|
VERSION=${2%.*}
|
|
|
|
FUZZY=${2##${VERSION}.}
|
|
|
|
|
|
|
|
for _POOL in $(git -C ${1} tag | grep ^${VERSION} | sort -r); do
|
|
|
|
_POOL=${_POOL##${VERSION}}
|
|
|
|
if [ -z "${_POOL}" ]; then
|
|
|
|
POOL=${VERSION}${_POOL}
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
if [ ${_POOL##.} -lt ${FUZZY} ]; then
|
|
|
|
POOL=${VERSION}${_POOL}
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -z "${POOL}" ]; then
|
|
|
|
echo ">>> ${1} doesn't match tag ${2}"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
echo ">>> ${1} matches tag ${2} -> ${POOL}"
|
|
|
|
|
|
|
|
export REPO_TAG=${POOL}
|
|
|
|
}
|
|
|
|
|
2014-12-28 11:01:40 +01:00
|
|
|
setup_clone()
|
|
|
|
{
|
2015-07-24 10:20:05 +02:00
|
|
|
echo ">>> Setting up ${2} clone in ${1}"
|
2014-12-28 11:01:40 +01:00
|
|
|
|
2015-01-07 06:56:10 +01:00
|
|
|
# repositories may be huge so avoid the copy :)
|
|
|
|
mkdir -p ${1}${2} && mount_unionfs -o below ${2} ${1}${2}
|
2014-12-28 11:01:40 +01:00
|
|
|
}
|
|
|
|
|
2015-07-24 10:20:05 +02:00
|
|
|
setup_copy()
|
|
|
|
{
|
|
|
|
echo ">>> Setting up ${2} copy in ${1}"
|
|
|
|
|
|
|
|
# in case we want to clobber HEAD
|
2015-08-10 10:33:35 +02:00
|
|
|
rm -rf ${1}${2}
|
2015-08-05 08:58:23 +02:00
|
|
|
mkdir -p $(dirname ${1}${2})
|
|
|
|
cp -r ${2} ${1}${2}
|
2015-07-24 10:20:05 +02:00
|
|
|
}
|
|
|
|
|
2014-12-20 22:34:42 +01:00
|
|
|
setup_chroot()
|
|
|
|
{
|
|
|
|
echo ">>> Setting up chroot in ${1}"
|
|
|
|
|
2016-07-18 07:16:57 +02:00
|
|
|
if [ ${PRODUCT_HOST} != ${PRODUCT_ARCH} ]; then
|
|
|
|
# additional emulation layer so that chroot
|
|
|
|
# looks like a native environment later on
|
|
|
|
mkdir -p ${1}/usr/local/bin
|
|
|
|
cp /usr/local/bin/qemu-${PRODUCT_TARGET}-static \
|
|
|
|
${1}/usr/local/bin
|
|
|
|
/usr/local/etc/rc.d/qemu_user_static onerestart
|
2016-07-18 08:38:36 +02:00
|
|
|
|
|
|
|
# copy the native toolchain for extra speed
|
|
|
|
XTOOLS_SET=$(find ${SETSDIR} -name "xtools-*-${PRODUCT_ARCH}.txz")
|
|
|
|
if [ -n "${XTOOLS_SET}" ]; then
|
2016-07-18 17:53:08 +02:00
|
|
|
tar -C ${1} -xpf ${XTOOLS_SET} \
|
|
|
|
--exclude="./bin/sh" \
|
|
|
|
--exclude="./usr/bin/flex"
|
2016-07-18 08:38:36 +02:00
|
|
|
fi
|
2016-07-18 07:16:57 +02:00
|
|
|
fi
|
|
|
|
|
2014-12-20 22:34:42 +01:00
|
|
|
cp /etc/resolv.conf ${1}/etc
|
|
|
|
mount -t devfs devfs ${1}/dev
|
2016-07-18 07:16:57 +02:00
|
|
|
chroot ${1} /bin/sh /etc/rc.d/ldconfig start
|
2014-12-20 22:34:42 +01:00
|
|
|
}
|
|
|
|
|
2015-03-13 09:11:36 +01:00
|
|
|
setup_marker()
|
|
|
|
{
|
|
|
|
# Let opnsense-update(8) know it's up to date
|
2016-05-21 11:54:42 +02:00
|
|
|
MARKER="/usr/local/opnsense/version/opnsense-update.${3}"
|
2015-03-13 09:11:36 +01:00
|
|
|
|
|
|
|
if [ ! -f ${1}${MARKER} ]; then
|
|
|
|
# first call means bootstrap the marker file
|
|
|
|
mkdir -p ${1}$(dirname ${MARKER})
|
|
|
|
echo ${2} > ${1}${MARKER}
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2014-11-09 13:14:07 +01:00
|
|
|
setup_base()
|
|
|
|
{
|
2015-05-07 13:08:21 +02:00
|
|
|
local BASE_SET BASE_VER
|
|
|
|
|
2014-11-09 13:14:07 +01:00
|
|
|
echo ">>> Setting up world in ${1}"
|
|
|
|
|
2016-07-17 15:38:10 +02:00
|
|
|
BASE_SET=$(find ${SETSDIR} -name "base-*-${PRODUCT_ARCH}.txz")
|
2015-05-07 13:08:21 +02:00
|
|
|
|
|
|
|
tar -C ${1} -xpf ${BASE_SET}
|
2015-03-13 09:11:36 +01:00
|
|
|
|
2015-03-09 08:01:50 +01:00
|
|
|
# /home is needed for LiveCD images, and since it
|
|
|
|
# belongs to the base system, we create it from here.
|
2014-11-15 11:29:03 +01:00
|
|
|
mkdir -p ${1}/home
|
|
|
|
|
2015-04-03 12:08:03 +02:00
|
|
|
# /conf is needed for the config subsystem at this
|
|
|
|
# point as the storage location. We ought to add
|
|
|
|
# this here, because otherwise read-only install
|
|
|
|
# media wouldn't be able to bootstrap the directory.
|
|
|
|
mkdir -p ${1}/conf
|
|
|
|
|
2015-05-07 13:08:21 +02:00
|
|
|
BASE_VER=${BASE_SET##${SETSDIR}/base-}
|
2015-03-13 09:11:36 +01:00
|
|
|
|
2015-06-18 11:57:20 +02:00
|
|
|
setup_marker ${1} ${BASE_VER%%.txz} base
|
2014-11-09 13:14:07 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
setup_kernel()
|
|
|
|
{
|
2015-05-07 13:08:21 +02:00
|
|
|
local KERNEL_SET KERNEL_VER
|
2015-05-07 14:07:03 +02:00
|
|
|
|
2014-11-09 13:14:07 +01:00
|
|
|
echo ">>> Setting up kernel in ${1}"
|
|
|
|
|
2016-07-17 15:38:10 +02:00
|
|
|
KERNEL_SET=$(find ${SETSDIR} -name "kernel-*-${PRODUCT_ARCH}.txz")
|
2015-03-13 09:11:36 +01:00
|
|
|
|
2015-04-28 13:58:28 +02:00
|
|
|
tar -C ${1} -xpf ${KERNEL_SET}
|
2015-03-13 09:11:36 +01:00
|
|
|
|
2015-05-07 13:08:21 +02:00
|
|
|
KERNEL_VER=${KERNEL_SET##${SETSDIR}/kernel-}
|
2015-03-13 09:11:36 +01:00
|
|
|
|
2015-06-18 11:57:20 +02:00
|
|
|
setup_marker ${1} ${KERNEL_VER%%.txz} kernel
|
2014-11-09 13:14:07 +01:00
|
|
|
}
|
|
|
|
|
2015-09-11 22:18:34 +02:00
|
|
|
setup_distfiles()
|
|
|
|
{
|
|
|
|
echo ">>> Setting up distfiles in ${1}"
|
|
|
|
|
|
|
|
DISTFILES_SET=$(find ${SETSDIR} -name "distfiles-*.tar")
|
|
|
|
if [ -n "${DISTFILES_SET}" ]; then
|
|
|
|
mkdir -p ${1}${PORTSDIR}
|
|
|
|
tar -C ${1}${PORTSDIR} -xpf ${DISTFILES_SET}
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2016-02-04 21:55:29 +01:00
|
|
|
setup_entropy()
|
|
|
|
{
|
|
|
|
echo ">>> Setting up entropy in ${1}"
|
|
|
|
|
|
|
|
mkdir -p ${1}/boot
|
|
|
|
|
|
|
|
umask 077
|
|
|
|
|
|
|
|
dd if=/dev/random of=${1}/boot/entropy bs=4096 count=1
|
|
|
|
dd if=/dev/random of=${1}/entropy bs=4096 count=1
|
|
|
|
|
|
|
|
chown 0:0 ${1}/boot/entropy
|
|
|
|
chown 0:0 ${1}/entropy
|
|
|
|
|
|
|
|
umask 022
|
|
|
|
}
|
|
|
|
|
2015-12-25 23:47:57 +01:00
|
|
|
generate_signature()
|
|
|
|
{
|
2016-02-17 22:04:20 +01:00
|
|
|
if [ -n "$(${PRODUCT_SIGNCHK})" ]; then
|
2016-10-03 04:36:00 +02:00
|
|
|
echo -n ">>> Signing $(basename ${1})... "
|
2016-02-17 22:04:20 +01:00
|
|
|
sha256 -q ${1} | ${PRODUCT_SIGNCMD} > ${1}.sig
|
2015-12-26 17:37:52 +01:00
|
|
|
echo "done"
|
2015-12-25 23:47:57 +01:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2016-05-21 11:54:42 +02:00
|
|
|
check_images()
|
|
|
|
{
|
|
|
|
SELF=${1}
|
|
|
|
SKIP=${2}
|
|
|
|
|
2016-07-17 15:38:10 +02:00
|
|
|
IMAGE=$(find ${IMAGESDIR} -name "*-${SELF}-${PRODUCT_ARCH}.*")
|
2016-05-21 11:54:42 +02:00
|
|
|
|
|
|
|
if [ -f "${IMAGE}" -a -z "${SKIP}" ]; then
|
|
|
|
echo ">>> Reusing ${SELF} image: ${IMAGE}"
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2016-01-25 07:38:07 +01:00
|
|
|
check_packages()
|
|
|
|
{
|
2016-05-21 11:54:42 +02:00
|
|
|
SELF=${1}
|
2016-01-25 07:45:36 +01:00
|
|
|
SKIP=${2}
|
2016-01-25 07:38:07 +01:00
|
|
|
|
2016-07-17 15:38:10 +02:00
|
|
|
PACKAGESET=$(find ${SETSDIR} -name "packages-*-${PRODUCT_FLAVOUR}-${PRODUCT_ARCH}.tar")
|
2016-05-21 11:54:42 +02:00
|
|
|
|
|
|
|
if [ -z "${SELF}" -o -z "${PACKAGESET}" -o -n "${SKIP}" ]; then
|
2016-01-25 07:38:07 +01:00
|
|
|
return
|
|
|
|
fi
|
|
|
|
|
2016-05-21 11:54:42 +02:00
|
|
|
DONE=$(tar tf ${PACKAGESET} | grep "^\./\.${SELF}_done\$" || true)
|
2016-01-25 07:38:07 +01:00
|
|
|
if [ -n "${DONE}" ]; then
|
2016-05-21 11:54:42 +02:00
|
|
|
echo ">>> Packages (${SELF}) are up to date"
|
2016-01-25 07:38:07 +01:00
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2015-05-08 13:12:10 +02:00
|
|
|
extract_packages()
|
2014-11-15 10:55:32 +01:00
|
|
|
{
|
2015-05-08 13:12:10 +02:00
|
|
|
echo ">>> Extracting packages in ${1}"
|
2014-11-15 10:55:32 +01:00
|
|
|
|
2014-12-23 18:36:52 +01:00
|
|
|
BASEDIR=${1}
|
|
|
|
|
2015-05-08 13:12:10 +02:00
|
|
|
rm -rf ${BASEDIR}${PACKAGESDIR}/All
|
|
|
|
mkdir -p ${BASEDIR}${PACKAGESDIR}/All
|
|
|
|
|
2016-07-17 15:38:10 +02:00
|
|
|
PACKAGESET=$(find ${SETSDIR} -name "packages-*-${PRODUCT_FLAVOUR}-${PRODUCT_ARCH}.tar")
|
2015-05-08 13:12:10 +02:00
|
|
|
if [ -f "${PACKAGESET}" ]; then
|
|
|
|
tar -C ${BASEDIR}${PACKAGESDIR} -xpf ${PACKAGESET}
|
|
|
|
fi
|
2015-07-18 18:47:46 +02:00
|
|
|
}
|
|
|
|
|
2016-07-05 10:08:50 +02:00
|
|
|
search_packages()
|
|
|
|
{
|
|
|
|
BASEDIR=${1}
|
|
|
|
shift
|
|
|
|
PKGLIST=${@}
|
|
|
|
|
|
|
|
echo ">>> Searching packages in ${BASEDIR}: ${PKGLIST}"
|
|
|
|
|
|
|
|
for PKG in ${PKGLIST}; do
|
|
|
|
# exact matching according to package name
|
|
|
|
for PKGFILE in $(cd ${BASEDIR}${PACKAGESDIR}; \
|
|
|
|
find All -type f); do
|
|
|
|
PKGINFO=$(pkg -c ${BASEDIR} info -F ${PACKAGESDIR}/${PKGFILE} | grep ^Name | awk '{ print $3; }')
|
|
|
|
if [ ${PKG} = ${PKGINFO} ]; then
|
|
|
|
return 0
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
# match using globbing as a second pass
|
|
|
|
for PKGGLOB in $(cd ${BASEDIR}${PACKAGESDIR}; \
|
|
|
|
find All -name "${PKG}" -type f); do
|
|
|
|
return 0
|
|
|
|
done
|
|
|
|
done
|
|
|
|
|
|
|
|
return 1
|
|
|
|
}
|
|
|
|
|
2015-07-18 18:47:46 +02:00
|
|
|
remove_packages()
|
|
|
|
{
|
|
|
|
BASEDIR=${1}
|
|
|
|
shift
|
|
|
|
PKGLIST=${@}
|
2015-05-08 13:12:10 +02:00
|
|
|
|
2016-02-01 19:49:35 +01:00
|
|
|
echo ">>> Removing packages in ${BASEDIR}: ${PKGLIST}"
|
|
|
|
|
2015-07-16 18:13:34 +02:00
|
|
|
for PKG in ${PKGLIST}; do
|
2016-07-05 10:08:50 +02:00
|
|
|
# exact matching according to package name
|
2016-07-05 09:33:20 +02:00
|
|
|
for PKGFILE in $(cd ${BASEDIR}${PACKAGESDIR}; \
|
|
|
|
find All -type f); do
|
2015-07-24 13:28:03 +02:00
|
|
|
PKGINFO=$(pkg -c ${BASEDIR} info -F ${PACKAGESDIR}/${PKGFILE} | grep ^Name | awk '{ print $3; }')
|
2015-07-16 18:13:34 +02:00
|
|
|
if [ ${PKG} = ${PKGINFO} ]; then
|
2015-07-24 13:28:03 +02:00
|
|
|
rm ${BASEDIR}${PACKAGESDIR}/${PKGFILE}
|
2015-07-16 18:13:34 +02:00
|
|
|
fi
|
2015-05-08 13:12:10 +02:00
|
|
|
done
|
2016-07-05 10:08:50 +02:00
|
|
|
# match using globbing as a second pass
|
2016-07-05 09:33:20 +02:00
|
|
|
for PKGGLOB in $(cd ${BASEDIR}${PACKAGESDIR}; \
|
|
|
|
find All -name "${PKG}" -type f); do
|
|
|
|
rm ${BASEDIR}${PACKAGESDIR}/${PKGGLOB}
|
|
|
|
done
|
2015-07-16 18:13:34 +02:00
|
|
|
done
|
2015-05-08 13:12:10 +02:00
|
|
|
}
|
|
|
|
|
2016-05-26 07:26:15 +02:00
|
|
|
lock_packages()
|
2015-05-08 13:12:10 +02:00
|
|
|
{
|
2016-05-26 07:26:15 +02:00
|
|
|
BASEDIR=${1}
|
|
|
|
shift
|
|
|
|
PKGLIST=${@}
|
|
|
|
if [ -z "${PKGLIST}" ]; then
|
|
|
|
PKGLIST="-a"
|
|
|
|
fi
|
2015-05-08 13:12:10 +02:00
|
|
|
|
2016-05-26 07:26:15 +02:00
|
|
|
echo ">>> Locking packages in ${BASEDIR}: ${PKGLIST}"
|
|
|
|
|
|
|
|
for PKG in ${PKGLIST}; do
|
|
|
|
pkg -c ${BASEDIR} lock -qy ${PKG}
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
2016-07-05 10:08:50 +02:00
|
|
|
bootstrap_packages()
|
|
|
|
{
|
|
|
|
BASEDIR=${1}
|
|
|
|
|
|
|
|
echo ">>> Bootstrapping packages in ${BASEDIR}"
|
|
|
|
|
2016-07-10 16:49:31 +02:00
|
|
|
for PKG in $(cd ${BASEDIR}; find .${PACKAGESDIR}/All -type f); do
|
2016-07-05 10:08:50 +02:00
|
|
|
# Adds all available packages and removes the
|
|
|
|
# ones that cannot be installed due to missing
|
|
|
|
# dependencies. This behaviour is desired.
|
|
|
|
if ! pkg -c ${BASEDIR} add ${PKG}; then
|
|
|
|
rm -r ${BASEDIR}/${PKG}
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
2016-05-26 07:26:15 +02:00
|
|
|
install_packages()
|
|
|
|
{
|
2015-05-08 13:12:10 +02:00
|
|
|
BASEDIR=${1}
|
|
|
|
shift
|
|
|
|
PKGLIST=${@}
|
2014-12-23 18:36:52 +01:00
|
|
|
|
2016-05-26 07:26:15 +02:00
|
|
|
echo ">>> Installing packages in ${BASEDIR}: ${PKGLIST}"
|
|
|
|
|
2015-07-24 08:13:53 +02:00
|
|
|
# remove previous packages for a clean environment
|
2015-07-17 17:51:48 +02:00
|
|
|
pkg -c ${BASEDIR} remove -fya
|
|
|
|
|
2016-07-05 10:08:50 +02:00
|
|
|
# Adds all selected packages and fails if one cannot
|
|
|
|
# be installed. Used to build a runtime environment.
|
|
|
|
for PKG in pkg ${PKGLIST}; do
|
|
|
|
PKGFOUND=
|
|
|
|
for PKGFILE in $({
|
2015-07-24 08:13:53 +02:00
|
|
|
cd ${BASEDIR}
|
2016-07-05 10:08:50 +02:00
|
|
|
find .${PACKAGESDIR}/All -name "${PKG}-*.txz"
|
2015-07-24 08:13:53 +02:00
|
|
|
}); do
|
2016-07-05 10:08:50 +02:00
|
|
|
PKGINFO=$(pkg -c ${BASEDIR} info -F ${PKGFILE} | grep ^Name | awk '{ print $3; }')
|
|
|
|
if [ ${PKG} = ${PKGINFO} ]; then
|
|
|
|
PKGFOUND=${PKGFILE}
|
2015-09-10 15:50:04 +02:00
|
|
|
fi
|
2014-12-23 18:36:52 +01:00
|
|
|
done
|
2016-07-05 10:08:50 +02:00
|
|
|
if [ -n "${PKGFOUND}" ]; then
|
|
|
|
pkg -c ${BASEDIR} add ${PKGFOUND}
|
|
|
|
else
|
|
|
|
echo "Could not find package: ${PKG}" >&2
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
done
|
2015-02-19 08:38:53 +01:00
|
|
|
|
2016-05-26 07:26:15 +02:00
|
|
|
# collect all installed packages (minus locked packages)
|
|
|
|
PKGLIST="$(pkg -c ${BASEDIR} query -e "%k != 1" %n)"
|
2015-04-27 10:35:01 +02:00
|
|
|
|
|
|
|
for PKG in ${PKGLIST}; do
|
|
|
|
# add, unlike install, is not aware of repositories :(
|
2015-05-07 08:11:21 +02:00
|
|
|
pkg -c ${BASEDIR} annotate -qyA ${PKG} \
|
|
|
|
repository ${PRODUCT_NAME}
|
2015-04-27 10:35:01 +02:00
|
|
|
done
|
2015-05-08 13:12:10 +02:00
|
|
|
}
|
2014-11-15 10:55:32 +01:00
|
|
|
|
2015-07-17 17:37:31 +02:00
|
|
|
custom_packages()
|
2015-07-16 17:34:35 +02:00
|
|
|
{
|
|
|
|
chroot ${1} /bin/sh -es << EOF
|
2016-08-29 20:10:19 +02:00
|
|
|
make -C ${2} ${3} FLAVOUR=${PRODUCT_FLAVOUR} WRKDIR=/work \
|
|
|
|
PKGDIR=${PACKAGESDIR}/All package
|
2015-07-16 17:34:35 +02:00
|
|
|
EOF
|
|
|
|
}
|
|
|
|
|
2015-05-08 13:12:10 +02:00
|
|
|
bundle_packages()
|
|
|
|
{
|
2016-01-20 10:24:20 +01:00
|
|
|
BASEDIR=${1}
|
2016-05-21 11:54:42 +02:00
|
|
|
SELF=${2}
|
2016-01-20 10:24:20 +01:00
|
|
|
|
2016-06-28 20:34:11 +02:00
|
|
|
shift
|
|
|
|
shift
|
|
|
|
|
|
|
|
REDOS=${@}
|
|
|
|
|
2015-05-16 13:25:53 +02:00
|
|
|
sh ./clean.sh packages
|
2015-05-08 13:12:10 +02:00
|
|
|
|
2015-07-24 07:40:53 +02:00
|
|
|
git_describe ${PORTSDIR}
|
|
|
|
|
2016-05-26 07:26:15 +02:00
|
|
|
# clean up in case of partial run
|
|
|
|
rm -rf ${BASEDIR}${PACKAGESDIR}-new
|
|
|
|
|
2015-05-08 13:12:10 +02:00
|
|
|
# rebuild expected FreeBSD structure
|
2016-01-20 10:24:20 +01:00
|
|
|
mkdir -p ${BASEDIR}${PACKAGESDIR}-new/Latest
|
|
|
|
mkdir -p ${BASEDIR}${PACKAGESDIR}-new/All
|
|
|
|
|
|
|
|
for PROGRESS in $({
|
|
|
|
find ${BASEDIR}${PACKAGESDIR} -type f -name ".*_done"
|
|
|
|
}); do
|
|
|
|
# push previous markers to home location
|
|
|
|
cp ${PROGRESS} ${BASEDIR}${PACKAGESDIR}-new
|
|
|
|
done
|
|
|
|
|
2016-06-28 20:34:11 +02:00
|
|
|
for REDO in ${REDOS}; do
|
|
|
|
# remove markers we need to rerun
|
|
|
|
rm -f ${BASEDIR}${PACKAGESDIR}-new/.${REDO}_done
|
|
|
|
done
|
|
|
|
|
2016-05-21 11:54:42 +02:00
|
|
|
if [ -n "${SELF}" ]; then
|
2016-01-20 10:24:20 +01:00
|
|
|
# add build marker to set
|
2017-01-05 07:49:32 +01:00
|
|
|
MARKER="${BASEDIR}${PACKAGESDIR}-new/.${SELF}_done"
|
|
|
|
if [ ! -f ${MARKER} ]; then
|
|
|
|
# append build info if new
|
|
|
|
sh ./info.sh > ${MARKER}
|
|
|
|
fi
|
|
|
|
touch ${MARKER}
|
2016-01-20 10:24:20 +01:00
|
|
|
fi
|
2015-05-08 13:12:10 +02:00
|
|
|
|
|
|
|
# push packages to home location
|
2016-01-20 10:24:20 +01:00
|
|
|
cp ${BASEDIR}${PACKAGESDIR}/All/* ${BASEDIR}${PACKAGESDIR}-new/All
|
2015-05-08 13:12:10 +02:00
|
|
|
|
2016-02-01 18:07:20 +01:00
|
|
|
SIGNARGS=
|
2015-11-17 20:10:41 +01:00
|
|
|
|
2016-02-17 22:04:20 +01:00
|
|
|
if [ -n "$(${PRODUCT_SIGNCHK})" ]; then
|
|
|
|
SIGNARGS="signing_command: ${PRODUCT_SIGNCMD}"
|
2015-05-08 13:12:10 +02:00
|
|
|
fi
|
|
|
|
|
2016-12-29 20:37:32 +01:00
|
|
|
# generate all signatures and add bootstrap links
|
|
|
|
for PKGFILE in $(cd ${BASEDIR}${PACKAGESDIR}-new; \
|
|
|
|
find All -type f); do
|
|
|
|
PKGINFO=$(pkg info -F ${BASEDIR}${PACKAGESDIR}-new/${PKGFILE} \
|
|
|
|
| grep ^Name | awk '{ print $3; }')
|
|
|
|
(
|
|
|
|
cd ${BASEDIR}${PACKAGESDIR}-new/Latest
|
|
|
|
ln -s ../${PKGFILE} ${PKGINFO}.txz
|
|
|
|
)
|
|
|
|
generate_signature \
|
|
|
|
${BASEDIR}${PACKAGESDIR}-new/Latest/${PKGINFO}.txz
|
|
|
|
done
|
2016-02-01 18:07:20 +01:00
|
|
|
|
2015-05-08 13:12:10 +02:00
|
|
|
# generate index files
|
2016-01-20 10:24:20 +01:00
|
|
|
pkg repo ${BASEDIR}${PACKAGESDIR}-new/ ${SIGNARGS}
|
2015-05-08 13:12:10 +02:00
|
|
|
|
2016-07-17 15:38:10 +02:00
|
|
|
REPO_RELEASE="${REPO_VERSION}-${PRODUCT_FLAVOUR}-${PRODUCT_ARCH}"
|
2015-07-24 09:54:46 +02:00
|
|
|
echo -n ">>> Creating package mirror set for ${REPO_RELEASE}... "
|
2015-06-11 10:00:03 +02:00
|
|
|
tar -C ${STAGEDIR}${PACKAGESDIR}-new -cf \
|
2015-07-24 09:54:46 +02:00
|
|
|
${SETSDIR}/packages-${REPO_RELEASE}.tar .
|
2015-05-08 13:12:10 +02:00
|
|
|
echo "done"
|
2016-10-04 01:47:38 +02:00
|
|
|
|
|
|
|
generate_signature ${SETSDIR}/packages-${REPO_RELEASE}.tar
|
2015-05-08 13:12:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
clean_packages()
|
|
|
|
{
|
2015-05-10 13:59:51 +02:00
|
|
|
rm -rf ${1}${PACKAGESDIR}
|
2015-05-08 13:12:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
setup_packages()
|
|
|
|
{
|
|
|
|
extract_packages ${1}
|
2017-01-05 18:02:21 +01:00
|
|
|
install_packages ${@} ${PRODUCT_PKGNAME} ${PRODUCT_ADDITIONS}
|
2015-05-08 13:12:10 +02:00
|
|
|
clean_packages ${1}
|
2014-11-15 10:55:32 +01:00
|
|
|
}
|
|
|
|
|
2016-05-06 06:55:01 +02:00
|
|
|
_setup_extras_generic()
|
2016-05-05 17:33:12 +02:00
|
|
|
{
|
|
|
|
if [ ! -f ${CONFIGDIR}/extras.conf ]; then
|
|
|
|
return
|
|
|
|
fi
|
|
|
|
|
2016-09-22 17:36:52 +02:00
|
|
|
unset -f ${2}_hook
|
|
|
|
|
2016-05-05 17:33:12 +02:00
|
|
|
. ${CONFIGDIR}/extras.conf
|
|
|
|
|
2016-05-05 22:37:51 +02:00
|
|
|
if [ -n "$(type ${2}_hook 2> /dev/null)" ]; then
|
|
|
|
echo ">>> Begin extra: ${2}_hook"
|
2016-05-05 17:33:12 +02:00
|
|
|
${2}_hook ${1}
|
2016-05-05 22:37:51 +02:00
|
|
|
echo ">>> End extra: ${2}_hook"
|
2016-05-05 17:33:12 +02:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2016-05-06 06:55:01 +02:00
|
|
|
_setup_extras_device()
|
|
|
|
{
|
|
|
|
if [ ! -f ${DEVICEDIR}/${PRODUCT_DEVICE}.conf ]; then
|
|
|
|
return
|
|
|
|
fi
|
|
|
|
|
2016-09-22 17:36:52 +02:00
|
|
|
unset -f ${2}_hook
|
|
|
|
|
2016-05-06 06:55:01 +02:00
|
|
|
. ${DEVICEDIR}/${PRODUCT_DEVICE}.conf
|
|
|
|
|
|
|
|
if [ -n "$(type ${2}_hook 2> /dev/null)" ]; then
|
|
|
|
echo ">>> Begin ${PRODUCT_DEVICE} extra: ${2}_hook"
|
|
|
|
${2}_hook ${1}
|
|
|
|
echo ">>> End ${PRODUCT_DEVICE} extra: ${2}_hook"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
setup_extras()
|
|
|
|
{
|
|
|
|
_setup_extras_generic ${@}
|
|
|
|
_setup_extras_device ${@}
|
|
|
|
}
|
|
|
|
|
2014-11-16 16:20:27 +01:00
|
|
|
setup_mtree()
|
|
|
|
{
|
|
|
|
echo ">>> Creating mtree summary of files present..."
|
|
|
|
|
|
|
|
cat > ${1}/tmp/installed_filesystem.mtree.exclude <<EOF
|
|
|
|
./dev
|
|
|
|
./tmp
|
|
|
|
EOF
|
2015-05-04 09:13:58 +02:00
|
|
|
chroot ${1} /bin/sh -es <<EOF
|
2014-11-16 16:20:27 +01:00
|
|
|
/usr/sbin/mtree -c -k uid,gid,mode,size,sha256digest -p / -X /tmp/installed_filesystem.mtree.exclude > /tmp/installed_filesystem.mtree
|
|
|
|
/bin/chmod 600 /tmp/installed_filesystem.mtree
|
|
|
|
/bin/mv /tmp/installed_filesystem.mtree /etc/
|
|
|
|
/bin/rm /tmp/installed_filesystem.mtree.exclude
|
|
|
|
EOF
|
|
|
|
}
|
|
|
|
|
2014-11-09 11:15:01 +01:00
|
|
|
setup_stage()
|
|
|
|
{
|
2014-12-21 09:30:41 +01:00
|
|
|
echo ">>> Setting up stage in ${1}"
|
|
|
|
|
2016-05-20 16:12:11 +02:00
|
|
|
MOUNTDIRS="/dev /mnt ${SRCDIR} ${PORTSDIR} ${COREDIR} ${PLUGINSDIR}"
|
2016-05-21 10:53:24 +02:00
|
|
|
STAGE=${1}
|
|
|
|
|
2016-07-19 08:39:00 +02:00
|
|
|
local PID DIR
|
|
|
|
|
2016-05-21 10:53:24 +02:00
|
|
|
shift
|
2015-01-07 06:56:10 +01:00
|
|
|
|
2016-06-03 12:10:25 +02:00
|
|
|
# kill stale pids for chrooted daemons
|
|
|
|
if [ -d ${STAGE}/var/run ]; then
|
|
|
|
PIDS=$(find ${STAGE}/var/run -name "*.pid")
|
|
|
|
for PID in ${PIDS}; do
|
|
|
|
pkill -F ${PID};
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
|
2014-12-20 22:31:37 +01:00
|
|
|
# might have been a chroot
|
2015-01-07 06:56:10 +01:00
|
|
|
for DIR in ${MOUNTDIRS}; do
|
2016-05-21 10:53:24 +02:00
|
|
|
if [ -d ${STAGE}${DIR} ]; then
|
|
|
|
umount ${STAGE}${DIR} 2> /dev/null || true
|
2015-01-07 06:56:10 +01:00
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
2014-12-20 22:31:37 +01:00
|
|
|
# remove base system files
|
2016-05-21 10:53:24 +02:00
|
|
|
rm -rf ${STAGE} 2> /dev/null ||
|
|
|
|
(chflags -R noschg ${STAGE}; rm -rf ${STAGE} 2> /dev/null)
|
2015-01-07 06:56:10 +01:00
|
|
|
|
2014-12-20 22:31:37 +01:00
|
|
|
# revive directory for next run
|
2016-05-21 10:53:24 +02:00
|
|
|
mkdir -p ${STAGE}
|
|
|
|
|
|
|
|
# additional directories if requested
|
|
|
|
for DIR in ${@}; do
|
|
|
|
mkdir -p ${STAGE}/${DIR}
|
|
|
|
done
|
2014-11-09 11:15:01 +01:00
|
|
|
}
|