nss: update to 3.68.

Also unify native and cross build.
This commit is contained in:
Đoàn Trần Công Danh 2021-07-21 11:24:36 +07:00 committed by Đoàn Trần Công Danh
parent 72a24dc40a
commit f6ba5a5590
3 changed files with 48 additions and 60 deletions

View File

@ -0,0 +1,11 @@
--- nss-3.68.orig/nss/coreconf/nsinstall/Makefile
+++ nss-3.68/nss/coreconf/nsinstall/Makefile
@@ -32,6 +32,8 @@ endif
ifdef NATIVE_FLAGS
OS_CFLAGS=$(NATIVE_FLAGS)
+XCFLAGS = $(NATIVE_FLAGS)
+LDFLAGS = $(LDFLAGS_FOR_BUILD)
endif
include $(DEPTH)/coreconf/rules.mk

View File

@ -0,0 +1,11 @@
--- nss-3.67.orig/nss/coreconf/rules.mk
+++ nss-3.67/nss/coreconf/rules.mk
@@ -223,7 +223,7 @@ ifdef MT
endif # MSVC with manifest tool
endif
else
- $(MKSHLIB) -o $@ $(OBJS) $(SUB_SHLOBJS) $(LD_LIBS) $(EXTRA_LIBS) $(EXTRA_SHARED_LIBS) $(OS_LIBS)
+ $(MKSHLIB) $(LDFLAGS) -o $@ $(OBJS) $(SUB_SHLOBJS) $(LD_LIBS) $(EXTRA_LIBS) $(EXTRA_SHARED_LIBS) $(OS_LIBS)
chmod +x $@
endif
endif

View File

@ -1,10 +1,10 @@
# Template file for 'nss' # Template file for 'nss'
_nsprver=4.30 _nsprver=4.32
pkgname=nss pkgname=nss
version=3.67 version=3.68
revision=2 revision=1
hostmakedepends="perl" hostmakedepends="perl"
makedepends="nspr-devel sqlite-devel zlib-devel" makedepends="nspr-devel sqlite-devel zlib-devel"
depends="nspr>=${_nsprver}" depends="nspr>=${_nsprver}"
@ -13,7 +13,7 @@ maintainer="Đoàn Trần Công Danh <congdanhqx@gmail.com>"
license="MPL-2.0" license="MPL-2.0"
homepage="https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS" homepage="https://developer.mozilla.org/en-US/docs/Mozilla/Projects/NSS"
distfiles="${MOZILLA_SITE}/security/nss/releases/NSS_${version//\./_}_RTM/src/nss-${version}.tar.gz" distfiles="${MOZILLA_SITE}/security/nss/releases/NSS_${version//\./_}_RTM/src/nss-${version}.tar.gz"
checksum=f6549a9148cd27b394b40c77fa73111d5ea23cdb51d796665de1b7458f88ce7f checksum=c402b32cac83034ec1c3d826ef4306cd14a066d7d9a6f4c30d82b3bc043c725b
export NS_USE_GCC=1 export NS_USE_GCC=1
export LIBRUNPATH= export LIBRUNPATH=
@ -22,20 +22,11 @@ export NSS_USE_SYSTEM_SQLITE=1
export NSS_ENABLE_WERROR=0 export NSS_ENABLE_WERROR=0
export NSS_ENABLE_ECC=1 export NSS_ENABLE_ECC=1
export FREEBL_NO_DEPEND=1 export FREEBL_NO_DEPEND=1
export NSPR_INCLUDE_DIR=${XBPS_CROSS_BASE}/usr/include/nspr
export NSPR_LIB_DIR=${XBPS_CROSS_BASE}/usr/lib
do_build() { do_build() {
local _native_use64 _target_use64 local _use64 _ARCH
# Respect LDFLAGS
vsed -e 's/[$](MKSHLIB) /&$(LDFLAGS) /g' \
-i nss/coreconf/rules.mk
export NATIVE_CC="$BUILD_CC"
export NATIVE_FLAGS="$BUILD_CFLAGS"
if [ "$XBPS_WORDSIZE" = "64" ]; then
_native_use64="USE_64=1"
fi
# Build System can detect this just fine, # Build System can detect this just fine,
# but I don't like to see useless warning barf for every line. # but I don't like to see useless warning barf for every line.
@ -53,56 +44,31 @@ do_build() {
;; ;;
esac esac
cd nss
# Build nsinstall for host.
make ${makejobs} LD=$BUILD_LD LDFLAGS="$BUILD_LDFLAGS" ${_native_use64} -C coreconf
if [ "$CROSS_BUILD" ]; then
# We don't run test in cross build
export NSS_DISABLE_GTESTS=1
if [ "$XBPS_TARGET_WORDSIZE" = "64" ]; then if [ "$XBPS_TARGET_WORDSIZE" = "64" ]; then
CFLAGS+=" -DNS_PTR_GT_32" CFLAGS+=" -DNS_PTR_GT_32"
_target_use64="USE_64=1" _use64="USE_64=1"
fi fi
case "$XBPS_TARGET_MACHINE" in case "$XBPS_TARGET_MACHINE" in
aarch64*|ppc*|x86_64*) aarch64*|ppc*|x86_64*|i?86*)
_ARCH="${XBPS_TARGET_MACHINE%-*}" _ARCH="${XBPS_TARGET_MACHINE%-*}"
;; ;;
arm*) _ARCH="arm";; arm*) _ARCH="arm";;
mips*) _ARCH="mips";; mips*) _ARCH="mips";;
*) msg_error "$pkgver: unknown target machine\n";; *) msg_error "$pkgver: unknown target machine\n";;
esac esac
# ... and then copy it to $wrksrc.
find ${wrksrc} -type f -name nsinstall -exec cp {} ${wrksrc} \;
make clean
export NSPR_INCLUDE_DIR=${XBPS_CROSS_BASE}/usr/include/nspr
export NSPR_LIB_DIR=${XBPS_CROSS_BASE}/usr/lib
export XCFLAGS="${CFLAGS}" export XCFLAGS="${CFLAGS}"
make -C nss ${makejobs} \
make ${makejobs} \ ${CROSS_BUILD:+CROSS_COMPILE=1} OS_TEST="${_ARCH}" \
CROSS_COMPILE=1 OS_TEST="${_ARCH}" \ NATIVE_CC="${BUILD_CC}" NATIVE_FLAGS="${BUILD_CFLAGS}" \
NSINSTALL="${wrksrc}/nsinstall" \ CCC="$CXX" ${_use64} \
CC="$CC" CCC="$CXX" RANLIB="$RANLIB" ${_target_use64} \
all all
else
# native build
export NSPR_INCLUDE_DIR=/usr/include/nspr
export NSPR_LIB_DIR=/usr/lib
export XCFLAGS="${CFLAGS}"
make ${makejobs} ${_native_use64} all
fi
} }
do_check() { do_check() {
local _use_64 local _use_64
# We couldn't run test in cross compile!
export NSPR_INCLUDE_DIR=/usr/include/nspr
export NSPR_LIB_DIR=/usr/lib
export XCFLAGS="${CFLAGS}" export XCFLAGS="${CFLAGS}"
if [ "$XBPS_WORDSIZE" = "64" ]; then if [ "$XBPS_TARGET_WORDSIZE" = "64" ]; then
_use_64="USE_64=1" _use_64="USE_64=1"
fi fi
cd nss/tests cd nss/tests