X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=vserver-reference.init;fp=vserver-reference.init;h=a9b7e4f532a063870b89461198bdff34a0d4efb9;hb=90ed554d985b8d2de59024d29024fc78b4482346;hp=56c4de5ead1aff86b156abcf7bfad555817adcd0;hpb=5a949b31060abe2a1cc2d0437dced8dbb01f1026;p=vserver-reference.git diff --git a/vserver-reference.init b/vserver-reference.init index 56c4de5..a9b7e4f 100755 --- a/vserver-reference.init +++ b/vserver-reference.init @@ -56,9 +56,8 @@ chmod 0000 "$__DEFAULT_VSERVERDIR" setattr --barrier "$__DEFAULT_VSERVERDIR" # Build reference images for system slices -# XXX Use Stork? -for lst in "$__DEFAULT_VSERVERDIR/system-packages/"*.lst ; do - NAME=$(basename $lst .lst) +for systemvserver in "$__DEFAULT_VSERVERDIR/.vstub/"*.cloned ; do + NAME=$(basename $systemvserver .cloned) # Copy base reference image if [ ! -d "$__DEFAULT_VSERVERDIR/.vref/$NAME" ] ; then @@ -68,15 +67,17 @@ for lst in "$__DEFAULT_VSERVERDIR/system-packages/"*.lst ; do mkdir -p "$__DEFAULT_VSERVERDIR/.vtmp" TMP=$(mktemp -d "$__DEFAULT_VSERVERDIR/.vtmp/$NAME.XXXXXX") mkdir -p "$__DEFAULT_VSERVERDIR/.vref" - "$__PKGLIBDIR/vbuild" "$__DEFAULT_VSERVERDIR/.vref/default" "$TMP" + + # build the systemvserver from the one it was originally cloned from + TYPE=$(cat $systemvserver) + REF="$__DEFAULT_VSERVERDIR/.vref/$TYPE" + "$_VCLONE" "$REF"/ "$TMP"/ RETVAL=$? - # Install/update additional packages + # merge the stub with the reference to get the system slice if [ $RETVAL -eq 0 ] ; then - pushd "$__DEFAULT_VSERVERDIR/system-packages" >/dev/null - xargs rpm --root "$TMP" --install < "$NAME.lst" + rsync -a "$__DEFAULT_VSERVERDIR/.vstub/$NAME"/ "$TMP"/ RETVAL=$? - popd >/dev/null fi # Clean RPM state