wok-next rev 3757

mirror-tools/mkpkgiso: fix sort weights
author Pascal Bellard <pascal.bellard@slitaz.org>
date Fri Jul 24 11:41:10 2009 +0200 (2009-07-24)
parents f060e21dde4c
children ca7105738738
files mirror-tools/stuff/usr/bin/mkpkgiso
line diff
     1.1 --- a/mirror-tools/stuff/usr/bin/mkpkgiso	Thu Jul 23 15:51:49 2009 +0000
     1.2 +++ b/mirror-tools/stuff/usr/bin/mkpkgiso	Fri Jul 24 11:41:10 2009 +0200
     1.3 @@ -8,7 +8,8 @@
     1.4  VERSION=0.5
     1.5  
     1.6  ROOT=/home/slitaz/iso
     1.7 -TEMP_DIR=${ROOT}/_iso.$$
     1.8 +SORT_DIR=_iso.$$
     1.9 +TEMP_DIR=${ROOT}/$SORT_DIR
    1.10  SORT_FILE=${ROOT}/_sort.$$
    1.11  PKG_VER=$1
    1.12  shift
    1.13 @@ -54,6 +55,15 @@
    1.14      echo -e "\\033[0;39m ]"
    1.15  }
    1.16  
    1.17 +add_sort()
    1.18 +{
    1.19 +	if true; then
    1.20 +		echo "$1 $2"
    1.21 +	else
    1.22 +		( cd $ROOT ; find $1 | awk "{ printf \"%s $2\\n\",\$0 }" )
    1.23 +	fi
    1.24 +}
    1.25 +
    1.26  # Create temp directory
    1.27  mkdir -p $TEMP_DIR/packages/$PKG_VER
    1.28  
    1.29 @@ -128,15 +138,18 @@
    1.30  
    1.31  status
    1.32  cat > $SORT_FILE <<EOT
    1.33 -install.sh 8
    1.34 -README 8
    1.35 -index.html 8
    1.36 -md5sum 8
    1.37 -style.css 8
    1.38 -images/header.png 8
    1.39 +$SORT_DIR/install.sh -4000
    1.40 +$SORT_DIR/README -4000
    1.41 +$SORT_DIR/index.html -4000
    1.42 +$SORT_DIR/md5sum -4000
    1.43 +$SORT_DIR/style.css -4000
    1.44 +$SORT_DIR/images/header.png -4000
    1.45 +$SORT_DIR/boot/bzImage 2
    1.46 +$SORT_DIR/boot/rootfs.gz 1
    1.47 +$SORT_DIR/packages -9000
    1.48  EOT
    1.49 -( cd $TEMP_DIR ; ls packages/*/packages* packages/*/files.list.lzma ) | \
    1.50 -		awk '{ printf "%s 4\n",$0 }' >> $SORT_FILE
    1.51 +( cd $ROOT; ls $SORT_DIR/packages/*/packages* $SORT_DIR/packages/*/files.list.lzma ) | \
    1.52 +		awk '{ printf "%s -7000\n",$0 }' >> $SORT_FILE
    1.53  chmod 755  $TEMP_DIR/install.sh
    1.54  
    1.55  case " $OPTIONS " in
    1.56 @@ -185,8 +198,7 @@
    1.57  echo "=> Wok (cooking) is in \$DIR/wok"
    1.58  EOF
    1.59  	if get_from_hg wok "wok (cooking)"; then
    1.60 -		( cd $TEMP_DIR ; find wok -not -type d ) | \
    1.61 -			awk '{ printf "%s 2\n",$0 }' >> $SORT_FILE
    1.62 +		add_sort $SORT_DIR/wok -8000 >> $SORT_FILE
    1.63  	fi;;
    1.64  --wok-stable)
    1.65  	cat >>$TEMP_DIR/install.sh<<EOF
    1.66 @@ -194,13 +206,11 @@
    1.67  EOF
    1.68  	if get_from_hg wok-stable "wok (stable)"; then
    1.69  		mv $TEMP_DIR/wok-stable $TEMP_DIR/wok
    1.70 -		( cd $TEMP_DIR ; find wok -not -type d ) | \
    1.71 -			awk '{ printf "%s 2\n",$0 }' >> $SORT_FILE
    1.72 +		add_sort $SORT_DIR/wok -8000 >> $SORT_FILE
    1.73  	fi;;
    1.74  --website)
    1.75  	if get_from_hg website "web site"; then
    1.76 -		( cd $TEMP_DIR ; find website -not -type d ) | \
    1.77 -			awk '{ printf "%s 5\n",$0 }' >> $SORT_FILE
    1.78 +		add_sort $SORT_DIR/website -6000 >> $SORT_FILE
    1.79  		cat >>$TEMP_DIR/install.sh<<EOF
    1.80  [ -d /var/www ] || mkdir -p /var/www
    1.81  ln -s \$DIR/website /var/www
    1.82 @@ -238,9 +248,13 @@
    1.83  			mkdir -p "$(dirname $TEMP_DIR/$file)"
    1.84  		isoinfo -R -x "$file" -i $iso > "$TEMP_DIR/$file"
    1.85  	done
    1.86 +	if [ -f "$(echo $TEMP_DIR/boot/vmlinuz*)" ]; then
    1.87 +		rm -f $TEMP_DIR/boot/bzImage
    1.88 +		ln $TEMP_DIR/boot/vmlinuz* $TEMP_DIR/boot/bzImage
    1.89 +    fi
    1.90  	status
    1.91 -	BOOT_OPT="-b boot/isolinux/isolinux.bin -c boot/isolinux/boot.cat \
    1.92 --no-emul-boot -boot-load-size 4 -boot-info-table -sort $SORT_FILE"
    1.93 +	BOOT_OPT="-sort $SORT_FILE -b boot/isolinux/isolinux.bin \
    1.94 +-c boot/isolinux/boot.cat  -no-emul-boot -boot-load-size 4 -boot-info-table"
    1.95      case " $OPTIONS " in
    1.96  	*\ --auto-install\ *)
    1.97      	echo -n "Enable auto install"
    1.98 @@ -257,7 +271,7 @@
    1.99      	echo -n "Enable loram autodetection"
   1.100  		cp $PXE_DIR/ifmem.c32 "$TEMP_DIR/boot/isolinux"
   1.101  		isoinfo -R -x "/usr.sqfs" -i $isoloram > "$TEMP_DIR/usr.sqfs"
   1.102 -		echo 'usr.sqfs 8' >> $SORT_FILE
   1.103 +		add_sort $SORT_DIR/usr.sqfs -5000 >> $SORT_FILE
   1.104  		isoinfo -R -x "/boot/rootfs.gz" -i $isoloram > \
   1.105  			"$TEMP_DIR/boot/loram.gz"
   1.106  		sed -i -e 's|kernel /boot/bzImage|kernel /boot/isolinux/ifmem.c32\n\tappend 160768 core loram\n|' \
   1.107 @@ -266,8 +280,7 @@
   1.108  		status
   1.109  		;;
   1.110  	esac
   1.111 -	( cd $TEMP_DIR ; find boot -not -type d ) | \
   1.112 -		awk '{ printf "%s 9\n",$0 }' >> $SORT_FILE
   1.113 +	add_sort $SORT_DIR/boot 0 >> $SORT_FILE
   1.114  	;;
   1.115  *\ --webboot\ *)
   1.116  	if extract_boot gpxe; then
   1.117 @@ -276,15 +289,14 @@
   1.118  		isoinfo -x "/BOOT/ISOLINUX/ISOLINUX.BIN;1" -i $iso > \
   1.119  			$TEMP_DIR/boot/isolinux/isolinux.bin
   1.120  		mv $TEMP_DIR/boot/gpxe $TEMP_DIR/boot/isolinux
   1.121 -		( cd $TEMP_DIR ; find boot -not -type d ) | \
   1.122 -			awk '{ printf "%s 9\n",$0 }' >> $SORT_FILE
   1.123 +		add_sort $SORT_DIR/boot 0 >> $SORT_FILE
   1.124  		cat > $TEMP_DIR/boot/isolinux/isolinux.cfg <<EOT
   1.125  default gpxe
   1.126  append http://mirror.slitaz.org/pxe/pxelinux.0
   1.127  EOT
   1.128  		status
   1.129 -		BOOT_OPT="-b boot/isolinux/isolinux.bin -c boot/isolinux/boot.cat \
   1.130 --no-emul-boot -boot-load-size 4 -boot-info-table -sort $SORT_FILE"
   1.131 +		BOOT_OPT="-sort $SORT_FILE -b boot/isolinux/isolinux.bin \
   1.132 +-c boot/isolinux/boot.cat -no-emul-boot -boot-load-size 4 -boot-info-table"
   1.133  	fi
   1.134  	;;
   1.135  esac
   1.136 @@ -294,6 +306,8 @@
   1.137  		    tail -1 | awk '{ print $1 }') used by boot."
   1.138  fi
   1.139  
   1.140 +sort -r -k 2 $SORT_FILE > $SORT_FILE.$$
   1.141 +mv $SORT_FILE.$$ $SORT_FILE
   1.142  case " $OPTIONS " in
   1.143  *\ --dry-run\ *)
   1.144  	echo "Please check and remove $TEMP_DIR and $SORT_FILE"