--- /dev/null
+#
+# hdw-linux Config script
+#
+# author: hackbard
+#
+# script initializing environment
+#
+
+hdw_status=""
+
+while [ "$1" ] ; do
+ case "$1" in
+ -stage) hdw_status="$2" ; shift 2 ;;
+ *) echo
+ echo "Usage:"
+ echo
+ echo " ./scripts/Config -stage <stagelevel>"
+ echo ;;
+ esac
+done
+
+if [ -z "$hdw_status" ]; then
+ echo "something went wrong. stage needs to be specified."
+ exit 1
+fi
+
+# execute Config file & create symlink to doc/README + doc/BUILD
+if [ -f ./Config ] ; then
+ hdw_home_dir=`pwd`
+ echo "setting hdw_home_dir to $hdw_home_dir"
+ echo "reading ./Config file"
+ . ./Config
+ [ ! -s ./README ] && ln -s ./doc/README .
+ [ ! -s ./BUILD ] && ln -s ./doc/BUILD .
+ [ ! -s ./INSTALL ] && ln -s ./doc/INSTALL .
+ [ ! -s ./License ] && ln -s ./doc/License .
+else
+ echo "./Config file not found. are you in correct directory?"
+ exit 1
+fi
+
+# define the stage 0/1 prefix to use
+# default "static", though no static linking is done anymore in stage1
+if [ -z "$hdw_stage1_prefix" ] ; then
+ s1_prefix="static" # default
+else
+ s1_prefix=$hdw_stage1_prefix
+fi
+
+# lets see what root is:
+[ "$hdw_status" = "2" -o "$hdw_status" = "3" ] && root=""
+if [ "$hdw_status" -lt 2 -o "$hdw_crossbuild" != "0" ] ; then
+ if [ -z "$hdw_build_dir" ] ; then
+ echo "please set hdw_build_dir in ./Config!"
+ exit 1
+ elif [ ! -d $hdw_build_dir ] ; then
+ echo "please set _existing_ hdw_build_dir in ./Config"
+ exit 1
+ else
+ echo "hdw_build_dir variable set to $hdw_build_dir"
+ root="$hdw_build_dir"
+ fi
+fi
+
+# setting up general environment, now that we know $root
+set +h
+umask 022
+export LC_ALL=POSIX
+[ "$hdw_status" -lt "2" ] && export PATH="$root/${s1_prefix}/bin:$PATH"
+
+# let's do optimization and care for crossbuilds
+if [ ! -z "`uname --version | grep sh-utils`" ] ; then
+ hdw_arch_build="`uname -m -p | tr " " -`-linux-gnu"
+else
+ hdw_arch_build="`uname -m`-unknown-linux-gnu"
+fi
+case "$hdw_arch" in
+ ia32) if [ -z "$hdw_arch_opt" ] ; then
+ hdw_arch_target="i386-pc-linux-gnu"
+ elif [ ! -z "$hdw_arch_opt" ] ; then
+ hdw_arch_target="${hdw_arch_opt}-pc-linux-gnu"
+ hdw_cflags="-march=${hdw_arch_opt}"
+ fi
+ hdw_arch_build=${hdw_arch_build//unknown/pc} ;;
+ sparc*) if [ -z "$hdw_arch_opt" ] ; then
+ hdw_arch_target="$hdw_arch-unknown-linux-gnu"
+ else
+ # hack this! :)
+ echo "pls hack sparc* opt. options and submit :)"
+ echo "no optimization used!"
+ hdw_arch_target="$hdw_arch-unknown-linux-gnu"
+ hdw_cflags="-march={hdw_arch_opt}"
+ fi ;;
+ ppc)
+ hdw_arch_target="powerpc-unknown-linux-gnu"
+ [ ! -z "$hdw_arch_opt" ] && hdw_cflags="-march=${hdw_arch_opt}"
+ hdw_arch_build=${hdw_arch_build//ppc/powerpc} ;;
+ *) echo "not supported yet"
+ echo "please choose a valid optimization and build platform."
+ exit 1 ;;
+esac
+# -O flag
+[ ! -z "$hdw_opt" ] && hdw_cflags="-O${hdw_opt} $hdw_cflags"
+
+# build tools to use
+hdw_arch_prefix=""
+if [ "$hdw_crossbuild" != "0" ] ; then
+ hdw_arch_prefix="$hdw_arch_target-"
+ if [ "$hdw_real_build" ] ; then
+ if [ "$hdw_arch" = "ia32" ] ; then
+ hdw_arch_build=${hdw_arch_build//$hdw_arch_opt/$hdw_real_build}
+ else
+ hdw_arch_build=${hdw_arch_build//$hdw_arch/$hdw_real_build}
+ fi
+ fi
+fi
+# test: actually we always use the compilers for target
+# hdw_arch_prefix="$hdw_arch_target-"
+
+# resume ...
+echo "hdw_arch_target variable set to $hdw_arch_target"
+echo "hdw_arch_build variable set to $hdw_arch_build"
+echo "hdw_cflags variable set to $hdw_cflags"
+[ "$hdw_status" = "1" ] && echo "hdw_stage1_prefix set to '$s1_prefix'"
+
+# lets see what we are going to build
+if [ -z $hdw_target ] ; then
+ echo "please set hdw_target in ./Config!"
+ exit 1
+elif [ ! -d ./targets/$hdw_target ] ; then
+ echo "please set _existing_ hdw_target in ./Config!"
+ exit 1
+else
+ echo "hdw_target variable set to $hdw_target"
+fi
+
--- /dev/null
+#/bin/sh
+#
+# hdw - linux ./scripts/Create-Binary
+#
+# this script is used to create the binary packages
+#
+
+package=""
+tar_name=""
+my_root=""
+
+while [ "$1" ] ; do
+ case "$1" in
+ all) package=all ; shift 1 ;;
+ -package) package=$2 ; shift 2 ;;
+ -tar-name) tar_name=$2 ; shift 2 ;;
+ -root) my_root=$2 ; shift 2 ;;
+ *)
+ echo "usage: $0 -package <package> -tar-name <tarname> -root <root>"
+ exit 1 ;;
+ esac
+done
+
+# do we run?
+if [ -z "$package" ] ; then
+ echo "no package specified"
+ exit 1
+fi
+
+# how to call the packaged tar file (no .tar.bz2 ending!)
+[ -z "$tar_name" ] && tar_name="$package"
+
+# get Config & set hdw_home_dir
+. ./Config && hdw_home_dir=`pwd`
+
+# which root to use?
+[ ! -z "$my_root" ] && hdw_build_dir="$my_root"
+
+# create binary directory
+if [ ! -z "$hdw_arch_opt" ]; then
+ bin_dir=${hdw_arch}-${hdw_arch_opt}
+else
+ bin_dir=${hdw_arch}-generic
+fi
+mkdir -p binaries/$bin_dir
+
+# single package
+if [ "$package" != "all" ] ; then
+if [ -d ./binaries/$bin_dir/${package} ] ; then
+ echo "$package binary already exists, skipped"
+ echo "(remove ./binaries/$bin_dir/$package to recreate it)"
+ exit 0
+else
+ # does it exist?
+ if [ ! -f $hdw_build_dir/var/adm/flists/$package ] ; then
+ echo "package not build (moved flist file?)"
+ exit 0
+ else
+ echo "creating binary tarball of $package"
+ mkdir -p $hdw_home_dir/binaries/$bin_dir/$package &&
+ cd $hdw_build_dir &&
+ # which files do we need? - are we packaging linux?
+ if [ "$package" = "linux" ] ; then
+ fl_file="var/adm/flists/$package*"
+ else
+ fl_file="var/adm/flists/$package"
+ fi
+ cat $fl_file | awk '{ print $2 }' | \
+ tar --no-recursion --use-compress-program=bzip2 \
+ -cf $hdw_home_dir/binaries/$bin_dir/$package/$tar_name.tar.bz2 \
+ -T -
+ cp $hdw_build_dir/var/adm/flists/$package \
+ $hdw_home_dir/binaries/$bin_dir/$package
+ cd $hdw_home_dir
+ echo "done"
+ fi
+fi
+
+elif [ "$package" = "all" ] ; then
+
+((counter=1))
+for pkg in `ls -A $hdw_build_dir/var/adm/flists | grep -v '.stage1'`; do
+ ./scripts/Create-Binary -package $pkg -root $hdw_build_dir
+ ((counter+=1))
+done
+
+# add 00-dirtree, build in stage1
+./scripts/Create-Binary -package 00-dirtree.stage1 -tar-name 00-dirtree
+((counter+=1))
+
+echo "created $counter binaries, done"
+fi