[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]

[or-cvs] r14642: Made the progress bar actually work in the USB copying scrip (incognito/trunk/root_overlay/usr/sbin)



Author: anonym
Date: 2008-05-16 16:21:58 -0400 (Fri, 16 May 2008)
New Revision: 14642

Modified:
   incognito/trunk/root_overlay/usr/sbin/create-usb
Log:
Made the progress bar actually work in the USB copying script.


Modified: incognito/trunk/root_overlay/usr/sbin/create-usb
===================================================================
--- incognito/trunk/root_overlay/usr/sbin/create-usb	2008-05-16 20:13:10 UTC (rev 14641)
+++ incognito/trunk/root_overlay/usr/sbin/create-usb	2008-05-16 20:21:58 UTC (rev 14642)
@@ -5,10 +5,10 @@
 #
 
 DEFAULT_WIDTH=80
-# declare OTHER_BLOCK to allow block devices besides USB
 
-# show an xdialog of available USB drives. the one which the user choses is partitioned into
-# a single big partition. USBPART will stored the new partition and USBDEV the device.
+# Show an Xdialog of available USB drives. The one which the user choses is
+# partitioned into a single big partition. USBPART will stored the path to
+# the new partition and USBDEV the path to the device.
 format_usb() {
     # Find the mkfs.vfat command
     MKFS_VFAT="$(which mkfs.vfat 2>/dev/null)"
@@ -75,8 +75,9 @@
     fi
 }
 
-# show an xdialog of available vfat partitions on attached USB drives. The chosen partition
-# will be stored in USBPART and the device it resides on is stored in USBDEV.
+# Show an Xdialog of available vfat partitions on attached USB drives. The
+# path to chosen partition will be stored in USBPART and the path to the 
+# device it resides on is stored in USBDEV.
 get_vfat() {
     I=0
 
@@ -122,7 +123,50 @@
     USBDEV="${USBPART/%[0-9]}"
 }
 
+# Copies the file with path equal to the first parameter to the file with path
+# equal to the second paramter. When a 1MB block has been copied (or block of
+# less than 1MB if it's the last one) a dot (.) is written, which can be used
+# by Xdialog. Upon error, ERR will be set to 1, otherwise 0.
+file_copy() {
+    SRC=$1
+    DST=$2
+    ERR=0
 
+    # Size of source file and the block size, in bytes
+    SIZE=$( stat --format=%s $SRC )
+    BLOCK_SIZE=$(( 1024*1024 ))
+
+    # The number of blocks, accounting for the last block even if smaller
+    # than BLOCK_SIZE.
+    BLOCKS=$(( (${SIZE}+${BLOCK_SIZE}-1)/${BLOCK_SIZE} ))
+
+    # Make sure permissions are OK
+    if [[ -r ${SRC} ]]; then
+        if [[ -e ${DST} ]]; then
+            if [[ -w ${DST} ]]; then
+                rm $DST
+            else
+                ERR=1
+                return
+            fi
+        fi
+    else
+        ERR=1
+        return
+    fi
+
+    # Copy the file, one block at a time
+    for i in $(seq 0 1 $(( ${BLOCKS} - 1 ))); do
+        dd if=${SRC} of=${DST} oflag=append conv=notrunc \
+           seek=${i} skip=${i} bs=${BLOCK_SIZE}c count=1 &> /dev/null
+	sync
+        echo -n "."
+    done
+
+    echo
+}
+
+
 # Main script:
 
 # Root of the Live CD
@@ -130,7 +174,7 @@
     MEDIAROOT="/mnt/cdrom"
 fi
 
-# determine isolinux/syslinux config directory
+# Determine isolinux/syslinux config directory
 if [[ -d "${MEDIAROOT}/syslinux" ]]; then
 	SYSLINUX="syslinux"
 elif [[ -d "${MEDIAROOT}/isolinux" ]]; then
@@ -181,7 +225,7 @@
 fi
 
 # Mount the drive
-MTPT="/mnt/createusb-mp"
+MTPT="$(mktemp -t -d incognitoXXXXXXXX)"
 mkdir -p ${MTPT}
 mount -v -t vfat "${USBPART}" "${MTPT}"
 if [[ $? -ne 0 ]]; then
@@ -189,23 +233,26 @@
     exit 1
 fi
 
-# Verify free space
+# Maximum capacity in KB
+TOTALSIZE="$(df -k -P "${MTPT}" | tail -n 1 | awk '{ print $2 }')"
+
+# Verify free space in KB
 MEDIAFREE="$(df -k -P "${MTPT}" | tail -n 1 | awk '{ print $4 }')"
 # Account for files that will be overwritten
