X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=build.sh;h=f1a0657d2af11971ff730fa7757092c7e1c90371;hb=b4f19098a0c1ffdcb0ac900f068ecf07eab4cb7f;hp=de0d5ff9e5556c8bd278ef92e68edb993d9cded9;hpb=d932bb545864493f5685319ec77b3d2d02e2ac6e;p=sliceimage.git diff --git a/build.sh b/build.sh index de0d5ff..f1a0657 100755 --- a/build.sh +++ b/build.sh @@ -37,6 +37,10 @@ pl_process_fedora_options $@ shiftcount=$? shift $shiftcount +# pldistro expected as $1 - defaults to planetlab +pldistro=planetlab +[ -n "$@" ] && pldistro=$1 + # Do not tolerate errors set -e @@ -52,24 +56,26 @@ vrefname=default vref=${vrefdir}/${vrefname} install -d -m 755 ${vref} -# "Parse" out the packages and groups for mkfedora -lst="vserver-reference.lst" -options="$(pl_getPackagesOptions $lst) $(pl_getGroupsOptions $lst)" +# locate the packages and groups file +pkgsfile=$(pl_locateDistroFile ../build/ ${pldistro} vserver.pkgs) -# Populate a minimal /dev in the reference image -pl_makedevs ${vref} +# Some of the PlanetLab RPMs attempt to (re)start themselves in %post, +# unless the installation is running inside the BootCD environment. We +# would like to pretend that we are. +export PL_BOOTCD=1 # Populate image with vserver-reference packages -pl_setup_chroot ${vref} ${options} -k +pl_root_setup_chroot ${vref} -k -f $pkgsfile -for systemvserver in reference-vservers/*.lst ; do - NAME=$(basename $systemvserver .lst) +systemvserver_count=$(ls ../build/config.${pldistro}/vserver-*.pkgs 2> /dev/null | wc -l) +[ $systemvserver_count -gt 0 ] && for systemvserver in $(ls ../build/config.${pldistro}/vserver-*.pkgs) ; do + NAME=$(basename $systemvserver .pkgs | sed -e s,vserver-,,) echo "--------START BUILDING system vserver ${NAME}: $(date)" # "Parse" out the packages and groups for yum - systempackages=$(pl_getPackages $systemvserver) - systemgroups=$(pl_getGroups $systemvserver) + systempackages=$(pl_getPackages ${pl_DISTRO_NAME} $systemvserver) + systemgroups=$(pl_getGroups ${pl_DISTRO_NAME} $systemvserver) vdir=${vstubdir}/${NAME} rm -rf ${vdir}/*