change version numbers to SVN; from now on, SVN code will remain at version SVN and I will change the version numbers at each release; import initial code to allow the user to change the Slackware version for the matching SBo mirror. In other words, a user can have a local mirror for the Slackware 11.0 SlackBuilds from SBo and also a mirror for the 12.0 SlackBuilds. These would default to /home/sbo/11.0 and /home/sbo/12.0 initially. The user can override the default SLACKVER set in the config file either with the new -v switch for cli users, or from within the dialog interface; also update man pages to reflect this new feature.

This commit is contained in:
chess.griffin 2008-04-03 22:40:00 +00:00
parent 704a8e07ce
commit 590667bb8c
3 changed files with 110 additions and 13 deletions

View File

@ -32,7 +32,7 @@ SCRIPT=${0##*/}
DIAG=""
SBOPKG_CONF="${SBOPKG_CONF:-/etc/sbopkg/sbopkg.conf}"
CWD="$(pwd)"
VER=0.0.6
VER=SVN
sanity_checks () {
# Check if config file is there and if so check that it has all
@ -57,12 +57,13 @@ else
exit 1
fi
fi
if [ ! -d "$LOCALREPO/$SLACKVER" ]; then
echo "$SCRIPT: Directory $LOCALREPO/$SLACKVER does not exist."
if [ ! -d "$LOCALREPO" ]; then
echo "$SCRIPT: Directory $LOCALREPO does not exist."
echo "Please create it and run $SCRIPT again." 1>&2
exit 1
else
cd $LOCALREPO/$SLACKVER
#cd $LOCALREPO/$SLACKVER
cd $LOCALREPO
fi
if [ ! -d "$SRCDIR" ]; then
echo "Creating local cache directory $SRCDIR to keep \
@ -89,8 +90,40 @@ else
fi
}
check_slack_version () {
if [ ! -d "$LOCALREPO/$SLACKVER" ]; then
if [ "$DIAG" = 1 ]; then
dialog --title "Create directory?" --yesno "The directory \
$LOCALREPO/$SLACKVER was not found. Would like to create it? \
Select YES to create or NO to return." 10 30
if [ $? = 0 ]; then
check_root
if [ $ROOT = "false" ]; then
dialog --title "ERROR" --msgbox "Sorry, only the root \
user can create this directory." 8 30
break
else
mkdir -p $LOCALREPO/$SLACKVER
dialog --title "Done" --msgbox "The directory has been \
created." 8 30
continue
fi
else
continue
fi
else
echo "$SCRIPT: Directory $LOCALREPO does not exist."
echo "Please create it and run $SCRIPT again." 1>&2
exit 1
fi
else
cd $LOCALREPO/$SLACKVER
fi
}
show_changelog () {
# Show the changelog
cd $LOCALREPO/$SLACKVER
if [ "$DIAG" = 1 ]; then
if [ ! -e ./ChangeLog.txt ]; then
dialog --title "ERROR" --msgbox "No ChangeLog.txt \
@ -106,8 +139,24 @@ else
fi
}
get_version_list () {
# This function displays the Slack versions available in the local SBo
# repository
cd $LOCALREPO
rm -f $TMP/sbopkg_version_list 2> /dev/null
DIR=( */ )
if [ -n "$DIR" ]; then
for i in ${DIR[*]%/}; do
echo "$i \"SBo repo for Slackware version $i\"" >> \
$TMP/sbopkg_version_list
done
fi
exit 0
}
get_category_list () {
# This function displays the list of SBo categories in the dialog
cd $LOCALREPO/$SLACKVER
rm -f $TMP/sbopkg_category_list 2> /dev/null
DIR=( */ )
if [ -n "$DIR" ]; then
@ -136,6 +185,26 @@ fi
cd $LOCALREPO/$SLACKVER
}
select_version () {
#get_version_list
while [ 0 ]; do
dialog --title "Choose a Slackware version" \
--menu "You are currently using sbopkg to browse a local copy of SBo \
for Slackware version $SLACKVER. If you would like to change \
it, please select another version below:" 20 50 3 \
"11.0" "Slackware version 11.0" \
"12.0" "Slackware version 12.0" 2>$TMP/sbopkg_version_selection
#"12.1" "Slackware version 12.1"
if [ $? = 1 ]; then
break
fi
#exit 0
SLACKVER="$(cat $TMP/sbopkg_version_selection)"
break
done
rm -rf $TMP/sbopkg_version_selection
}
info_item () {
# This function shows the menu for each package where the user can see
# certain information or build the package if he is root
@ -284,6 +353,7 @@ rm -rf $TMP/sbopkg_rsync.lck
rsync_repo () {
# This function does the rsync with SBo.
check_slack_version
check_write $LOCALREPO/$SLACKVER/
if [ "$WRITE" = "false" ]; then
if [ "$DIAG" = 1 ]; then
@ -314,6 +384,7 @@ search_package () {
# Search for package name and exit if not found. If it is found,
# populate various variables with data about the package for
# displaying information and building.
cd $LOCALREPO/$SLACKVER
PKG=$1
PKGPATH=$(find -name $PKG)
if [ ! $(find -name "$PKG") ]; then
@ -328,6 +399,7 @@ fi
. $PKGPATH/$PKG.info
PKGNAME=${PKG##*/}
SRCNAME=${DOWNLOAD##*/}
cd -
}
show_readme () {
@ -336,6 +408,7 @@ show_readme () {
# other ways to do this. Perhaps have a way for the user to choose
# which of the 4 docs he wants to view? Or have a menu listing the 4
# docs? Undecided.
cd $LOCALREPO/$SLACKVER
${PAGER:-more} $PKGPATH/{README,$PKGNAME.SlackBuild,$PKGNAME.info,\
slack-desc}
return 0
@ -480,13 +553,14 @@ while [ 0 ]; do
dialog --title "SlackBuilds.org Package Browser \
(sbopkg version $VER)" --menu \
"\nChoose one of the following or press <Cancel> to exit\n" \
15 60 7 \
15 60 8 \
"Rsync" "Rsync with SlackBuilds.org" \
"ChangeLog" "View the SlackBuilds.org ChangeLog" \
"Browse" "Browse the local SlackBuilds.org repo" \
"Search" "Search the local SlackBuilds.org repo" \
"Cache" "View the contents of the cache directory" \
"Log" "View the permanent build log" \
"Version" "Select Slackware version (currently: $SLACKVER)" \
"Exit" "Exit sbopkg" 2>$TMP/sbopkg_main_menu_answer
if [ $? = 1 ]; then
@ -534,6 +608,10 @@ if [ "$R" = "Log" ]; then
view_perm_log
fi
if [ "$R" = "Version" ]; then
select_version
fi
if [ "$R" = "Exit" ]; then
clear
cleanup
@ -558,7 +636,7 @@ if [ $# -eq 0 ]; then
fi
# This is the command line options and help
while getopts ":b:d:f:hlrs:" OPT; do
while getopts ":b:d:f:hlrs:v:" OPT; do
case $OPT in
b ) BUILD="$OPTARG"
;;
@ -572,6 +650,9 @@ while getopts ":b:d:f:hlrs:" OPT; do
;;
s ) SEARCH="$OPTARG"
;;
v ) VERSION=1
CUSTOMVER="$OPTARG"
;;
h|* )
echo
echo "$SCRIPT v$VER"
@ -589,6 +670,8 @@ ChangeLog.txt and then quit."
echo " the local mirror and then quit."
echo " -s package Search for a package and, if found, \
display package information."
echo " -v version Set the Slackware version for the"
echo " mirror (current choices are 11.0 and 12.0)"
echo
echo "Note: multiple arguments to -b and -s must be \
quoted (\"pkg1 pkg2\")"
@ -601,6 +684,10 @@ shift $(($OPTIND - 1))
sanity_checks
if [ -n "$VERSION" ]; then
SLACKVER=$CUSTOMVER
fi
if [ -n "$BUILD" ]; then
check_root
if [ $ROOT = "false" ]; then
@ -636,7 +723,8 @@ if [ -n "$CHANGELOG" ]; then
fi
if [ -n "$RSYNC" ]; then
echo "Rsyncing with Slackbuilds.org repository into $LOCALREPO."
echo "Rsyncing with Slackbuilds.org repository into \
$LOCALREPO/$SLACKVER."
rsync_repo
cleanup
echo "Finished rsync."
@ -652,6 +740,10 @@ if [ -n "$SEARCH" ]; then
exit 0
fi
if [ -n "$VERSION" ]; then
SLACKVER=$NEWVER
fi
cleanup
echo "All done."
exit 0

View File

@ -1,4 +1,4 @@
.TH SBOPKG.CONF 5 "Apr 2008" sbopkg-0.0.6 ""
.TH SBOPKG.CONF 5 "Apr 2008" sbopkg-SVN ""
.SH NAME
.B sbopkg.conf
\- Configuration file for sbopkg
@ -25,8 +25,8 @@ The default value of RSYNCMIRROR is slackbuilds.org::slackbuilds
.TP 5
.B SLACKVER
.br
This option allows the user to set the Slackware version in order to
rsync with the matching SBo repository.
This option allows the user to set the default Slackware version in
order to rsync with the matching SBo repository.
The default value of SLACKVER is 12.0.

View File

@ -1,4 +1,4 @@
.TH SBOPKG 8 "Apr 2008" sbopkg-0.0.6 ""
.TH SBOPKG 8 "Apr 2008" sbopkg-SVN ""
.SH NAME
.B sbopkg
\ - The SlackBuilds.org Package Browser
@ -88,6 +88,11 @@ Search for PACKAGE(s) and, if found, display the README, SlackBuild,
package is specified, they must be in quotes. For example
"sbopkg -s "foo bar".
.TP 5
.B -v VERSION
Set the Slackware version to use for the matching local SBo mirror.
Current options are 11.0 and 12.0.
.SH FILES
.B /etc/sbopkg/sbopkg.conf
\ - File to specify configuration options.