From 250c4cb11bcc29ec43c8712291a032bd9040f5b0 Mon Sep 17 00:00:00 2001 From: "chess.griffin" Date: Tue, 1 Apr 2008 13:10:28 +0000 Subject: [PATCH] initial search code in dialog interface; tweak sbopkg.8 man page --- src/usr/bin/sbopkg | 34 +++++++++++++++++++----- src/usr/man/man8/sbopkg.8 | 56 ++++++++++++++++++++++++--------------- 2 files changed, 62 insertions(+), 28 deletions(-) diff --git a/src/usr/bin/sbopkg b/src/usr/bin/sbopkg index c4f3748..c3b4c36 100755 --- a/src/usr/bin/sbopkg +++ b/src/usr/bin/sbopkg @@ -364,12 +364,19 @@ SRCNAME=${DOWNLOAD##*/} show_readme () { # Show the package's text files. -# Thanks to slakmagik, this works much better. I may still look at -# 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. -${PAGER:-more} $PKGPATH/{README,$PKGNAME.SlackBuild,$PKGNAME.info,\ -slack-desc} +# I am still not happy with how this works and am trying to think +# of a better way to have these 4 docs available for viewing from the +# cli. Maybe have -s just return the readme, as the result of a +# search, and maybe have another option like -v to view all 4 docs? +# Also, maybe 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. +SBODOCS="README $PKGNAME.SlackBuild $PKGNAME.info slack-desc" +for i in $SBODOCS; do + echo + echo "Viewing "$i":" + ${PAGER:-more} $PKGPATH/$i + read # This was added because README was scrolling past too quickly +done return 0 } @@ -460,10 +467,11 @@ while [ 0 ]; do dialog --title "SlackBuilds.org Package Browser \ (sbopkg version $VER)" --menu \ "\nChoose one of the following or press to exit\n" \ - 15 60 6 \ + 15 60 7 \ "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" \ "Exit" "Exit sbopkg" 2>$TMP/sbopkg_main_menu_answer @@ -488,6 +496,18 @@ if [ "$R" = "Browse" ]; then browse_categories fi +if [ "$R" = "Search" ]; then + dialog --inputbox "Enter the name of a package you would like \ +to search for" 0 0 2>/$TMP/sbopkg_search_request + if [ $? = 1 ]; then + continue + fi + SRCH="$(cat $TMP/sbopkg_search_request)" + search_package $SRCH + SRCHRESULT="$(echo $PKGPATH | sed 's/^.\///')" + dialog --title "Package location" --msgbox "$SRCHRESULT" 8 30 +fi + if [ "$R" = "Cache" ]; then view_cache_dir fi diff --git a/src/usr/man/man8/sbopkg.8 b/src/usr/man/man8/sbopkg.8 index 3d909a0..2122773 100644 --- a/src/usr/man/man8/sbopkg.8 +++ b/src/usr/man/man8/sbopkg.8 @@ -1,4 +1,4 @@ -.TH SBOPKG 8 "Mar 2008" sbopkg-0.0.4 "" +.TH SBOPKG 8 "Mar 2008" sbopkg-0.0.5 "" .SH NAME .B sbopkg \ - The SlackBuilds.org Package Browser @@ -21,31 +21,42 @@ Before sbopkg can be used, a configuration file must be created at Sbopkg can be run from the command line by simply invoking "sbopkg." Doing so will launch the dialog-based interface, and the menus -provided should be fairly explanatory. The main menu allows the user -to rsync with the SlackBuilds.org repository, view the SlackBuilds.org -Changelog, display the contents of the local cache directory, display -the permanent build log, and browse the local copy of the SBo -repository. Once the browse function is chosen, the user can select -the category of software to view. After choosing a category, the user -can then view the various software packages available in the local SBo -repository. Selecting a package will display another menu allowing -the user to view the package's README, SlackBuild, .info, or -slack-desc file. The user can also edit the SlackBuild and the edited -SlackBuild will remain after doig an rsync. Additionally, if sbopkg -is run with root privileges, then the user can choose to build a -package as well using either the original SlackBuild or the -locally-edited one if present. If KEEPLOG is set to YES in the -sbopkg.conf file then a permanent log of the build process is saved in -/tmp/sbopkg-build-log. +provided should be fairly self-explanatory. The main menu allows the +user to rsync with the SlackBuilds.org repository, view the +SlackBuilds.org Changelog, display the contents of the local cache +directory where source tarballs are saved, display the permanent build +log, and browse or search the local copy of the SBo repository. Once +the browse function is chosen, the user can select the category of +software to view. After choosing a category, the user can then view +the various software packages available in that category within the +local SBo repository. Selecting a package will display another menu +allowing the user to view the package's README, SlackBuild, .info, or +slack-desc files. The user can also edit the SlackBuild and the +edited SlackBuild will remain after doing an rsync. Additionally, if +sbopkg is run with root privileges, then the user can choose to build +a package as well using either the original SlackBuild or the +locally-edited one, if present. Finally, if KEEPLOG is set to YES in +the sbopkg.conf file then a permanent log of the build process is +saved in /tmp/sbopkg-build-log. Alternatively, sbopkg can be run from the command line without using the dialog interface. Executing "sbopkg -h" will display a list of options available from the command line. +Certain features of sbopkg rely on outside binaries, such as a pager +to view the text files when sbopkg is run from the comamnd line, and +an editor to edit the SlackBuild. The pager function will look to the +environmental variable $PAGER and if that variable is not defined then +it will default to 'more.' Similarly, the edit SlackBuild function +found when sbopkg is used with the dialog interface will look to +$EDITOR and will default to 'vi' if no $EDITOR has been defined. + .SH OPTIONS .TP 5 -.B -b PACKAGE -Search for and build PACKAGE from the local SBo repository +.B -b PACKAGE(s) +Search for and build PACKAGE(s) from the local SBo repository. If more +than one package is specified, they must be in quotes. For example +"sbopkg -b "foo bar". .TP 5 .B -d DIRECTORY @@ -71,8 +82,11 @@ Display the SBo ChangeLog.txt and quit Rsync the local repository with SlackBuilds.org and quit .TP 5 -.B -s PACKAGE -Search for PACKAGE and, if found, display the README +.B -s PACKAGE(s) +Search for PACKAGE(s) and, if found, display the README, SlackBuild, +.info, and slack-desc files in that order. If more than one +package is specified, they must be in quotes. For example +"sbopkg -s "foo bar". .SH FILES .B /etc/sbopkg/sbopkg.conf