commit:     96da169000b276f2dd8a643d04d92766b9f8b7df
Author:     Lars Wendler <polynomial-c <AT> gentoo <DOT> org>
AuthorDate: Tue Jul 11 07:08:19 2017 +0000
Commit:     Lars Wendler <polynomial-c <AT> gentoo <DOT> org>
CommitDate: Tue Jul 11 07:08:19 2017 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=96da1690

sys-libs/db: Disable sqlite in latest version as well.

Package-Manager: Portage-2.3.6, Repoman-2.3.2

 sys-libs/db/db-6.2.32-r1.ebuild | 237 ++++++++++++++++++++++++++++++++++++++++
 1 file changed, 237 insertions(+)

diff --git a/sys-libs/db/db-6.2.32-r1.ebuild b/sys-libs/db/db-6.2.32-r1.ebuild
new file mode 100644
index 00000000000..2dbb2cc1a5d
--- /dev/null
+++ b/sys-libs/db/db-6.2.32-r1.ebuild
@@ -0,0 +1,237 @@
+# Copyright 1999-2017 Gentoo Foundation
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=5
+inherit eutils db flag-o-matic java-pkg-opt-2 autotools multilib 
multilib-minimal versionator toolchain-funcs
+
+#Number of official patches
+#PATCHNO=`echo ${PV}|sed -e "s,\(.*_p\)\([0-9]*\),\2,"`
+PATCHNO=${PV/*.*.*_p}
+if [[ ${PATCHNO} == "${PV}" ]] ; then
+       MY_PV=${PV}
+       MY_P=${P}
+       PATCHNO=0
+else
+       MY_PV=${PV/_p${PATCHNO}}
+       MY_P=${PN}-${MY_PV}
+fi
+
+S_BASE="${WORKDIR}/${MY_P}"
+S="${S_BASE}/build_unix"
+DESCRIPTION="Oracle Berkeley DB"
+HOMEPAGE="http://www.oracle.com/technetwork/database/database-technologies/berkeleydb/overview/index.html";
+SRC_URI="http://download.oracle.com/berkeley-db/${MY_P}.tar.gz";
+for (( i=1 ; i<=${PATCHNO} ; i++ )) ; do
+       export SRC_URI="${SRC_URI} 
http://www.oracle.com/technology/products/berkeley-db/db/update/${MY_PV}/patch.${MY_PV}.${i}";
+done
+
+LICENSE="AGPL-3"
+SLOT="$(get_version_component_range 1-2)"
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~m68k ~ppc ~ppc64 ~s390 ~sh 
~sparc ~x86 ~sparc-fbsd ~x86-fbsd"
+IUSE="doc java cxx tcl test"
+
+REQUIRED_USE="test? ( tcl )"
+
+# the entire testsuite needs the TCL functionality
+DEPEND="tcl? ( >=dev-lang/tcl-8.5.15-r1:0=[${MULTILIB_USEDEP}] )
+       test? ( >=dev-lang/tcl-8.5.15-r1:0=[${MULTILIB_USEDEP}] )
+       java? ( >=virtual/jdk-1.5 )
+       >=sys-devel/binutils-2.16.1"
+RDEPEND="tcl? ( >=dev-lang/tcl-8.5.15-r1:0=[${MULTILIB_USEDEP}] )
+       java? ( >=virtual/jre-1.5 )"
+
+MULTILIB_WRAPPED_HEADERS=(
+       /usr/include/db$(get_version_component_range 1-2)/db.h
+)
+
+PATCHES=(
+       # bug #510506
+       "${FILESDIR}"/${PN}-4.8.24-java-manifest-location.patch
+
+       # use the includes from the prefix
+       "${FILESDIR}"/${PN}-6.2.32-jni-check-prefix-first.patch
+       "${FILESDIR}"/${PN}-4.3-listen-to-java-options.patch
+
+       # sqlite configure call has an extra leading ..
+       # upstreamed:5.2.36, missing in 5.3.x/6.x
+       # still needs to be patched in 6.0.20
+       "${FILESDIR}"/${PN}-6.1.19-sqlite-configure-path.patch
+
+       # The upstream testsuite copies .lib and the binaries for each parallel 
test
+       # core, ~300MB each. This patch uses links instead, saves a lot of 
space.
+       "${FILESDIR}"/${PN}-6.0.20-test-link.patch
+)
+
+src_prepare() {
+       cd "${WORKDIR}"/"${MY_P}"
+       for (( i=1 ; i<=${PATCHNO} ; i++ ))
+       do
+               epatch "${DISTDIR}"/patch."${MY_PV}"."${i}"
+       done
+
+       epatch "${PATCHES[@]}"
+       epatch_user
+
+       # Upstream release script grabs the dates when the script was run, so 
lets
+       # end-run them to keep the date the same.
+       export REAL_DB_RELEASE_DATE="$(awk \
+               '/^DB_VERSION_STRING=/{ gsub(".*\\(|\\).*","",$0); print $0; }' 
\
+               "${S_BASE}"/dist/configure)"
+       sed -r -i \
+               -e "/^DB_RELEASE_DATE=/s~=.*~='${REAL_DB_RELEASE_DATE}'~g" \
+               "${S_BASE}"/dist/RELEASE || die
+
+       # Include the SLOT for Java JAR files
+       # This supersedes the unused jarlocation patches.
+       sed -r -i \
+               -e '/jarfile=.*\.jar$/s,(.jar$),-$(LIBVERSION)\1,g' \
+               "${S_BASE}"/dist/Makefile.in || die
+
+       cd "${S_BASE}"/dist || die
+       rm -f aclocal/libtool.m4
+       sed -i \
+               -e '/AC_PROG_LIBTOOL$/aLT_OUTPUT' \
+               configure.ac || die
+       sed -i \
+               -e '/^AC_PATH_TOOL/s/ sh, none/ bash, none/' \
+               aclocal/programs.m4 || die
+       AT_M4DIR="aclocal aclocal_java" eautoreconf
+       # Upstream sucks - they do autoconf and THEN replace the version 
variables.
+       . ./RELEASE
+       for v in \
+               DB_VERSION_{FAMILY,LETTER,RELEASE,MAJOR,MINOR} \
+               DB_VERSION_{PATCH,FULL,UNIQUE_NAME,STRING,FULL_STRING} \
+               DB_VERSION \
+               DB_RELEASE_DATE ; do
+               local ev="__EDIT_${v}__"
+               sed -i -e "s/${ev}/${!v}/g" configure || die
+       done
+}
+
+multilib_src_configure() {
+       local myconf=()
+
+       tc-ld-disable-gold #470634
+
+       # compilation with -O0 fails on amd64, see bug #171231
+       if [[ ${ABI} == amd64 ]]; then
+               local CFLAGS=${CFLAGS} CXXFLAGS=${CXXFLAGS}
+               replace-flags -O0 -O2
+               is-flagq -O[s123] || append-flags -O2
+       fi
+
+       # Add linker versions to the symbols. Easier to do, and safer than 
header file
+       # mumbo jumbo.
+       if use userland_GNU ; then
+               append-ldflags -Wl,--default-symver
+       fi
+
+       # use `set` here since the java opts will contain whitespace
+       if multilib_is_native_abi && use java ; then
+               myconf+=(
+                       --with-java-prefix="${JAVA_HOME}"
+                       --with-javac-flags="$(java-pkg_javac-args)"
+               )
+       fi
+
+       # Bug #270851: test needs TCL support
+       if use tcl || use test ; then
+               myconf+=(
+                       --enable-tcl
+                       --with-tcl="${EPREFIX}/usr/$(get_libdir)"
+               )
+       else
+               myconf+=(--disable-tcl )
+       fi
+
+       # sql_compat will cause a collision with sqlite3
+       # --enable-sql_compat
+       # Don't --enable-sql* because we don't want to use bundled sqlite.
+       # See Gentoo bug #605688
+       ECONF_SOURCE="${S_BASE}"/dist \
+       STRIP="true" \
+       econf \
+               --enable-compat185 \
+               --enable-dbm \
+               --enable-o_direct \
+               --without-uniquename \
+               --disable-sql \
+               --disable-sql_codegen \
+               --disable-sql_compat \
+               $([[ ${ABI} == arm ]] && echo --with-mutex=ARM/gcc-assembly) \
+               $([[ ${ABI} == amd64 ]] && echo --with-mutex=x86/gcc-assembly) \
+               $(use_enable cxx) \
+               $(use_enable cxx stl) \
+               $(multilib_native_use_enable java) \
+               "${myconf[@]}" \
+               $(use_enable test)
+}
+
+multilib_src_install() {
+       emake install DESTDIR="${D}"
+
+       db_src_install_headerslot
+
+       db_src_install_usrlibcleanup
+
+       if multilib_is_native_abi && use java; then
+               java-pkg_regso "${ED}"/usr/"$(get_libdir)"/libdb_java*.so
+               java-pkg_dojar "${ED}"/usr/"$(get_libdir)"/*.jar
+               rm -f "${ED}"/usr/"$(get_libdir)"/*.jar
+       fi
+}
+
+multilib_src_install_all() {
+       db_src_install_usrbinslot
+
+       db_src_install_doc
+
+       dodir /usr/sbin
+       # This file is not always built, and no longer exists as of db-4.8
+       if [[ -f "${ED}"/usr/bin/berkeley_db_svc ]] ; then
+               mv "${ED}"/usr/bin/berkeley_db_svc \
+                       "${ED}"/usr/sbin/berkeley_db"${SLOT/./}"_svc || die
+       fi
+}
+
+pkg_postinst() {
+       multilib_foreach_abi db_fix_so
+}
+
+pkg_postrm() {
+       multilib_foreach_abi db_fix_so
+}
+
+src_test() {
+       # db_repsite is impossible to build, as upstream strips those sources.
+       # db_repsite is used directly in the setup_site_prog,
+       # setup_site_prog is called from open_site_prog
+       # which is called only from tests in the multi_repmgr group.
+       #sed -ri \
+       #       -e '/set subs/s,multi_repmgr,,g' \
+       #       "${S_BASE}/test/testparams.tcl"
+       sed -ri \
+               -e '/multi_repmgr/d' \
+               "${S_BASE}/test/tcl/test.tcl" || die
+
+       # This is the only failure in 5.2.28 so far, and looks like a false 
positive.
+       # Repmgr018 (btree): Test of repmgr stats.
+       #     Repmgr018.a: Start a master.
+       #     Repmgr018.b: Start a client.
+       #     Repmgr018.c: Run some transactions at master.
+       #         Rep_test: btree 20 key/data pairs starting at 0
+       #         Rep_test.a: put/get loop
+       # FAIL:07:05:59 (00:00:00) perm_no_failed_stat: expected 0, got 1
+       sed -ri \
+               -e '/set parms.*repmgr018/d' \
+               -e 's/repmgr018//g' \
+               "${S_BASE}/test/tcl/test.tcl" || die
+
+       multilib-minimal_src_test
+}
+
+multilib_src_test() {
+       multilib_is_native_abi || return
+
+       S=${BUILD_DIR} db_src_test
+}

Reply via email to