diff options
author | grant <grant@pkgsrc.org> | 2004-01-10 08:38:43 +0000 |
---|---|---|
committer | grant <grant@pkgsrc.org> | 2004-01-10 08:38:43 +0000 |
commit | b508fcf3503d5e254eb1dc4ba1fee82f53699be4 (patch) | |
tree | e12022920708184b7b81a45fd805c54dada53612 /mk | |
parent | 5cf91440216c115f7a0b62f4bae7744c5186e5b0 (diff) | |
download | pkgsrc-b508fcf3503d5e254eb1dc4ba1fee82f53699be4.tar.gz |
make shared library handling more efficient by nuking the
show-shlib-type target and instead defining SHLIB_TYPE using
similar semantics show-shlib-type, but on non-dylib and non-AIX
platforms, use ${OBJECT_FMT} instead of compiling a dummy binary
and running file(1) over it.
with archivers/bzip2 on my Solaris 9 box, this shaves 1.6sec, 92
fork()s and 956 stat()s from creating ${WRKDIR}/.PLIST and the
do-shlib-handling target.
Diffstat (limited to 'mk')
-rw-r--r-- | mk/bsd.pkg.mk | 50 |
1 files changed, 12 insertions, 38 deletions
diff --git a/mk/bsd.pkg.mk b/mk/bsd.pkg.mk index d4489d943a3..5724d7cd67b 100644 --- a/mk/bsd.pkg.mk +++ b/mk/bsd.pkg.mk @@ -1,4 +1,4 @@ -# $NetBSD: bsd.pkg.mk,v 1.1340 2004/01/07 15:30:54 salo Exp $ +# $NetBSD: bsd.pkg.mk,v 1.1341 2004/01/10 08:38:43 grant Exp $ # # This file is in the public domain. # @@ -98,6 +98,14 @@ CHECK_SHLIBS?= YES # run check-shlibs after install SHLIB_HANDLING?= YES # do automatic shared lib handling NOCLEAN?= NO # don't clean up after update +.if exists(/usr/lib/libc.dylib) +SHLIB_TYPE= dylib +.elif ${OPSYS} == "AIX" +SHLIB_TYPE= aixlib +.else +SHLIB_TYPE= ${OBJECT_FMT} +.endif + PKGBASE?= ${PKGNAME:C/-[^-]*$//} PKGVERSION?= ${PKGNAME:C/^.*-//} PKGWILDCARD?= ${PKGBASE}-[0-9]* @@ -2867,11 +2875,10 @@ do-shlib-handling: ${_PKG_SILENT}${_PKG_DEBUG} \ sos=`${EGREP} -h -x '.*/lib[^/]+\.so' ${PLIST} || ${TRUE}`; \ if [ "$$sos" != "" ]; then \ - shlib_type=`${MAKE} ${MAKEFLAGS} show-shlib-type`; \ if [ "${SHLIB_PLIST_MODE}" = "0" ]; then \ - ${ECHO_MSG} "${_PKGSRC_IN}> [Automatic $$shlib_type shared object handling]"; \ + ${ECHO_MSG} "${_PKGSRC_IN}> [Automatic ${SHLIB_TYPE} shared object handling]"; \ fi; \ - case "$$shlib_type" in \ + case "${SHLIB_TYPE}" in \ ELF) ;; \ "a.out") \ ${AWK} '${_AOUT_AWK}' <${PLIST} >${PLIST}.tmp ; \ @@ -2967,38 +2974,6 @@ check-shlibs: fi .endif # NO_PKG_REGISTER - -.if !target(show-shlib-type) -# Show the shared lib type being built: one of ELF, a.out, dylib, or none -.PHONY: show-shlib-type -show-shlib-type: -. if exists(/usr/lib/libc.dylib) - ${_PKG_SILENT}${_PKG_DEBUG} \ - ${ECHO} "dylib" -. elif ${OPSYS} == "AIX" - ${_PKG_SILENT}${_PKG_DEBUG} \ - ${ECHO} "aixlib" -. else - ${_PKG_SILENT}${_PKG_DEBUG} \ - cd ${WRKDIR} && \ - sotype=none; \ - if [ "X${MKPIC}" != "Xno" -a "X${NOPIC}" = "X" ]; then \ - ${ECHO} "int main() { exit(0); }" > a.$$$$.c; \ - ${CC} ${CFLAGS} a.$$$$.c -o a.$$$$.out; \ - case `${FILE_CMD} a.$$$$.out` in \ - *ELF*dynamically*) \ - sotype=ELF ;; \ - *shared*library*) \ - sotype="a.out" ;; \ - *dynamically*) \ - sotype="a.out" ;; \ - esac; \ - fi; \ - ${ECHO} "$$sotype"; \ - ${RM} -f a.$$$$.c a.$$$$.out -. endif # libc.dylib -.endif - .PHONY: acquire-extract-lock acquire-patch-lock acquire-tools-lock .PHONY: acquire-buildlink-lock acquire-configure-lock acquire-build-lock acquire-extract-lock: @@ -4504,8 +4479,7 @@ print-PLIST: ${_PKG_SILENT}${_PKG_DEBUG}\ ${ECHO} '@comment $$'NetBSD'$$' ${_PKG_SILENT}${_PKG_DEBUG}\ - shlib_type=`${MAKE} ${MAKEFLAGS} show-shlib-type`; \ - case $$shlib_type in \ + case "${SHLIB_TYPE}" in \ "a.out") genlinks=1 ;; \ *) genlinks=0 ;; \ esac; \ |