Subject: pkg/31916: Better checks in bsd.pkg.mk if pkg_create happens to core dump during install
To: None <pkg-manager@netbsd.org, gnats-admin@netbsd.org,>
From: None <lars.nordlund@hem.utfors.se>
List: pkgsrc-bugs
Date: 10/25/2005 23:34:00
>Number: 31916
>Category: pkg
>Synopsis: Better checks in bsd.pkg.mk if pkg_create happens to core dump during install
>Confidential: no
>Severity: serious
>Priority: medium
>Responsible: pkg-manager
>State: open
>Class: change-request
>Submitter-Id: net
>Arrival-Date: Tue Oct 25 23:34:00 +0000 2005
>Originator: Lars Nordlund
>Release: NetBSD/current, i386, pkgsrc-current
>Organization:
>Environment:
>Description:
(from mail sent to tech-pkg@netbsd.org)
On my NetBSD i386-current with pkgsrc-current I see this:
===> lars@glengoyne:/usr/pkgsrc/net/openslp %make install
[...]
===========================================================================
===> do-shlib-handling [openslp-1.2.1] ===> [Automatic ELF shared object handling]
===> register-pkg [openslp-1.2.1] ===> Registering installation for openslp-1.2.1
[1] Segmentation fault (core dumped) /home/lars/tmp/p...
===> check-wrkref [openslp-1.2.1] ===> Checking for work-directory references in openslp-1.2.1
===> lars@glengoyne:/usr/pkgsrc/net/openslp %echo $?
0
===> lars@glengoyne:/usr/pkgsrc/net/openslp %ls -la work.glengoyne/.pkgdb/+CONTENTS
-rw-r--r-- 1 root wheel 0 Oct 24 21:47 work.glengoyne/.pkgdb/+CONTENTS
===> lars@glengoyne:/usr/pkgsrc/net/openslp %
i.e. 'make install' silently fails leaving the package with an empty
+CONTENTS file. This causes problems for other packages because they
can't be properly buildlinked (or something like that?).
After some discussions I came up with this patch:
The diff:
@@ -4386,7 +4435,13 @@
case $$doit in \
yes) \
${ECHO_MSG} "${_PKGSRC_IN}> Registering installation for ${PKGNAME}"; \
- ${PKG_CREATE} ${PKG_ARGS_INSTALL} -O ${PKGFILE} > ${PKG_DB_TMPDIR}/+CONTENTS; \
+ if ${PKG_CREATE} ${PKG_ARGS_INSTALL} -O ${PKGFILE} > ${PKG_DB_TMPDIR}/+CONTENTS; then \
+ :; \
+ else \
+ ${ECHO} "(pkg_create: exitcode $$?)"; \
+ ${ECHO} "Broken pkgdb? Try repairing it with \"pkg_admin rebuild\""; \
+ exit 1; \
+ fi; \
list="`${MAKE} ${MAKEFLAGS} run-depends-list ECHO_MSG=${TRUE} | ${SORT} -u`" ; \
for realdep in `${ECHO} $$list | ${XARGS} -n 1 ${SETENV} ${PKG_BEST_EXISTS} | ${SORT} -u`; do \
if ${TEST} -z "$$realdep"; then \
This catches non-zero exit values from pkg_create and tries to give some kind of information about what to do.
>How-To-Repeat:
>Fix: