2005-10-29 16:27:43 +00:00
|
|
|
#!/bin/sh
|
2010-01-19 02:39:03 +00:00
|
|
|
set -o errexit
|
2005-10-29 16:27:43 +00:00
|
|
|
|
2007-04-06 21:13:35 +00:00
|
|
|
# The first argument is the shell script that initializes the variables:
|
2005-10-29 16:27:43 +00:00
|
|
|
# sourceDir
|
|
|
|
# outputDir
|
|
|
|
# tmpDir
|
2010-04-10 23:14:42 +00:00
|
|
|
# addBuildCompatibilityLibDir
|
2013-07-05 10:51:42 +02:00
|
|
|
# systemPackages, commonPackages - lists of the hpkg packages copied/updated
|
|
|
|
# (in "system" and "common" respectively)
|
2013-07-06 02:29:51 +02:00
|
|
|
# repositories - all repository files
|
2013-07-05 10:51:42 +02:00
|
|
|
# downloadDir
|
2010-04-10 23:14:42 +00:00
|
|
|
# The following are only for image types:
|
2005-10-29 16:27:43 +00:00
|
|
|
# installDir
|
|
|
|
# isImage
|
|
|
|
# imagePath
|
|
|
|
# imageSize
|
2008-09-19 17:32:57 +00:00
|
|
|
# imageLabel
|
2013-07-05 10:51:42 +02:00
|
|
|
# resolvePackageDependencies
|
2007-04-06 21:13:35 +00:00
|
|
|
# updateOnly
|
2007-10-01 17:27:13 +00:00
|
|
|
# dontClearImage
|
2008-02-17 13:54:32 +00:00
|
|
|
# isVMwareImage
|
2008-08-18 08:39:46 +00:00
|
|
|
#
|
2008-04-19 15:55:54 +00:00
|
|
|
# addattr
|
2005-10-29 16:27:43 +00:00
|
|
|
# copyattr
|
2013-07-05 10:51:42 +02:00
|
|
|
# getPackageDependencies
|
2013-04-29 19:38:29 +02:00
|
|
|
# package
|
2005-10-29 16:27:43 +00:00
|
|
|
# rc
|
* BuildPlatformMain supports overriding HOST_LIBROOT on the target now,
so one can set it to the static libroot, if desired.
* Generic attribute emulation:
- Added build tool rm_attrs, a simple "rm" replacement, which also
removes the attributes directory for a given file.
- Added build/scripts/rm_attrs shell script, which wraps the
invocation of the rm_attrs tool. If it doesn't exist yet, the
ordinary rm is used.
- The RM jam variable refers to the rm_attrs script now, i.e. whenever
something is removed by the build system, the attributes are removed
too (if the build tool has already been built, that is).
- Removed the shell function attrrmrf() in build_haiku_image. We use
the rm_attrs tool instead, if necessary.
git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@24528 a95241bf-73f2-0310-859d-f6bbb57e9c96
2008-03-22 21:05:03 +00:00
|
|
|
# rmAttrs
|
2007-09-04 21:50:00 +00:00
|
|
|
# unzip
|
2010-04-10 23:14:42 +00:00
|
|
|
# The following are only for image types:
|
|
|
|
# bfsShell
|
|
|
|
# fsShellCommand
|
|
|
|
# makebootable
|
|
|
|
# resattr
|
2008-04-03 21:18:18 +00:00
|
|
|
# vmdkimage
|
2010-04-10 23:14:42 +00:00
|
|
|
# The following is only for cd types:
|
|
|
|
# generate_attribute_stores
|
|
|
|
# isCD
|
2005-10-29 16:27:43 +00:00
|
|
|
#
|
|
|
|
if [ $# -gt 0 ]; then
|
|
|
|
. $1
|
|
|
|
shift
|
|
|
|
fi
|
|
|
|
|
2010-04-10 23:14:42 +00:00
|
|
|
if [ ! $isCD ]; then
|
|
|
|
# If the haiku image path is a symlink resolve it now (makebootable needs the
|
|
|
|
# path of the actual device path under Linux).
|
|
|
|
normalizedImagePath=''
|
|
|
|
if readlink -f "$imagePath" > /dev/null 2>&1 ; then
|
|
|
|
normalizedImagePath=$(readlink -f "$imagePath")
|
2010-04-20 03:36:06 +00:00
|
|
|
elif realpath "$imagePath" > /dev/null 2>&1 ; then
|
2010-04-27 20:14:18 +00:00
|
|
|
normalizedImagePath=$(realpath "$imagePath")
|
2010-04-10 23:14:42 +00:00
|
|
|
elif greadlink -f "$imagePath" > /dev/null 2>&1 ; then
|
|
|
|
normalizedImagePath=$(greadlink -f "$imagePath")
|
|
|
|
fi
|
|
|
|
if [ -n "$normalizedImagePath" ]; then
|
|
|
|
imagePath="$normalizedImagePath"
|
|
|
|
fi
|
2008-06-18 13:02:41 +00:00
|
|
|
fi
|
|
|
|
|
2005-10-29 16:27:43 +00:00
|
|
|
# this adds the build library dir to LD_LIBRARY_PATH
|
|
|
|
eval "$addBuildCompatibilityLibDir"
|
|
|
|
|
|
|
|
# map the shell commands
|
2010-04-10 23:14:42 +00:00
|
|
|
if [ $isCD ]; then
|
|
|
|
outputDir=$tmpDir/cdsource
|
|
|
|
|
|
|
|
sPrefix=
|
|
|
|
tPrefix="$outputDir/"
|
|
|
|
cd=cd
|
|
|
|
scd=:
|
|
|
|
cp="$copyattr -d"
|
|
|
|
copyAttrs="$copyattr"
|
|
|
|
ln=ln
|
|
|
|
mkdir=mkdir
|
|
|
|
rm=rm
|
|
|
|
elif [ $isImage ]; then
|
2011-01-04 01:06:56 +00:00
|
|
|
# If FIFOs are used for the communication with the FS shell, prepare them.
|
|
|
|
if $fsShellCommand --uses-fifos; then
|
|
|
|
fifoBasePath=/tmp/build_haiku_image-$$-fifo
|
|
|
|
toFSShellFifo=${fifoBasePath}-to-shell
|
|
|
|
fromFSShellFifo=${fifoBasePath}-from-shell
|
|
|
|
|
|
|
|
rm -f $toFSShellFifo $fromFSShellFifo
|
|
|
|
mkfifo $toFSShellFifo $fromFSShellFifo
|
|
|
|
|
|
|
|
# Open the FIFOs such that they are ready for the fsShellCommand. This
|
|
|
|
# also makes sure that they remain open until this script exits. When we
|
|
|
|
# exit while the FS shell is still running and waiting for commands,
|
2011-01-04 01:39:30 +00:00
|
|
|
# closing of our file descriptors will break the FIFOs and the FS shell
|
2011-01-04 01:06:56 +00:00
|
|
|
# will exit, too.
|
2011-01-04 01:39:30 +00:00
|
|
|
# Note: A bit of trickery is needed since opening one end blocks until
|
|
|
|
# someone opens the other end.
|
|
|
|
sleep 3<$fromFSShellFifo 1 &
|
|
|
|
exec 6>$fromFSShellFifo 3<$fromFSShellFifo
|
|
|
|
sleep 5<$toFSShellFifo 1 &
|
|
|
|
exec 4>$toFSShellFifo 5<$toFSShellFifo
|
2011-01-04 01:06:56 +00:00
|
|
|
|
|
|
|
# Remove the FIFO files again -- we have the open FDs, so they can
|
|
|
|
# still be used and this makes sure they won't hang around any further.
|
|
|
|
rm -f $toFSShellFifo $fromFSShellFifo
|
|
|
|
|
|
|
|
# Remap the fsShellCommand and bfsShell such that they don't inherit the
|
|
|
|
# wrong FDs. For both fsShellCommand and bfsShell FD 3 is the input from
|
|
|
|
# the respectively other program, FD 4 is the output to it.
|
|
|
|
actualFSShellCommand="$fsShellCommand"
|
|
|
|
actualBFSShell="$bfsShell"
|
|
|
|
|
|
|
|
fsShellCommandWrapper()
|
|
|
|
{
|
|
|
|
$actualFSShellCommand 5>&- 6>&- "$@"
|
|
|
|
}
|
|
|
|
|
|
|
|
bfsShellWrapper()
|
|
|
|
{
|
|
|
|
$actualBFSShell 3>&5 4<&6 "$@"
|
|
|
|
}
|
|
|
|
|
|
|
|
fsShellCommand=fsShellCommandWrapper
|
|
|
|
bfsShell=bfsShellWrapper
|
|
|
|
fi
|
|
|
|
|
|
|
|
# set up the other commands
|
2005-10-29 16:27:43 +00:00
|
|
|
sPrefix=:
|
|
|
|
tPrefix=/myfs/
|
|
|
|
cd="$fsShellCommand cd"
|
|
|
|
scd="$fsShellCommand cd"
|
2008-08-18 08:39:46 +00:00
|
|
|
cp="$fsShellCommand cp -f"
|
2007-07-26 23:20:58 +00:00
|
|
|
copyAttrs="$fsShellCommand cp -a"
|
2005-10-29 16:27:43 +00:00
|
|
|
ln="$fsShellCommand ln"
|
|
|
|
mkdir="$fsShellCommand mkdir"
|
|
|
|
rm="$fsShellCommand rm"
|
|
|
|
mkindex="$fsShellCommand mkindex"
|
|
|
|
else
|
|
|
|
sPrefix=
|
|
|
|
# TODO: This should come from the environment.
|
|
|
|
tPrefix="$installDir/"
|
|
|
|
cd=cd
|
|
|
|
scd=:
|
|
|
|
cp="$copyattr -d"
|
2007-07-26 23:20:58 +00:00
|
|
|
copyAttrs="$copyattr"
|
2005-10-29 16:27:43 +00:00
|
|
|
ln=ln
|
|
|
|
mkdir=mkdir
|
|
|
|
rm=rm
|
2006-11-03 09:36:49 +00:00
|
|
|
mkindex=mkindex
|
2005-10-29 16:27:43 +00:00
|
|
|
fi
|
|
|
|
|
2010-04-24 21:32:17 +00:00
|
|
|
|
2010-02-27 17:48:12 +00:00
|
|
|
extractFile()
|
2007-09-04 21:50:00 +00:00
|
|
|
{
|
2013-08-01 08:53:06 +02:00
|
|
|
# extractFile <archive> <directory> <extractedSubDir>
|
2010-02-27 17:48:12 +00:00
|
|
|
archiveFile=$1
|
|
|
|
targetExtractedDir=$2
|
2010-02-27 18:15:47 +00:00
|
|
|
extractedSubDir=$3
|
2010-02-27 17:48:12 +00:00
|
|
|
|
|
|
|
extractDir=$tmpDir/extract
|
|
|
|
$rmAttrs -rf "$extractDir"
|
|
|
|
mkdir -p "$extractDir"
|
2010-04-24 19:52:36 +00:00
|
|
|
|
2010-02-27 17:48:12 +00:00
|
|
|
case "$archiveFile" in
|
|
|
|
*.zip)
|
2011-06-16 09:00:06 +02:00
|
|
|
echo "Extracting $archiveFile ..."
|
2010-02-27 17:48:12 +00:00
|
|
|
$unzip -q -d "$extractDir" "$archiveFile"
|
|
|
|
;;
|
|
|
|
*.tgz|*.tar.gz)
|
2011-06-16 09:00:06 +02:00
|
|
|
echo "Extracting $archiveFile ..."
|
2010-02-27 17:48:12 +00:00
|
|
|
tar -C "$extractDir" -xf "$archiveFile"
|
|
|
|
;;
|
2011-06-16 09:00:06 +02:00
|
|
|
*.hpkg)
|
2013-04-29 19:38:29 +02:00
|
|
|
echo "Extracting $archiveFile ..."
|
|
|
|
if [ -n "$extractedSubDir" ]; then
|
|
|
|
$package extract -C "$extractDir" "$archiveFile" \
|
|
|
|
"$extractedSubDir"
|
|
|
|
else
|
|
|
|
$package extract -C "$extractDir" "$archiveFile"
|
|
|
|
fi
|
2011-06-16 09:00:06 +02:00
|
|
|
;;
|
2010-02-27 17:48:12 +00:00
|
|
|
*)
|
2013-04-29 19:38:29 +02:00
|
|
|
echo "Unhandled archive extension in build_haiku_image" \
|
|
|
|
"extractFile()"
|
2010-02-27 17:48:12 +00:00
|
|
|
exit 1
|
|
|
|
;;
|
|
|
|
esac
|
2010-04-24 19:52:36 +00:00
|
|
|
|
2010-02-27 17:48:12 +00:00
|
|
|
if [ -f $extractDir/.OptionalPackageDescription ]; then
|
|
|
|
cat $extractDir/.OptionalPackageDescription >> $copyrightsFile
|
2008-04-19 15:55:54 +00:00
|
|
|
echo >> $copyrightsFile
|
2010-02-27 17:48:12 +00:00
|
|
|
rm $extractDir/.OptionalPackageDescription
|
2007-09-04 21:50:00 +00:00
|
|
|
fi
|
2008-04-19 15:55:54 +00:00
|
|
|
|
2013-04-29 19:38:29 +02:00
|
|
|
$cp -r "${sPrefix}$extractDir/$extractedSubDir/." \
|
|
|
|
"${tPrefix}$targetExtractedDir"
|
2008-04-19 15:55:54 +00:00
|
|
|
|
2010-02-27 17:48:12 +00:00
|
|
|
$rmAttrs -rf "$extractDir"
|
2007-09-04 21:50:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2013-07-05 10:51:42 +02:00
|
|
|
downloadFile()
|
|
|
|
{
|
|
|
|
url=$1
|
|
|
|
path=$2
|
|
|
|
|
|
|
|
if [ ! -f "$path" ]; then
|
|
|
|
wget -O "$path" "$url"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2008-04-19 15:55:54 +00:00
|
|
|
mkdir -p $tmpDir
|
|
|
|
copyrightsFile=$tmpDir/copyrights
|
|
|
|
$rmAttrs -f $copyrightsFile
|
|
|
|
|
2010-04-10 23:14:42 +00:00
|
|
|
if [ $isCD ]; then
|
|
|
|
# setup output dir
|
|
|
|
$rmAttrs -rf "$outputDir"
|
|
|
|
mkdir -p "$outputDir"
|
2010-04-27 20:14:18 +00:00
|
|
|
fi
|
2008-04-19 15:55:54 +00:00
|
|
|
|
2005-10-29 16:27:43 +00:00
|
|
|
# create the image and mount it
|
|
|
|
if [ $isImage ]; then
|
|
|
|
echo
|
2008-02-17 13:54:32 +00:00
|
|
|
|
|
|
|
imageOffsetFlags=
|
|
|
|
if [ $isVMwareImage ]; then
|
|
|
|
imageOffsetFlags="--start-offset 65536"
|
|
|
|
fi
|
|
|
|
|
2007-04-06 21:13:35 +00:00
|
|
|
if [ ! $updateOnly ]; then
|
|
|
|
echo "Creating image ..."
|
2008-02-17 13:54:32 +00:00
|
|
|
|
2009-04-12 09:18:18 +00:00
|
|
|
imageFlags="-i${imageSize}M"
|
|
|
|
if [ ! "$dontClearImage" ]; then
|
|
|
|
imageFlags="$imageFlags -c"
|
|
|
|
fi
|
|
|
|
|
2008-02-17 13:54:32 +00:00
|
|
|
if [ $isVMwareImage ]; then
|
2010-01-19 02:39:03 +00:00
|
|
|
$vmdkimage -h 64k $imageFlags "$imagePath"
|
2009-04-12 09:18:18 +00:00
|
|
|
else
|
2010-01-19 02:39:03 +00:00
|
|
|
$createImage $imageFlags "$imagePath"
|
2008-02-17 13:54:32 +00:00
|
|
|
fi
|
|
|
|
|
2008-09-19 17:32:57 +00:00
|
|
|
$bfsShell --initialize $imageOffsetFlags "$imagePath" \
|
2010-01-19 02:39:03 +00:00
|
|
|
"$imageLabel" "block_size 2048"
|
2008-03-27 21:11:04 +00:00
|
|
|
$makebootable $imageOffsetFlags "$imagePath"
|
2007-04-06 21:13:35 +00:00
|
|
|
fi
|
2011-01-04 01:06:56 +00:00
|
|
|
|
2008-03-27 21:11:04 +00:00
|
|
|
$bfsShell -n $imageOffsetFlags "$imagePath" > /dev/null &
|
2005-10-29 16:27:43 +00:00
|
|
|
sleep 1
|
2011-01-04 01:06:56 +00:00
|
|
|
|
|
|
|
# Close FDs 5 and 6. Those represent the pipe ends that are used by the
|
|
|
|
# FS shell. Closing them in the shell process makes sure an unexpected death
|
|
|
|
# of the FS shell causes writing to/reading from the other ends to fail
|
|
|
|
# immediately.
|
|
|
|
exec 5>&- 6>&-
|
|
|
|
|
2008-03-09 17:34:26 +00:00
|
|
|
# bail out, if mounting fails
|
2010-01-19 02:39:03 +00:00
|
|
|
$cd .
|
2005-10-29 16:27:43 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
echo "Populating image ..."
|
|
|
|
while [ $# -gt 0 ]; do
|
|
|
|
. $1
|
|
|
|
shift
|
|
|
|
done
|
|
|
|
|
|
|
|
|
2013-07-05 10:51:42 +02:00
|
|
|
# resolve package dependencies
|
|
|
|
if [ -n "$resolvePackageDependencies" ]; then
|
|
|
|
echo "Resolving package dependencies ..."
|
|
|
|
|
|
|
|
# additional packages for system
|
2013-07-06 02:29:51 +02:00
|
|
|
packageUrls=`$getPackageDependencies $repositories -- $systemPackages`
|
2013-07-05 10:51:42 +02:00
|
|
|
for packageUrl in $packageUrls; do
|
|
|
|
packageFileName=`basename $packageUrl`
|
|
|
|
packageFilePath="$downloadDir/$packageFileName"
|
|
|
|
downloadFile $packageUrl "$packageFilePath"
|
|
|
|
$cp "${sPrefix}$packageFilePath" "${tPrefix}system/packages"
|
|
|
|
systemPackages="$systemPackages $packageFilePath"
|
|
|
|
done
|
|
|
|
|
|
|
|
# additional packages for common
|
2013-07-06 02:29:51 +02:00
|
|
|
packageUrls=`$getPackageDependencies $repositories -- $systemPackages \
|
2013-07-05 10:51:42 +02:00
|
|
|
$commonPackages`
|
|
|
|
for packageUrl in $packageUrls; do
|
|
|
|
packageFileName=`basename $packageUrl`
|
|
|
|
packageFilePath="$downloadDir/$packageFileName"
|
|
|
|
downloadFile $packageUrl "$packageFilePath"
|
|
|
|
$cp "${sPrefix}$packageFilePath" "${tPrefix}common/packages"
|
|
|
|
commonPackages="$commonPackages $packageFilePath"
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
2013-04-29 19:38:29 +02:00
|
|
|
# install default settings for packages
|
2013-07-05 10:51:42 +02:00
|
|
|
for packageFile in $systemPackages $commonPackages; do
|
2013-04-29 19:38:29 +02:00
|
|
|
if $package list -p $packageFile | egrep '^settings/' > /dev/null; then
|
|
|
|
extractFile $packageFile common/settings settings
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
|
2008-04-19 15:55:54 +00:00
|
|
|
# add the concatenated copyrights as an attribute to AboutSystem
|
2011-06-17 15:11:16 +02:00
|
|
|
# TODO: That might not be necessary, when all third-party software everything
|
|
|
|
# is packaged. Though we might not package everything.
|
|
|
|
|
|
|
|
# if [ ! $updateOnly ]; then
|
|
|
|
# if [ -f $copyrightsFile ]; then
|
|
|
|
# copyrightAttrs=$tmpDir/copyrightAttrs
|
|
|
|
# $rmAttrs -f $copyrightAttrs
|
|
|
|
# touch $copyrightAttrs
|
|
|
|
# $addattr -f $copyrightsFile COPYRIGHTS $copyrightAttrs
|
|
|
|
# $copyAttrs ${sPrefix}$copyrightAttrs ${tPrefix}system/apps/AboutSystem
|
|
|
|
# fi
|
|
|
|
# fi
|
2008-04-19 15:55:54 +00:00
|
|
|
|
2010-04-10 23:14:42 +00:00
|
|
|
if [ $isCD ]; then
|
|
|
|
# generate the attribute stores
|
|
|
|
echo "Generating attribute stores ..."
|
|
|
|
$generate_attribute_stores "$tPrefix"
|
|
|
|
|
|
|
|
echo "Copying boot image ..."
|
|
|
|
$cp "$cdBootFloppy" "$outputDir"
|
|
|
|
|
2011-05-25 02:13:13 +00:00
|
|
|
if [ $(which mkisofs) ]; then
|
|
|
|
# build the iso image using mkisofs
|
|
|
|
echo "Building CD image (mkisofs)..."
|
|
|
|
mkisofs -uid 0 -gid 0 -b `basename $cdBootFloppy` -R -V "$cdLabel" -o "$cdImagePath" "$tPrefix"
|
|
|
|
elif [ $(which genisoimage) ]; then
|
|
|
|
# build the iso image using genisoimage
|
|
|
|
echo "Building CD image (genisoimage)..."
|
|
|
|
echo "WARNING: genisoimage fallback has known problems with long filenames!"
|
|
|
|
echo " Please install mkisofs before making production releases!"
|
|
|
|
genisoimage -r -iso-level 4 -b `basename $cdBootFloppy` -V "$cdLabel" -o "$cdImagePath" "$tPrefix"
|
|
|
|
else
|
|
|
|
echo "you need mkisofs (preferred) or genisoimage to create a CD image."
|
|
|
|
exit 1
|
|
|
|
fi
|
2010-04-10 23:14:42 +00:00
|
|
|
|
|
|
|
# cleanup output dir
|
|
|
|
$rmAttrs -rf "$outputDir"
|
|
|
|
fi
|
2008-04-19 15:55:54 +00:00
|
|
|
|
2005-10-29 16:27:43 +00:00
|
|
|
# unmount
|
|
|
|
if [ $isImage ]; then
|
|
|
|
echo "Unmounting ..."
|
|
|
|
$fsShellCommand sync
|
|
|
|
$fsShellCommand quit
|
|
|
|
fi
|