2005-10-29 16:27:43 +00:00
|
|
|
#!/bin/sh
|
|
|
|
|
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
|
|
|
|
# installDir
|
|
|
|
# isImage
|
|
|
|
# imagePath
|
|
|
|
# imageSize
|
|
|
|
# addBuildCompatibilityLibDir
|
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
|
2005-10-29 16:27:43 +00:00
|
|
|
#
|
|
|
|
# bfsShell
|
|
|
|
# copyattr
|
|
|
|
# fsShellCommand
|
|
|
|
# makebootable
|
|
|
|
# resattr
|
|
|
|
# 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
|
2008-02-17 13:54:32 +00:00
|
|
|
# vmdkheader
|
2005-10-29 16:27:43 +00:00
|
|
|
#
|
|
|
|
if [ $# -gt 0 ]; then
|
|
|
|
. $1
|
|
|
|
shift
|
|
|
|
fi
|
|
|
|
|
|
|
|
# this adds the build library dir to LD_LIBRARY_PATH
|
|
|
|
eval "$addBuildCompatibilityLibDir"
|
|
|
|
|
|
|
|
# map the shell commands
|
|
|
|
if [ $isImage ]; then
|
|
|
|
sPrefix=:
|
|
|
|
tPrefix=/myfs/
|
|
|
|
cd="$fsShellCommand cd"
|
|
|
|
scd="$fsShellCommand cd"
|
|
|
|
cp="$fsShellCommand cp"
|
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
|
|
|
|
|
2007-09-04 21:50:00 +00:00
|
|
|
|
|
|
|
unzipFile()
|
|
|
|
{
|
|
|
|
# unzipFile <archive> <directory>
|
|
|
|
zipFile=$1
|
|
|
|
targetUnzipDir=$2
|
|
|
|
|
|
|
|
echo "Unzipping $zipFile ..."
|
|
|
|
|
|
|
|
if [ $isImage ]; then
|
|
|
|
unzipDir=$tmpDir/unzip
|
* 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 -rf "$unzipDir"
|
2008-01-30 02:16:13 +00:00
|
|
|
mkdir -p "$unzipDir"
|
2007-09-04 21:50:00 +00:00
|
|
|
|
2008-01-30 02:16:13 +00:00
|
|
|
$unzip -q -d "$unzipDir" "$zipFile"
|
|
|
|
$cp -r "${sPrefix}$unzipDir/." "${tPrefix}$targetUnzipDir"
|
2007-09-04 21:50:00 +00:00
|
|
|
|
* 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 -rf "$unzipDir"
|
2007-09-04 21:50:00 +00:00
|
|
|
else
|
2008-01-30 02:16:13 +00:00
|
|
|
$unzip -q -o -d "${tPrefix}$targetUnzipDir" "${sPrefix}$zipFile"
|
2007-09-04 21:50:00 +00:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
|
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
|
|
|
|
|
|
|
ddFlags=
|
|
|
|
if [ $isVMwareImage ]; then
|
2008-03-27 21:11:04 +00:00
|
|
|
rm -f "$imagePath"
|
|
|
|
$vmdkheader -h 64k -i${imageSize}M "$imagePath" || exit 1
|
2008-02-17 13:54:32 +00:00
|
|
|
ddFlags="conv=notrunc oflag=append"
|
|
|
|
dontClearImage=
|
|
|
|
fi
|
|
|
|
|
2008-03-27 21:11:04 +00:00
|
|
|
if [ ! -e "$imagePath" -o ! "$dontClearImage" ]; then
|
|
|
|
dd if=/dev/zero of="$imagePath" bs=1048576 count=$imageSize $ddFlags
|
2007-10-01 17:27:13 +00:00
|
|
|
fi
|
2008-03-27 21:11:04 +00:00
|
|
|
$bfsShell --initialize $imageOffsetFlags "$imagePath" Haiku \
|
|
|
|
"block_size 2048" || exit 1
|
|
|
|
$makebootable $imageOffsetFlags "$imagePath"
|
2007-04-06 21:13:35 +00:00
|
|
|
fi
|
2008-03-27 21:11:04 +00:00
|
|
|
$bfsShell -n $imageOffsetFlags "$imagePath" > /dev/null &
|
2005-10-29 16:27:43 +00:00
|
|
|
sleep 1
|
2008-03-09 17:34:26 +00:00
|
|
|
# bail out, if mounting fails
|
|
|
|
$cd . || exit 1
|
2005-10-29 16:27:43 +00:00
|
|
|
fi
|
|
|
|
|
2007-04-06 21:13:35 +00:00
|
|
|
# create BEOS:APP_SIG index -- needed to launch apps via signature
|
|
|
|
if [ ! $updateOnly ]; then
|
|
|
|
$mkindex BEOS:APP_SIG
|
|
|
|
fi
|
2005-10-29 16:27:43 +00:00
|
|
|
|
|
|
|
echo "Populating image ..."
|
|
|
|
while [ $# -gt 0 ]; do
|
|
|
|
. $1
|
|
|
|
shift
|
|
|
|
done
|
|
|
|
|
|
|
|
|
|
|
|
# install MIME database
|
|
|
|
# TODO: It should be possible to do that in the build system too.
|
2007-04-06 21:13:35 +00:00
|
|
|
|
|
|
|
if [ ! $updateOnly ]; then
|
|
|
|
mimeDBSource=$sourceDir/src/data/beos_mime
|
|
|
|
mimeDBDest=${tPrefix}home/config/settings/beos_mime
|
|
|
|
|
|
|
|
echo "Deleting old MIME database ..."
|
|
|
|
|
|
|
|
$rm -rf $mimeDBDest
|
|
|
|
$mkdir -p $mimeDBDest
|
|
|
|
mkdir -p $tmpDir
|
|
|
|
mimeTmpDir=$tmpDir/mime
|
|
|
|
mimeTmpIndex=0
|
|
|
|
|
|
|
|
# create tmp dir for the MIME conversion stuff
|
|
|
|
mkdir -p $mimeTmpDir
|
|
|
|
|
|
|
|
echo "Installing MIME database ..."
|
|
|
|
|
|
|
|
for inSuperFile in $mimeDBSource/*.super; do
|
|
|
|
superType=$(basename $inSuperFile .super)
|
|
|
|
outSuperDir=$mimeDBDest/$superType
|
|
|
|
|
|
|
|
# compile rdef to rsrc file and the rsrc file to attributes
|
|
|
|
mimeTmpIndex=$(($mimeTmpIndex + 1))
|
|
|
|
tmpFile=$mimeTmpDir/mimedb$$_${mimeTmpIndex}.rsrc
|
|
|
|
tmpFile2=$mimeTmpDir/mimedb$$_${mimeTmpIndex}.mime
|
|
|
|
$rc -o $tmpFile $inSuperFile
|
|
|
|
mkdir -p $tmpFile2
|
|
|
|
$resattr -O -o $tmpFile2 $tmpFile
|
|
|
|
$cp -r ${sPrefix}$tmpFile2 $outSuperDir
|
|
|
|
|
|
|
|
# iterate through the sub types
|
|
|
|
for inSubFile in $mimeDBSource/$superType/*; do
|
|
|
|
# check, if the type exists
|
|
|
|
if test -f $inSubFile && grep META:TYPE $inSubFile > /dev/null 2>&1 ; then
|
|
|
|
subType=$(basename $inSubFile)
|
|
|
|
outSubFile=$outSuperDir/$subType
|
|
|
|
|
|
|
|
# compile rdef to rsrc file and the rsrc file to attributes
|
|
|
|
mimeTmpIndex=$(($mimeTmpIndex + 1))
|
|
|
|
tmpFile=$mimeTmpDir/mimedb$$_${mimeTmpIndex}.rsrc
|
|
|
|
tmpFile2=$mimeTmpDir/mimedb$$_${mimeTmpIndex}.mime
|
|
|
|
$rc -o $tmpFile $inSubFile
|
|
|
|
$resattr -O -o $tmpFile2 $tmpFile
|
|
|
|
$cp ${sPrefix}$tmpFile2 $outSubFile
|
|
|
|
fi
|
|
|
|
done
|
2005-10-29 16:27:43 +00:00
|
|
|
done
|
|
|
|
|
2007-04-06 21:13:35 +00:00
|
|
|
# cleanup tmp dir
|
* 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 -rf $mimeTmpDir
|
2007-04-06 21:13:35 +00:00
|
|
|
fi # ! updateOnly
|
2005-10-29 16:27:43 +00:00
|
|
|
|
2007-03-24 23:34:28 +00:00
|
|
|
|
2005-10-29 16:27:43 +00:00
|
|
|
# unmount
|
|
|
|
if [ $isImage ]; then
|
|
|
|
echo "Unmounting ..."
|
|
|
|
$fsShellCommand sync
|
|
|
|
$fsShellCommand quit
|
|
|
|
fi
|