wok annotate slitaz-dev-tools/stuff/tazdev @ rev 4902
Typo in tazbb
author | Pascal Bellard <pascal.bellard@slitaz.org> |
---|---|
date | Thu Feb 11 17:28:21 2010 +0100 (2010-02-11) |
parents | 031f6e973842 |
children | 8399ea7a8262 |
rev | line source |
---|---|
pankso@3440 | 1 #!/bin/sh |
pankso@3440 | 2 # Tazdev - SliTaz developers and build host tool. |
pankso@3440 | 3 # System wide config file: /etc/slitaz/tazdev.conf |
pankso@3440 | 4 # |
pankso@3440 | 5 # (c) 2009 SliTaz GNU/Linux - GNU gpl v3 |
pankso@3440 | 6 # |
pankso@3440 | 7 # Authors : Christophe Lincoln (Pankso) <pankso@slitaz.org> |
pankso@3440 | 8 # |
pankso@3440 | 9 |
pankso@3440 | 10 if [ -f /etc/slitaz/tazdev.conf ]; then |
pankso@3440 | 11 . /etc/slitaz/tazdev.conf |
pankso@3444 | 12 if [ -f $PWD/tazdev.conf ]; then |
pankso@3444 | 13 . $PWD/tazdev.conf |
pankso@3444 | 14 fi |
pankso@3440 | 15 else |
pankso@3440 | 16 echo -e "\nNo config file found in /etc/slitaz or the current dir...\n" |
pankso@3440 | 17 exit 0 |
pankso@3440 | 18 fi |
pankso@3440 | 19 |
pankso@3440 | 20 usage() |
pankso@3440 | 21 { |
pankso@3440 | 22 echo -e "\nSliTaz developers and build host tool\n |
pankso@3499 | 23 \033[1mUsage: \033[0m `basename $0` [command] [user] [stable|cooking|path] |
pankso@3440 | 24 \033[1mCommands: \033[0m\n |
pankso@3500 | 25 usage Print this short usage and command list. |
paul@3526 | 26 projects-stats Display statistics about your projects (-ps). |
pankso@3500 | 27 cmplog Log 'tazwok cmp' result (or use tazbb). |
pankso@3500 | 28 update-wok Update Hg wok and copy it to the chroot wok. |
pankso@3500 | 29 update-www Update SliTaz Website repo from Hg. |
pankso@3500 | 30 chroot Mount virtual fs if needed and chroot into the build env. |
pankso@3500 | 31 gen-chroot Generate a chroot using the last cooking base rootfs. |
paul@3526 | 32 clean-chroot Clean a chroot environment (skip root/ and home/). |
pascal@4717 | 33 purge Remove obsolate packages and obsolate source tarballs. |
pascal@4719 | 34 dry-purge Show obsolate packages and obsolate source tarballs. |
pankso@3500 | 35 push Upload new packages to the main mirror (-p). |
pankso@3500 | 36 dry-push Show what will be uploaded to the mirror. Does nothing (-dp). |
pankso@3500 | 37 pull Download new packages from the main mirror. |
pankso@3500 | 38 dry-pull Show what will be downloaded from the mirror. Does nothing.\n" |
pankso@3440 | 39 } |
pankso@3440 | 40 |
pankso@3440 | 41 # Exit if user is not root. |
pankso@3440 | 42 check_root() |
pankso@3440 | 43 { |
pankso@3440 | 44 if test $(id -u) != 0 ; then |
pankso@3440 | 45 echo -e "\nThis program requires being run as root.\n" |
pankso@3440 | 46 exit 0 |
pankso@3440 | 47 fi |
pankso@3440 | 48 } |
pankso@3440 | 49 |
pankso@3499 | 50 status() |
pankso@3499 | 51 { |
pankso@3499 | 52 local CHECK=$? |
pankso@3500 | 53 echo -en "\033[70G" |
pankso@3499 | 54 if [ $CHECK = 0 ]; then |
pankso@3500 | 55 echo "Done" |
pankso@3499 | 56 else |
pankso@3500 | 57 echo "Failed" |
pankso@3499 | 58 fi |
pankso@3499 | 59 return $CHECK |
pankso@3499 | 60 } |
pankso@3499 | 61 |
pankso@3499 | 62 get_version() |
pankso@3499 | 63 { |
pankso@3499 | 64 if [ "$2" = "stable" ]; then |
pankso@3499 | 65 VERSION=stable |
pankso@3522 | 66 SLITAZ=$STABLE |
pankso@3499 | 67 elif [ -n "$2" ]; then |
pankso@3522 | 68 # Undigest - custom ? |
pankso@3522 | 69 VERSION=$2 |
pankso@3522 | 70 SLITAZ=/home/slitaz/$2 |
pankso@3499 | 71 else |
pankso@3499 | 72 VERSION=cooking |
pankso@3522 | 73 SLITAZ=$COOKING |
pankso@3499 | 74 fi |
pankso@3522 | 75 ROOTFS=$SLITAZ/chroot |
pankso@3522 | 76 HG_WOK=$SLITAZ/wok |
pankso@3522 | 77 BUILD_WOK=$SLITAZ/chroot/home/slitaz/wok |
pankso@3499 | 78 } |
pankso@3499 | 79 |
pankso@3440 | 80 check_mirror() |
pankso@3440 | 81 { |
pankso@3440 | 82 # ping -c 1 $MIRROR |
pankso@3440 | 83 if [ -n "$2" ]; then |
pankso@3440 | 84 USER=$2 |
pankso@3440 | 85 else |
pankso@3605 | 86 USER=$USER |
pankso@3440 | 87 fi |
pankso@3605 | 88 if [ "$2" = "stable" ] || [ "$3" = "stable" ]; then |
pankso@3440 | 89 REMOTE_DIR=$MIRROR_DIR/stable/ |
pankso@3440 | 90 LOCAL_DIR=$STABLE/packages/ |
pankso@3440 | 91 else |
pankso@3440 | 92 REMOTE_DIR=$MIRROR_DIR/cooking/ |
pankso@3440 | 93 LOCAL_DIR=$COOKING/packages/ |
pankso@3522 | 94 fi |
pankso@3440 | 95 } |
pankso@3440 | 96 |
pankso@3522 | 97 # Mount virtual Kernel file systems and chroot but check that nobody |
pankso@3499 | 98 # else has done mounts |
pankso@3499 | 99 mount_chroot() |
pankso@3499 | 100 { |
pankso@3499 | 101 if [ ! -d $ROOTFS/proc/1 ]; then |
paul@3526 | 102 echo -n "Mounting virtual filesystems..." |
pankso@3499 | 103 mount -t proc proc $ROOTFS/proc |
pankso@3499 | 104 mount -t sysfs sysfs $ROOTFS/sys |
pankso@3499 | 105 mount -t devpts devpts $ROOTFS/dev/pts |
pankso@3499 | 106 mount -t tmpfs shm $ROOTFS/dev/shm |
pankso@3499 | 107 status |
pankso@3499 | 108 fi |
pankso@3499 | 109 } |
pankso@3499 | 110 |
pankso@3522 | 111 # Unmount virtual Kernel file systems on exit and ensure we are the last |
pankso@3499 | 112 # user before unmounting ! |
pankso@3499 | 113 umount_chroot() |
pankso@3499 | 114 { |
pankso@3499 | 115 # Not working. Buggy ps ? |
pankso@3499 | 116 #sleep 6 |
pankso@3499 | 117 ps=$(ps | grep `basename $0` | grep -v grep | wc -l) |
pankso@3499 | 118 if [ "$ps" == "1" ]; then |
paul@3526 | 119 echo -ne "\Unmounting virtual filesystems..." |
pankso@3499 | 120 umount $ROOTFS/dev/shm |
pankso@3499 | 121 umount $ROOTFS/dev/pts |
pankso@3499 | 122 umount $ROOTFS/sys |
pankso@3499 | 123 umount $ROOTFS/proc |
pankso@3499 | 124 status |
pankso@3499 | 125 else |
pankso@3499 | 126 echo -e "\nProcess: $ps\n" |
pankso@3499 | 127 ps | grep `basename $0` | grep -v grep |
paul@3526 | 128 echo -e "\nLeaving virtual filesystems unmounted (`pidof tazdev`)...\n" |
pankso@3499 | 129 fi |
pankso@3499 | 130 } |
pankso@3499 | 131 |
pankso@3499 | 132 # Get the last cooking base rootfs, extract and configure. |
pankso@3499 | 133 gen_new_chroot() |
pankso@3499 | 134 { |
pankso@3499 | 135 echo -e "\nGenerating new chroot in : $ROOTFS" |
pankso@3499 | 136 echo "================================================================================" |
pankso@3499 | 137 mkdir -p $ROOTFS && cd $ROOTFS |
pankso@3499 | 138 wget $DL_URL/boot/cooking/rootfs-base.gz |
pankso@3499 | 139 echo -n "Extracting the rootfs..." |
pankso@3499 | 140 lzma d rootfs-base.gz -so | cpio -id |
pankso@3499 | 141 rm rootfs-base.gz |
pankso@3499 | 142 echo -n "Creating resolv.conf..." |
pankso@3499 | 143 cat /etc/resolv.conf > etc/resolv.conf |
pankso@3499 | 144 status |
pankso@3499 | 145 echo "================================================================================" |
pankso@3499 | 146 echo -e "Ready to chroot. Use 'tazdev chroot [version|path]'" |
pankso@3499 | 147 echo -e "Example: tazdev chroot $ROOTFS\n" |
pankso@3499 | 148 } |
pankso@3499 | 149 |
pascal@4717 | 150 # Remove obsolate slitaz packages |
pascal@4717 | 151 purge_packages() |
pascal@4717 | 152 { |
pascal@4719 | 153 arg=$1 |
pascal@4717 | 154 TMP_FILE=/tmp/tazdev.$$ |
pascal@4717 | 155 ls $BUILD_WOK | while read pkg; do |
pascal@4717 | 156 [ -f $BUILD_WOK/$pkg/taz/*/receipt ] || continue |
pascal@4717 | 157 EXTRAVERSION="" |
pascal@4717 | 158 . $BUILD_WOK/$pkg/taz/*/receipt |
pascal@4717 | 159 echo $PACKAGE-$VERSION$EXTRAVERSION.tazpkg |
pascal@4717 | 160 done > $TMP_FILE |
pascal@4717 | 161 ls $SLITAZ/chroot/home/slitaz/packages | while read pkg; do |
pascal@4717 | 162 case "$pkg" in |
pascal@4717 | 163 *.tazpkg) |
pascal@4717 | 164 grep -q ^$pkg$ $TMP_FILE && continue |
pascal@4717 | 165 echo Remove $pkg |
pascal@4719 | 166 [ "$arg" == "purge" ] && |
pascal@4717 | 167 rm -f $SLITAZ/chroot/home/slitaz/packages/$pkg ;; |
pascal@4717 | 168 esac |
pascal@4717 | 169 done |
pascal@4717 | 170 rm -f $TMP_FILE |
pascal@4717 | 171 } |
pascal@4717 | 172 |
pascal@4717 | 173 # Remove obsolate source tarballs |
pascal@4717 | 174 purge_sources() |
pascal@4717 | 175 { |
pascal@4719 | 176 arg=$1 |
pascal@4717 | 177 TMP_FILE=/tmp/tazdev.$$ |
pascal@4717 | 178 ls $BUILD_WOK | while read pkg; do |
pascal@4717 | 179 [ -f $BUILD_WOK/$pkg/taz/*/receipt ] || continue |
pascal@4717 | 180 TARBALL="" |
pascal@4717 | 181 . $BUILD_WOK/$pkg/taz/*/receipt |
pascal@4717 | 182 [ -n "$TARBALL" ] && echo $TARBALL |
pascal@4717 | 183 done > $TMP_FILE |
pascal@4717 | 184 ls $SLITAZ/chroot/home/slitaz/src | while read pkg; do |
pascal@4717 | 185 grep -q ^$pkg$ $TMP_FILE && continue |
pascal@4717 | 186 echo Remove $pkg |
pascal@4719 | 187 [ "$arg" == "purge" ] && |
pascal@4717 | 188 rm -f $SLITAZ/chroot/home/slitaz/src/$pkg |
pascal@4717 | 189 done |
pascal@4717 | 190 rm -f $TMP_FILE |
pascal@4717 | 191 } |
pascal@4717 | 192 |
pankso@3440 | 193 case "$1" in |
pankso@3440 | 194 cmplog) |
pankso@3440 | 195 # Log 'tazwok cmp' for the web interface (can be used via a cron job). |
pankso@3440 | 196 check_root |
pankso@3444 | 197 echo -e "Starting 'tazwok cmp' (can be long)...\n" |
pankso@3440 | 198 tazwok cmp | grep ^[A-Z] | tee $CMP_LOG |
pankso@3440 | 199 echo "Date: `date`" >> $CMP_LOG ;; |
pankso@3500 | 200 '-ps'|projects-stats) |
pankso@3500 | 201 echo -e "\nStatistics for: $PROJECTS\n" |
pankso@3500 | 202 echo -n "Project" && echo -ne "\033[24G Size" && echo -ne "\033[38G Revision" |
pankso@3500 | 203 echo -ne "\033[48G Version" && echo -e "\033[64G Files" |
pankso@3500 | 204 echo "================================================================================" |
pankso@3500 | 205 cd $PROJECTS |
pankso@3500 | 206 for proj in * |
pankso@3500 | 207 do |
pankso@3500 | 208 rev="" |
pankso@3500 | 209 echo -n "$proj" |
pankso@3500 | 210 size=`du -sh $proj | awk '{ print $1 }'` |
pankso@3500 | 211 echo -ne "\033[24G $size" |
pankso@3500 | 212 if [ -d $proj/.hg ]; then |
pankso@3500 | 213 cd $proj |
pankso@3500 | 214 rev=`hg head --template '{rev}\n'` |
pankso@3500 | 215 vers=`hg tags | head -n 2 | tail -n 1 | cut -d " " -f 1` |
pankso@3500 | 216 echo -ne "\033[38G $rev" |
pankso@3500 | 217 echo -ne "\033[48G $vers" && cd .. |
pankso@3500 | 218 fi |
pankso@3500 | 219 files=`find $proj -type f | wc -l` |
pankso@3500 | 220 echo -e "\033[64G $files" |
pankso@3500 | 221 done |
pankso@3500 | 222 echo "================================================================================" |
pankso@3500 | 223 echo "" ;; |
pankso@3440 | 224 update-wok) |
pankso@3499 | 225 # Update the Hg wok and copy it to the chroot env. Hg wok is |
pankso@3440 | 226 # copied to the chroot wok to avoid messing with build result |
paul@3455 | 227 # file and so we can also modify receipt directly without affecting |
pankso@3499 | 228 # the Hg wok. |
pankso@3440 | 229 check_root |
pascal@3731 | 230 get_version $@ |
pankso@3444 | 231 echo "" |
pankso@3447 | 232 echo "Hg wok : $HG_WOK" |
pankso@3447 | 233 echo "Build wok : $BUILD_WOK" |
pankso@3440 | 234 cd $HG_WOK |
pankso@3440 | 235 hg pull && hg update |
pankso@3447 | 236 echo -n "Copying Hg wok to the build wok... " |
pankso@3447 | 237 cp -a $HG_WOK/* $BUILD_WOK |
pankso@3499 | 238 cp -a $HG_WOK/.hg $BUILD_WOK |
pankso@3499 | 239 status && echo "" ;; |
pankso@3441 | 240 update-www) |
pankso@3441 | 241 # Update website from repo. |
pankso@3441 | 242 echo "" |
pankso@3441 | 243 cd $WEBSITE && hg pull && hg update |
pankso@3441 | 244 echo "" ;; |
pankso@3440 | 245 chroot) |
pankso@3522 | 246 # Chroot into a build env. Default to cooking configured in |
pankso@3440 | 247 # tazdev.conf |
pankso@3440 | 248 check_root |
pascal@3731 | 249 get_version $@ |
pankso@3499 | 250 mount_chroot |
pankso@3499 | 251 echo -e "\nChrooting in $ROOTFS...\n" |
pankso@3499 | 252 chroot $ROOTFS /bin/sh --login |
pankso@3499 | 253 umount_chroot |
pankso@3499 | 254 echo -e "Exiting $ROOTFS chroot environment...\n" ;; |
pankso@3499 | 255 gen-chroot) |
pankso@3499 | 256 check_root |
pascal@3731 | 257 get_version $@ |
pankso@3499 | 258 # Dont break another env. |
pankso@3499 | 259 if [ -d $ROOTFS/bin ]; then |
paul@3526 | 260 echo -e "\nA chroot environment already exists in : $ROOTFS\n" |
pankso@3499 | 261 exit 1 |
pankso@3499 | 262 fi |
pankso@3499 | 263 gen_new_chroot ;; |
pankso@3499 | 264 clean-chroot) |
pankso@3499 | 265 # Keep root/ and /home they may have a build wok, custom scripts, etc. |
pankso@3499 | 266 check_root |
pankso@3499 | 267 if [ -z "$2" ]; then |
pankso@3499 | 268 echo -e "\nPlease specify the path to the chroot environment to clean.\n" |
pankso@3499 | 269 exit 0 |
pankso@3440 | 270 else |
pankso@3499 | 271 ROOTFS=$2 |
pankso@3499 | 272 if [ ! -d "$ROOTFS" ]; then |
paul@3526 | 273 echo -e "\nWarning : $ROOTFS doesn't exist!\n" |
pankso@3499 | 274 exit 1 |
pankso@3499 | 275 fi |
pankso@3440 | 276 fi |
pankso@3499 | 277 if [ -d $ROOTFS/proc/1 ]; then |
pankso@3499 | 278 echo -e "\nWarning : $ROOTFS/proc mounted!\n" |
pankso@3499 | 279 exit 1 |
pankso@3440 | 280 fi |
pankso@3499 | 281 cd $ROOTFS || exit 1 |
pankso@3499 | 282 echo -e "\nCleaning chroot in: $ROOTFS" |
pankso@3499 | 283 echo "================================================================================" |
pankso@3499 | 284 for i in bin dev etc init lib media mnt proc sbin sys tmp usr var |
pankso@3499 | 285 do |
pankso@3499 | 286 echo -n "Removing: $i (`du -sh $i | awk '{ print $1 }'`)... " |
pankso@3499 | 287 rm -rf $i |
pankso@3499 | 288 status |
pankso@3499 | 289 done |
pankso@3499 | 290 echo "================================================================================" |
pankso@3499 | 291 echo "" ;; |
pankso@3500 | 292 '-p'|push) |
pankso@3502 | 293 check_mirror $@ |
pankso@3440 | 294 rsync -r -t -l -v -z --delete \ |
pankso@3499 | 295 $LOCAL_DIR -e ssh $USER@$MIRROR:$REMOTE_DIR ;; |
pankso@3500 | 296 '-dp'|dry-push) |
pankso@3502 | 297 check_mirror $@ |
pankso@3440 | 298 rsync -r -t -l -v -z --delete --dry-run \ |
pankso@3499 | 299 $LOCAL_DIR -e ssh $USER@$MIRROR:$REMOTE_DIR ;; |
pankso@3440 | 300 pull) |
pankso@3502 | 301 check_mirror $@ |
pankso@3440 | 302 rsync -r -t -l -v -z --delete \ |
pankso@3499 | 303 -e ssh $USER@$MIRROR:$REMOTE_DIR $LOCAL_DIR ;; |
pankso@3440 | 304 dry-pull) |
pankso@3502 | 305 check_mirror $@ |
pankso@3440 | 306 rsync -r -t -l -v -z --delete --dry-run \ |
pankso@3499 | 307 -e ssh $USER@$MIRROR:$REMOTE_DIR $LOCAL_DIR ;; |
pascal@4719 | 308 purge|dry-purge) |
pascal@4717 | 309 check_root |
pascal@4717 | 310 get_version $@ |
pascal@4719 | 311 purge_packages $1 |
pascal@4719 | 312 purge_sources $1 |
pascal@4717 | 313 ;; |
pankso@3440 | 314 usage|*) |
pankso@3440 | 315 usage ;; |
pankso@3440 | 316 esac |
pankso@3440 | 317 |
pankso@3440 | 318 exit 0 |