diff options
author | jlam <jlam> | 2004-01-19 23:11:19 +0000 |
---|---|---|
committer | jlam <jlam> | 2004-01-19 23:11:19 +0000 |
commit | 4254a15f280136ec5bab50ffc0b43865a6b83ae4 (patch) | |
tree | fc74073671647b6253e79eaf4d7afdbe0d7fd0d7 | |
parent | e142da660c4283f5054692798a53ab935b119269 (diff) | |
download | pkgsrc-4254a15f280136ec5bab50ffc0b43865a6b83ae4.tar.gz |
Fix brokenness introduced as part of the update of zlib to 1.2.1. The
updated package update bumped the zlib shared lib major, which required
that BUILDLINK_DEPENDS.zlib be bumped as well. Rather then requiring
zlib>=1.2.1 for packages that can use the built-in zlib on *BSD systems,
allow those built-in versions to satisfy zlib>=1.1.4nb1 dependencies,
and only require the latest version if no suitable zlib is found.
-rw-r--r-- | devel/zlib/buildlink2.mk | 93 | ||||
-rw-r--r-- | devel/zlib/buildlink3.mk | 63 |
2 files changed, 109 insertions, 47 deletions
diff --git a/devel/zlib/buildlink2.mk b/devel/zlib/buildlink2.mk index 58dc86696dc..9baa9cb6b80 100644 --- a/devel/zlib/buildlink2.mk +++ b/devel/zlib/buildlink2.mk @@ -1,4 +1,4 @@ -# $NetBSD: buildlink2.mk,v 1.7 2003/03/05 13:05:44 salo Exp $ +# $NetBSD: buildlink2.mk,v 1.8 2004/01/19 23:11:19 jlam Exp $ .if !defined(ZLIB_BUILDLINK2_MK) ZLIB_BUILDLINK2_MK= # defined @@ -8,46 +8,79 @@ ZLIB_BUILDLINK2_MK= # defined BUILDLINK_DEPENDS.zlib?= zlib>=1.1.4nb1 BUILDLINK_PKGSRCDIR.zlib?= ../../devel/zlib +_ZLIB_H= /usr/include/zlib.h + +.if !defined(BUILDLINK_IS_BUILTIN.zlib) +BUILDLINK_IS_BUILTIN.zlib= NO +. if exists(${_ZLIB_H}) +BUILDLINK_IS_BUILTIN.zlib= YES +. endif +.endif + .if defined(USE_ZLIB) -_NEED_ZLIB= YES -.else -. if exists(/usr/include/zlib.h) -_NEED_ZLIB= NO +BUILDLINK_USE_BUILTIN.zlib= NO +.endif + +.if !defined(BUILDLINK_USE_BUILTIN.zlib) +. if !empty(BUILDLINK_IS_BUILTIN.zlib:M[nN][oO]) +BUILDLINK_USE_BUILTIN.zlib= NO . else -_NEED_ZLIB= YES -. endif +BUILDLINK_USE_BUILTIN.zlib= YES # -# Solaris has a broken (for the purposes of pkgsrc) version of zlib. +# Create an appropriate name for the built-in package distributed +# with the system. This package name can be used to check against +# BUILDLINK_DEPENDS.<pkg> to see if we need to install the pkgsrc +# version or if the built-in one is sufficient. # -_INCOMPAT_ZLIB= SunOS-*-* - -# So does IRIX -_INCOMPAT_ZLIB+= IRIX-*-* - -# So does Darwin -_INCOMPAT_ZLIB+= Darwin-*-* - -# So does Linux -_INCOMPAT_ZLIB+= Linux-*-* - +_ZLIB_VERSION!= \ + ${AWK} '/\#define[ ]*ZLIB_VERSION/ { \ + vers = $$3; \ + gsub("\"", "", vers); \ + print vers; \ + } \ + ' ${_ZLIB_H} +_ZLIB_PKG= zlib-${_ZLIB_VERSION} # -# Some NetBSD versions shipped with versions lower than 1.1.3. +# If the built-in zlib is 1.1.4, then check whether it has the security +# fix for CAN-2003-0107, which was a buffer overflow in the gzprintf +# function. If it does, then treat it as the equivalent of zlib-1.1.4nb1. # -_INCOMPAT_ZLIB+= NetBSD-0.*-* NetBSD-1.[012]*-* -_INCOMPAT_ZLIB+= NetBSD-1.3-* NetBSD-1.3.*-* NetBSD-1.3[A-H]-* - -INCOMPAT_ZLIB?= # empty -. for _pattern_ in ${_INCOMPAT_ZLIB} ${INCOMPAT_ZLIB} -. if !empty(MACHINE_PLATFORM:M${_pattern_}) -_NEED_ZLIB= YES +_HAVE_CAN_2003_0107_FIX= NetBSD-1.3[I-Z]*-* NetBSD-1.[456]*-* +_HAVE_CAN_2003_0107_FIX+= NetBSD-[2-9]*-* NetBSD-1[0-9]*-* +# +# XXX These patterns for {Free,Open}BSD are too permissive, but I'm not +# XXX sure which versions of those OSes provide secure versions of +# XXX zlib-1.1.4. +# +_HAVE_CAN_2003_0107_FIX+= FreeBSD-*-* OpenBSD-*-* +. if ${_ZLIB_VERSION} == "1.1.4" +. for _pattern_ in ${_HAVE_CAN_2003_0107_FIX} +. if !empty(MACHINE_PLATFORM:M${_pattern_}) +_ZLIB_PKG= zlib-1.1.4nb1 +. endif +. endfor . endif -. endfor + +_ZLIB_DEPENDS= ${BUILDLINK_DEPENDS.zlib} +BUILDLINK_USE_BUILTIN.zlib!= \ + if ${PKG_ADMIN} pmatch '${_ZLIB_DEPENDS}' ${_ZLIB_PKG}; then \ + ${ECHO} "YES"; \ + else \ + ${ECHO} "NO"; \ + fi +. endif +MAKEFLAGS+= BUILDLINK_USE_BUILTIN.zlib="${BUILDLINK_USE_BUILTIN.zlib}" .endif -.if ${_NEED_ZLIB} == "YES" +.if !empty(BUILDLINK_USE_BUILTIN.zlib:M[nN][oO]) BUILDLINK_PACKAGES+= zlib -EVAL_PREFIX+= BUILDLINK_PREFIX.zlib=zlib +EVAL_PREFIX+= BUILDLINK_PREFIX.zlib=zlib BUILDLINK_PREFIX.zlib_DEFAULT= ${LOCALBASE} +# +# If we depend on the package, depend on the latest version with a library +# major number bump. +# +BUILDLINK_DEPENDS.zlib= zlib>=1.2.1 _BLNK_ZLIB_LDFLAGS= -L${BUILDLINK_PREFIX.zlib}/lib -lz .else BUILDLINK_PREFIX.zlib= /usr diff --git a/devel/zlib/buildlink3.mk b/devel/zlib/buildlink3.mk index 7a2e981e8e1..f43ce6f5d4b 100644 --- a/devel/zlib/buildlink3.mk +++ b/devel/zlib/buildlink3.mk @@ -1,4 +1,4 @@ -# $NetBSD: buildlink3.mk,v 1.4 2004/01/05 11:05:45 jlam Exp $ +# $NetBSD: buildlink3.mk,v 1.5 2004/01/19 23:11:19 jlam Exp $ BUILDLINK_DEPTH:= ${BUILDLINK_DEPTH}+ ZLIB_BUILDLINK3_MK:= ${ZLIB_BUILDLINK3_MK}+ @@ -13,9 +13,11 @@ BUILDLINK_PKGSRCDIR.zlib?= ../../devel/zlib BUILDLINK_CHECK_BUILTIN.zlib?= NO +_ZLIB_H= /usr/include/zlib.h + .if !defined(BUILDLINK_IS_BUILTIN.zlib) BUILDLINK_IS_BUILTIN.zlib= NO -. if exists(/usr/include/zlib.h) +. if exists(${_ZLIB_H}) BUILDLINK_IS_BUILTIN.zlib= YES . endif .endif @@ -34,30 +36,57 @@ BUILDLINK_USE_BUILTIN.zlib= NO . else BUILDLINK_USE_BUILTIN.zlib= YES # -# The listed platforms have a broken (for the purposes of pkgsrc) version -# of this package. +# Create an appropriate name for the built-in package distributed +# with the system. This package name can be used to check against +# BUILDLINK_DEPENDS.<pkg> to see if we need to install the pkgsrc +# version or if the built-in one is sufficient. +# +_ZLIB_VERSION!= \ + ${AWK} '/\#define[ ]*ZLIB_VERSION/ { \ + vers = $$3; \ + gsub("\"", "", vers); \ + print vers; \ + } \ + ' ${_ZLIB_H} +_ZLIB_PKG= zlib-${_ZLIB_VERSION} +# +# If the built-in zlib is 1.1.4, then check whether it has the security +# fix for CAN-2003-0107, which was a buffer overflow in the gzprintf +# function. If it does, then treat it as the equivalent of zlib-1.1.4nb1. # -_INCOMPAT_ZLIB= SunOS-*-* -_INCOMPAT_ZLIB+= IRIX-*-* -_INCOMPAT_ZLIB+= Darwin-*-* -_INCOMPAT_ZLIB+= Linux-*-* +_HAVE_CAN_2003_0107_FIX= NetBSD-1.3[I-Z]*-* NetBSD-1.[456]*-* +_HAVE_CAN_2003_0107_FIX+= NetBSD-[2-9]*-* NetBSD-1[0-9]*-* # -# Some NetBSD versions shipped with zlib versions lower than 1.1.3. +# XXX These patterns for {Free,Open}BSD are too permissive, but I'm not +# XXX sure which versions of those OSes provide secure versions of +# XXX zlib-1.1.4. # -_INCOMPAT_ZLIB+= NetBSD-0.*-* NetBSD-1.[012]*-* -_INCOMPAT_ZLIB+= NetBSD-1.3-* NetBSD-1.3.*-* NetBSD-1.3[A-H]-* +_HAVE_CAN_2003_0107_FIX+= FreeBSD-*-* OpenBSD-*-* +. if ${_ZLIB_VERSION} == "1.1.4" +. for _pattern_ in ${_HAVE_CAN_2003_0107_FIX} +. if !empty(MACHINE_PLATFORM:M${_pattern_}) +_ZLIB_PKG= zlib-1.1.4nb1 +. endif +. endfor +. endif -INCOMPAT_ZLIB?= # empty -. for _pattern_ in ${_INCOMPAT_ZLIB} ${INCOMPAT_ZLIB} -. if !empty(MACHINE_PLATFORM:M${_pattern_}) -BUILDLINK_USE_BUILTIN.zlib= NO -. endif -. endfor +_ZLIB_DEPENDS= ${BUILDLINK_DEPENDS.zlib} +BUILDLINK_USE_BUILTIN.zlib!= \ + if ${PKG_ADMIN} pmatch '${_ZLIB_DEPENDS}' ${_ZLIB_PKG}; then \ + ${ECHO} "YES"; \ + else \ + ${ECHO} "NO"; \ + fi . endif MAKEFLAGS+= BUILDLINK_USE_BUILTIN.zlib="${BUILDLINK_USE_BUILTIN.zlib}" .endif .if !empty(BUILDLINK_USE_BUILTIN.zlib:M[nN][oO]) +# +# If we depend on the package, depend on the latest version with a library +# major number bump. +# +BUILDLINK_DEPENDS.zlib= zlib>=1.2.1 . if !empty(BUILDLINK_DEPTH:M+) BUILDLINK_DEPENDS+= zlib . endif |