summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorjlam <jlam@pkgsrc.org>2006-04-12 21:13:56 +0000
committerjlam <jlam@pkgsrc.org>2006-04-12 21:13:56 +0000
commit530fe2b25a5ebd44939cba19c2839c7a8b98bdd6 (patch)
tree495480ff9abb0fb9022129f7ccc860fbaaa85dcf
parent67facdb57619aa05adf3d239267bb1032a2ac612 (diff)
downloadpkgsrc-530fe2b25a5ebd44939cba19c2839c7a8b98bdd6.tar.gz
Better error-checking in the +INFO_FILES scriptlet:
(1) Don't claim to be adding and removing the info file if it does exist at all. (2) Always try to create and remove the directory containing the "dir" index file to avoid failures.
-rw-r--r--mk/install/info-files80
1 files changed, 46 insertions, 34 deletions
diff --git a/mk/install/info-files b/mk/install/info-files
index 4b2a50a121d..6d1d24792b9 100644
--- a/mk/install/info-files
+++ b/mk/install/info-files
@@ -1,4 +1,4 @@
-# $NetBSD: info-files,v 1.4 2006/04/06 17:57:34 jlam Exp $
+# $NetBSD: info-files,v 1.5 2006/04/12 21:13:56 jlam Exp $
#
# Generate an +INFO_FILES script that handles info file registration for
# the package.
@@ -32,8 +32,10 @@ UNPACK,|UNPACK,+INFO_FILES)
ECHO="@ECHO@"
GREP="@GREP@"
INSTALL_INFO="@INSTALL_INFO@"
+MKDIR="@MKDIR@"
PWD_CMD="@PWD_CMD@"
RM="@RM@"
+RMDIR="@RMDIR@"
SED="@SED@"
SORT="@SORT@"
TEST="@TEST@"
@@ -55,24 +57,29 @@ ADD)
[!/]*) file="${PKG_PREFIX}/$file" ;;
esac
- case "$printed_header" in
- yes) ;;
- *) printed_header=yes
- ${ECHO} "==========================================================================="
- ${ECHO} "Registering info files for ${PKGNAME}:"
- ${ECHO} ""
- ;;
- esac
+ if ${TEST} ! -f "$file"; then
+ :
+ else
+ case "$printed_header" in
+ yes) ;;
+ *) printed_header=yes
+ ${ECHO} "==========================================================================="
+ ${ECHO} "Registering info files for ${PKGNAME}:"
+ ${ECHO} ""
+ ;;
+ esac
- ${TEST} -n "$infodir" || infodir="${file%/*}"
- infoindex="$infodir/dir"
- nentries="`${GREP} -c '^\*' $infoindex 2>/dev/null`"
- case "$nentries" in
- [0-9]*) ${TEST} $nentries -gt 0 || ${RM} $infoindex ;;
- esac
- ${ECHO} " $file"
- ${INSTALL_INFO} --info-dir="$infodir" --delete $file >/dev/null 2>&1
- ${INSTALL_INFO} --info-dir="$infodir" $file >/dev/null 2>&1
+ ${TEST} -n "$infodir" || infodir="${file%/*}"
+ infoindex="$infodir/dir"
+ nentries="`${GREP} -c '^\*' $infoindex 2>/dev/null`"
+ case "$nentries" in
+ [0-9]*) ${TEST} $nentries -gt 0 || ${RM} $infoindex ;;
+ esac
+ ${ECHO} " $file"
+ ${MKDIR} -p "$infodir"
+ ${INSTALL_INFO} --info-dir="$infodir" --delete $file >/dev/null 2>&1
+ ${INSTALL_INFO} --info-dir="$infodir" $file >/dev/null 2>&1
+ fi
done
case "$printed_header" in
yes) ${ECHO} ""
@@ -89,23 +96,28 @@ REMOVE)
[!/]*) file="${PKG_PREFIX}/$file" ;;
esac
- case "$printed_header" in
- yes) ;;
- *) printed_header=yes
- ${ECHO} "==========================================================================="
- ${ECHO} "Unregistering info files for ${PKGNAME}:"
- ${ECHO} ""
- ;;
- esac
+ if ${TEST} ! -f "$file"; then
+ :
+ else
+ case "$printed_header" in
+ yes) ;;
+ *) printed_header=yes
+ ${ECHO} "==========================================================================="
+ ${ECHO} "Unregistering info files for ${PKGNAME}:"
+ ${ECHO} ""
+ ;;
+ esac
- ${TEST} -n "$infodir" || infodir="${file%/*}"
- infoindex="$infodir/dir"
- ${ECHO} " $file"
- ${INSTALL_INFO} --info-dir="$infodir" --delete $file >/dev/null 2>&1
- nentries="`${GREP} -c '^\*' $infoindex 2>/dev/null`"
- case "$nentries" in
- [0-9]*) ${TEST} $nentries -gt 1 || ${RM} $infoindex ;;
- esac
+ ${TEST} -n "$infodir" || infodir="${file%/*}"
+ infoindex="$infodir/dir"
+ ${ECHO} " $file"
+ ${INSTALL_INFO} --info-dir="$infodir" --delete $file >/dev/null 2>&1
+ nentries="`${GREP} -c '^\*' $infoindex 2>/dev/null`"
+ case "$nentries" in
+ [0-9]*) ${TEST} $nentries -gt 1 || ${RM} $infoindex ;;
+ esac
+ ${RMDIR} -p "$infodir" 2>/dev/null || ${TRUE}
+ fi
done
case "$printed_header" in
yes) ${ECHO} ""