+# note that "+1023" is for making the division round up
 for FILE in ${COPY_FILES}; do
     for FP in $(ls ${MTPT}/${FILE} 2>/dev/null); do
-	MEDIAFREE=$(( ${MEDIAFREE}+$(stat --format=%s ${FP})/1024 ))
+        MEDIAFREE=$(( ${MEDIAFREE}+($(stat --format=%s ${FP})+1023)/1024))
     done
 done
 # Decrement by space of files to copy
 for FILE in ${COPY_FILES}; do
     for FP in $(ls ${MEDIAROOT}/${FILE} 2>/dev/null); do
-	MEDIAFREE=$(( ${MEDIAFREE}-$(stat --format=%s ${FP})/1024 ))
+        MEDIAFREE=$(( ${MEDIAFREE}-($(stat --format=%s ${FP})+1023)/1024))
     done
 done
 
-echo "Free space of ${MEDIAFREE}k"
-
+# Make sure that at least 128 KB is available after copy
 if [[ ${MEDIAFREE} -lt 128 ]]; then
     ${DIALOG} --msgbox "Not enough free space on USB partition ${USBPART}, need $(( 128-${MEDIAFREE} ))k" 0 ${DEFAULT_WIDTH}
     umount -v "${MTPT}"
@@ -217,35 +264,26 @@
     mkdir -p "${MTPT}/${DIR}" 2>/dev/null
 done
 
-# Copy files
-TOTAL=$( echo ${COPY_FILES} | wc -w )
-CURRENT=0
+# Size of files to copy in MB
+COPY_SIZE=$(( (${TOTALSIZE}-${MEDIAFREE})/1024 ))
+
+# Copy files and show progress (note that the progress is approximate, and the
+# the number of dots file_copy probably are greater than COPY_SIZE)
+ERR=0
 for FILE in ${COPY_FILES}; do
     FP="${MEDIAROOT}/${FILE}"
-    if [[ -r "${FP}" ]]; then
-	cp -v "${FP}" "${MTPT}/${FILE//isolinux/syslinux}"
-    else
-	cp -v ${FP} "${MTPT}/${FILE//isolinux/syslinux}"
-    fi
-    ERR=$?
-    if [[ $? -ne 0 ]]; then
-	echo "cp gave error ${ERR}" >&2
+    file_copy "${FP}" "${MTPT}/${FILE//isolinux/syslinux}"
+    if [[ ${ERR} -ne 0 ]]; then
+	echo "Error copying file ${FP} to ${MTPT}/${FILE//isolinux/syslinux}" >&2
 	${DIALOG} --msgbox "Could not copy file ${FILE} to USB drive" 0 ${DEFAULT_WIDTH}
 	umount -v "${MTPT}"
 	rmdir "${MTPT}"
-	export FAILED=1
 	exit 1
     fi
-    [[ "${TOTAL}" -gt 0 ]] && echo $(( (${CURRENT}*100)/${TOTAL} ))
-    CURRENT=$(( ${CURRENT}+1 ))
-done | ${DIALOG} --progress "Copying files" 0 ${DEFAULT_WIDTH}
+done | ${DIALOG} --progress "Copying files" 0 ${DEFAULT_WIDTH} ${COPY_SIZE}
 
-if [[ "${FAILED}" -eq 1 ]]; then
-    exit 1
-fi
-
 # Unmount the drive
-( echo 90 ; echo 90 ; umount -v "${MTPT}" ) | ${DIALOG} --progress "Completing USB file copy" 0 ${DEFAULT_WIDTH}
+umount -v "${MTPT}"
 rmdir "${MTPT}"
 
 # Make bootable
@@ -255,12 +293,14 @@
     exit 1
 fi
 
+# Copy syslinux MBR
 dd if=/usr/lib/syslinux/mbr.bin "of=${USBDEV}"
 if [[ $? -ne 0 ]]; then
     ${DIALOG} --msgbox "Could not copy Master Boot Record to USB drive ${USBDEV} (dd)" 0 ${DEFAULT_WIDTH}
     exit 1
 fi
 
+# Install syslinux
 syslinux "${USBPART}"
 if [[ $? -ne 0 ]]; then
     ${DIALOG} --msgbox "Could not setup boot loader on USB partition ${USBPART} (syslinux)" 0 ${DEFAULT_WIDTH}
@@ -268,7 +308,6 @@
 fi
 
 # Success!
-
 ${DIALOG} --msgbox "Bootable USB drive successfully created" 0 ${DEFAULT_WIDTH}
 
 exit 0