rework the loading/saving of build queues per some suggestions from Mauro Giachero; sbopkg now automatically saves a backup of the build queue, but the user may also optionally save the build and provide a specified path and filename and can load that user-saved file too

This commit is contained in:
chess.griffin 2009-01-15 18:25:57 +00:00
parent 06be5149a7
commit 5e46c6d19d

View file

@ -833,31 +833,35 @@ rm -f $TMP/sbopkg-ans-sort
continue continue
} }
delete_queue () { delete_backup_queue () {
# This function deletes any saved queues. # This function deletes any backup queues.
PERMQUEUE=$TMP/sbopkg-savedqueue PERMQUEUE=$TMP/sbopkg-savedqueue
if [ -e $PERMQUEUE ]; then if [ -e $PERMQUEUE ]; then
dialog --title "Delete Saved Queue?" --yesno "A saved build \ dialog --title "Delete Backup Queue?" --yesno "An \
queue was found. Would you like to delete it? Press <Yes> to \ automatically-saved backup build queue was found. Would you like \
delete the saved queue, or press <No> to cancel." 9 65 to delete it? Press <Yes> to delete the backup queue, or press \
<No> to cancel." 9 65
if [ $? = 0 ]; then if [ $? = 0 ]; then
rm -f $PERMQUEUE rm -f $PERMQUEUE
rm -f $TMP/sbopkg_backup_queue.lck
dialog --title "Done" --msgbox "The backup queue has been \
deleted." 8 30
fi fi
else else
dialog --title "Error" --msgbox "No saved queue was found." 8 30 dialog --title "Error" --msgbox "No backup queue was found." 8 30
fi fi
} }
load_queue () { load_backup_queue () {
# This function loads any saved queues and merges it with any # This function loads any backup queue and merges it with any
# current $TMPQUEUE. # current $TMPQUEUE.
TMPQUEUE=$TMP/sbopkg-tmp-queue TMPQUEUE=$TMP/sbopkg-tmp-queue
WORKINGQUEUE=$TMP/sbopkg-working-queue WORKINGQUEUE=$TMP/sbopkg-working-queue
PERMQUEUE=$TMP/sbopkg-savedqueue PERMQUEUE=$TMP/sbopkg-savedqueue
if [ -e $PERMQUEUE ]; then if [ -e $PERMQUEUE ]; then
dialog --title "Load Saved Queue?" --yesno "A saved build queue \ dialog --title "Load Backup Queue?" --yesno "A backup queue \
was found. Would you like to load it? Press <Yes> to load the \ was found. Would you like to load it? Press <Yes> to load the \
saved queue into your current queue, or press <No> to cancel." \ backup queue into your current queue, or press <No> to cancel." \
9 65 9 65
if [ $? = 0 ]; then if [ $? = 0 ]; then
rm -f $WORKINGQUEUE rm -f $WORKINGQUEUE
@ -865,37 +869,82 @@ saved queue into your current queue, or press <No> to cancel." \
cat $PERMQUEUE >> $WORKINGQUEUE cat $PERMQUEUE >> $WORKINGQUEUE
sort $WORKINGQUEUE | uniq > $TMPQUEUE sort $WORKINGQUEUE | uniq > $TMPQUEUE
rm -f $WORKINGQUEUE rm -f $WORKINGQUEUE
dialog --title "Done" --msgbox "The saved queue has been \ touch $TMP/sbopkg_backup_queue.lck
dialog --title "Done" --msgbox "The backup queue has been \
loaded." 8 30 loaded." 8 30
fi fi
else
dialog --title "Error" --msgbox "No saved queue was found." 8 30
fi fi
} }
save_queue () { save_backup_queue () {
# This function saves the build queue and merges it with any current # This function saves the build queue and merges it with any current
# $TMPQUEUE. # $TMPQUEUE.
TMPQUEUE=$TMP/sbopkg-tmp-queue TMPQUEUE=$TMP/sbopkg-tmp-queue
WORKINGQUEUE=$TMP/sbopkg-working-queue WORKINGQUEUE=$TMP/sbopkg-working-queue
PERMQUEUE=$TMP/sbopkg-savedqueue PERMQUEUE=$TMP/sbopkg-savedqueue
if [ -e $TMPQUEUE ]; then if [ -e $TMPQUEUE ]; then
dialog --title "Save Queue Permanently?" --yesno "Would you \ rm -f $WORKINGQUEUE
like to save a copy of the build queue? Press <Yes> to save (and \ cat $TMPQUEUE >> $WORKINGQUEUE
add to an already saved queue) or press <No> to cancel without \ cat $PERMQUEUE >> $WORKINGQUEUE
saving, which will keep any currently saved queue intact." 9 65 sort $WORKINGQUEUE | uniq > $PERMQUEUE
if [ $? = 0 ]; then rm -f $WORKINGQUEUE
fi
}
load_user_queue () {
# This function loads a user's specified saved queue and merges it
# with any current $TMPQUEUE.
TMPQUEUE=$TMP/sbopkg-tmp-queue
WORKINGQUEUE=$TMP/sbopkg-working-queue
dialog --title "Load Saved Queue" --inputbox "Please enter the path \
and filename to a saved build queue:" 10 50 2>/$TMP/sbopkg_user_queue
if [ $? = 0 ]; then
USERQUEUE="$(cat $TMP/sbopkg_user_queue)"
if [ -e $USERQUEUE ]; then
rm -f $WORKINGQUEUE rm -f $WORKINGQUEUE
cat $TMPQUEUE >> $WORKINGQUEUE cat $TMPQUEUE >> $WORKINGQUEUE
cat $PERMQUEUE >> $WORKINGQUEUE cat $USERQUEUE >> $WORKINGQUEUE
sort $WORKINGQUEUE | uniq > $PERMQUEUE sort $WORKINGQUEUE | uniq > $TMPQUEUE
rm -f $WORKINGQUEUE rm -f $WORKINGQUEUE
dialog --title "Done" --msgbox "The build queue has been \ dialog --title "Done" --msgbox "The saved queue has been \
saved." 8 30 loaded." 8 30
else
dialog --title "Error" --msgbox "No saved queue was found." \
8 30
fi fi
else fi
}
save_user_queue () {
# This function saves the build queue to a location the user
# specifies.
TMPQUEUE=$TMP/sbopkg-tmp-queue
if [ ! -e $TMPQUEUE ]; then
dialog --title "Empty Queue" --msgbox "The build \ dialog --title "Empty Queue" --msgbox "The build \
queue is empty." 8 30 queue is empty." 8 30
break
else
dialog --title "Save Queue" --inputbox "Please enter the path \
and filename where you would like to save the queue:" 10 50 \
2>/$TMP/sbopkg_user_queue
if [ $? = 0 ]; then
USERQUEUE="$(cat $TMP/sbopkg_user_queue)"
if [ ! "$USERQUEUE" = "" ]; then
if [ -e $USERQUEUE ]; then
dialog --title "Error" --yesno "Another file with \
that name already exists. Press <Yes> to continue and overwrite the \
other file, or press <No> to cancel." 10 50
if [ $? != 0 ]; then
continue
fi
fi
rm -f $USERQUEUE
touch $USERQUEUE
sort $TMPQUEUE | uniq > $USERQUEUE
dialog --title "Done" --msgbox "The build queue has been \
saved." 8 30
fi
fi
fi fi
} }
@ -1861,8 +1910,8 @@ dialog --default-item "$Q" --title "Build Queue Menu" --backtitle \
15 60 5 \ 15 60 5 \
"View" "View the build queue" \ "View" "View the build queue" \
"Load" "Load a saved build queue" \ "Load" "Load a saved build queue" \
"Save" "Save the build queue" \ "Save" "Save a build queue" \
"Delete" "Delete the saved build queue" \ "Delete" "Delete the automatic backup queue" \
"Process" "Process the build queue" \ "Process" "Process the build queue" \
2>$TMP/sbopkg_queue_menu_answer 2>$TMP/sbopkg_queue_menu_answer
@ -1875,19 +1924,22 @@ fi
Q="$(cat $TMP/sbopkg_queue_menu_answer)" Q="$(cat $TMP/sbopkg_queue_menu_answer)"
if [ "$Q" = "View" ]; then if [ "$Q" = "View" ]; then
if [ ! -e $TMP/sbopkg_backup_queue.lck ]; then
load_backup_queue
fi
view_queue view_queue
fi fi
if [ "$Q" = "Load" ]; then if [ "$Q" = "Load" ]; then
load_queue load_user_queue
fi fi
if [ "$Q" = "Save" ]; then if [ "$Q" = "Save" ]; then
save_queue save_user_queue
fi fi
if [ "$Q" = "Delete" ]; then if [ "$Q" = "Delete" ]; then
delete_queue delete_backup_queue
fi fi
if [ "$Q" = "Process" ]; then if [ "$Q" = "Process" ]; then
@ -2006,6 +2058,7 @@ SlackBuilds.org $SLACKVER repository." --menu \
"Exit" "Exit sbopkg" 2>$TMP/sbopkg_main_menu_answer "Exit" "Exit sbopkg" 2>$TMP/sbopkg_main_menu_answer
if [ $? != 0 ]; then if [ $? != 0 ]; then
save_backup_queue
clear clear
cleanup cleanup
exit 0 exit 0
@ -2067,6 +2120,7 @@ if [ "$R" = "Utilities" ]; then
fi fi
if [ "$R" = "Exit" ]; then if [ "$R" = "Exit" ]; then
save_backup_queue
clear clear
cleanup cleanup
exit 0 exit 0