diff options
author | Dave Woodfall <dave@slackbuilds.org> | 2021-02-20 19:16:11 +0000 |
---|---|---|
committer | Robby Workman <rworkman@slackware.com> | 2021-02-20 23:51:59 -0600 |
commit | 2cd5131e83ba364fa09d5633ad514ddefe684e8a (patch) | |
tree | e6c88a907b7b4b419694cfde7fc670ffecf655f8 /files/post-functions.sh | |
parent | 612b6553aea6e4ef714f2f8df2ff3d4de2a4a642 (diff) | |
download | slackpkg-2cd5131e83ba364fa09d5633ad514ddefe684e8a.tar.xz |
Fix new-config dialog
Diffstat (limited to 'files/post-functions.sh')
-rw-r--r-- | files/post-functions.sh | 65 |
1 files changed, 41 insertions, 24 deletions
diff --git a/files/post-functions.sh b/files/post-functions.sh index 593c47b..9fd483a 100644 --- a/files/post-functions.sh +++ b/files/post-functions.sh @@ -133,39 +133,55 @@ looknew() { ONLY_NEW_DOTNEW="" fi - echo -e "\nSearching for NEW configuration files" - FILES=$(find ${ROOT}/etc ${ROOT}/var/yp ${ROOT}/usr/share/vim -name "*.new" ${ONLY_NEW_DOTNEW} \ + SIZE=$( stty size ) + ROWS=${SIZE% *} + LISTMAX=$(( ROWS - 10 )) + + printf "%s\n" "Searching for NEW configuration files..." + + FILES=$( find \ + ${ROOT}/etc \ + ${ROOT}/var/yp \ + ${ROOT}/usr/share/vim \ + -name "*.new" \ + ${ONLY_NEW_DOTNEW} \ -not -name "rc.inet1.conf.new" \ -not -name "group.new" \ -not -name "passwd.new" \ -not -name "shadow.new" \ - -not -name "gshadow.new" 2>/dev/null | sort 2>/dev/null) - if [ "$FILES" != "" ]; then - newcount=$(echo "$FILES" | wc -l) - echo -ne "\n\ -Some packages had new configuration files installed ($newcount new files):\n\n" + -not -name "gshadow.new" 2>/dev/null | + sort -V 2>/dev/null ) + + if [ -n "$FILES" ]; then + newcount=$( echo "$FILES" | wc -l ) - SIZE=$(stty size) - ROWS=${SIZE% *} - LISTMAX=$((ROWS-20)) + printf "%s %s\n\n" "Some packages had new configuration" \ + "files installed ($newcount new files):" if [ $newcount -le $LISTMAX ]; then - echo -e "$FILES" + echo "$FILES" else F=0 + N=0 for FN in $FILES; do - F=$((F+1)) - echo "$FN" + F=$(( F + 1 )) + N=$(( N + 1 )) + echo "$N $FN" - if [ $F -ge $LISTMAX ]; then + if [ $F -ge $(( ROWS - 5 )) ]; then F=0 - echo -ne "\nPress SPACE for more, ENTER to skip" - IFS=$'\n' read -rn 1 junk - echo -e "\n" + IFS=$( printf "\n" ) read -rn 1 \ + -p " +Press SPACE for more, ENTER to skip" junk + printf "\n" + tput -S <<EOF + cuu 1 + el 2 + cuu 1 + el 2 +EOF - if [ "$junk" = " " ]; then - continue - elif [ "$junk" = "" ]; then + if [ -z "$junk" ]; then break fi fi @@ -173,7 +189,7 @@ Some packages had new configuration files installed ($newcount new files):\n\n" fi echo -ne "\n\ -You have four choices: +What do you want (K/O/R/P)? (K)eep the old files and consider .new files later @@ -183,9 +199,8 @@ You have four choices: echo -e "\n\n\ (R)emove all .new files - (P)rompt K, O, R selection for every single file + (P)rompt K, O, R selection for every single file" -What do you want (K/O/R/P)?" answer case $ANSWER in K|k) @@ -238,7 +253,9 @@ What do you want (K/O/R/P)?" break ;; *) - echo "OK! Your choice is nothing! slackpkg will Keep the old files for you to deal with later" + echo " +OK! Your choice is nothing! slackpkg will Keep the old files \ +for you to deal with later" ;; esac else |