Go to:
Gentoo Home
Documentation
Forums
Lists
Bugs
Planet
Store
Wiki
Get Gentoo!
Gentoo's Bugzilla – Attachment 566884 Details for
Bug 679046
dev-libs/libxml2: (apply upstream patch) always define LIBXML_THREAD_ENABLED
Home
|
New
–
[Ex]
|
Browse
|
Search
|
Privacy Policy
|
[?]
|
Reports
|
Requests
|
Help
|
New Account
|
Log In
[x]
|
Forgot Password
Login:
[x]
[patch]
proposed commit
0001-dev-libs-libxml2-always-define-LIBXML_THREAD_ENABLED.patch (text/plain), 9.25 KB, created by
Michael Haubenwallner (RETIRED)
on 2019-02-28 13:38:45 UTC
(
hide
)
Description:
proposed commit
Filename:
MIME Type:
Creator:
Michael Haubenwallner (RETIRED)
Created:
2019-02-28 13:38:45 UTC
Size:
9.25 KB
patch
obsolete
>From e6b7a85a8854b1ad794c561e473028c50139b45c Mon Sep 17 00:00:00 2001 >From: Michael Haubenwallner <haubi@gentoo.org> >Date: Thu, 28 Feb 2019 14:25:59 +0100 >Subject: [PATCH] dev-libs/libxml2: always define LIBXML_THREAD_ENABLED > >Apply upstream accepted patch, required for Cygwin. > >Closes: https://bugs.gentoo.org/679046 >Package-Manager: Portage-2.3.51, Repoman-2.3.11 >Signed-off-by: Michael Haubenwallner <haubi@gentoo.org> >--- > ...l2-2.9.9-define-when-threads-enabled.patch | 35 +++ > dev-libs/libxml2/libxml2-2.9.9-r1.ebuild | 216 ++++++++++++++++++ > 2 files changed, 251 insertions(+) > create mode 100644 dev-libs/libxml2/files/libxml2-2.9.9-define-when-threads-enabled.patch > create mode 100644 dev-libs/libxml2/libxml2-2.9.9-r1.ebuild > >diff --git a/dev-libs/libxml2/files/libxml2-2.9.9-define-when-threads-enabled.patch b/dev-libs/libxml2/files/libxml2-2.9.9-define-when-threads-enabled.patch >new file mode 100644 >index 00000000000..b48afa66053 >--- /dev/null >+++ b/dev-libs/libxml2/files/libxml2-2.9.9-define-when-threads-enabled.patch >@@ -0,0 +1,35 @@ >+https://mail.gnome.org/archives/xml/2019-February/msg00002.html >+ >+From cf68fe3d505dd3f7525ccc28c90f87432a747aa4 Mon Sep 17 00:00:00 2001 >+From: Michael Haubenwallner <michael.haubenwallner@ssi-schaefer.com> >+Date: Wed, 27 Feb 2019 15:00:14 +0100 >+Subject: [PATCH] Always define LIBXML_THREAD_ENABLED when enabled >+ >+When libxml2 is compiled with threads enabled, have the header file >+define LIBXML_THREAD_ENABLED even if the subsequent application by >+itself does not enable threads. Otherwise, the application would see >+the unthreaded API functions, but these are not exported (where it does >+make a difference, like on Win32 based platforms). >+--- >+ include/libxml/xmlversion.h.in | 3 --- >+ 1 file changed, 3 deletions(-) >+ >+diff --git a/include/libxml/xmlversion.h.in b/include/libxml/xmlversion.h.in >+index d10f9754..5ba64f23 100644 >+--- a/include/libxml/xmlversion.h.in >++++ b/include/libxml/xmlversion.h.in >+@@ -91,11 +91,8 @@ XMLPUBFUN void XMLCALL xmlCheckVersion(int version); >+ * Whether the thread support is configured in >+ */ >+ #if @WITH_THREADS@ >+-#if defined(_REENTRANT) || defined(__MT__) || \ >+- (defined(_POSIX_C_SOURCE) && (_POSIX_C_SOURCE - 0 >= 199506L)) >+ #define LIBXML_THREAD_ENABLED >+ #endif >+-#endif >+ >+ /** >+ * LIBXML_THREAD_ALLOC_ENABLED: >+-- >+2.18.1 >+ >diff --git a/dev-libs/libxml2/libxml2-2.9.9-r1.ebuild b/dev-libs/libxml2/libxml2-2.9.9-r1.ebuild >new file mode 100644 >index 00000000000..3f6dbb5c844 >--- /dev/null >+++ b/dev-libs/libxml2/libxml2-2.9.9-r1.ebuild >@@ -0,0 +1,216 @@ >+# Copyright 1999-2019 Gentoo Authors >+# Distributed under the terms of the GNU General Public License v2 >+ >+EAPI=6 >+PYTHON_COMPAT=( python2_7 python3_{4,5,6,7} ) >+PYTHON_REQ_USE="xml" >+ >+inherit libtool flag-o-matic ltprune python-r1 autotools prefix multilib-minimal >+ >+DESCRIPTION="XML C parser and toolkit" >+HOMEPAGE="http://www.xmlsoft.org/" >+ >+LICENSE="MIT" >+SLOT="2" >+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~m68k ~mips ~ppc ~ppc64 ~s390 ~sh ~sparc ~x86 ~ppc-aix ~x64-cygwin ~amd64-fbsd ~x86-fbsd ~amd64-linux ~x86-linux ~ppc-macos ~x64-macos ~x86-macos ~m68k-mint ~sparc-solaris ~sparc64-solaris ~x64-solaris ~x86-solaris" >+IUSE="debug examples icu ipv6 lzma python readline static-libs test" >+REQUIRED_USE="python? ( ${PYTHON_REQUIRED_USE} )" >+ >+XSTS_HOME="http://www.w3.org/XML/2004/xml-schema-test-suite" >+XSTS_NAME_1="xmlschema2002-01-16" >+XSTS_NAME_2="xmlschema2004-01-14" >+XSTS_TARBALL_1="xsts-2002-01-16.tar.gz" >+XSTS_TARBALL_2="xsts-2004-01-14.tar.gz" >+XMLCONF_TARBALL="xmlts20080827.tar.gz" >+ >+SRC_URI="ftp://xmlsoft.org/${PN}/${PN}-${PV/_rc/-rc}.tar.gz >+ test? ( >+ ${XSTS_HOME}/${XSTS_NAME_1}/${XSTS_TARBALL_1} >+ ${XSTS_HOME}/${XSTS_NAME_2}/${XSTS_TARBALL_2} >+ http://www.w3.org/XML/Test/${XMLCONF_TARBALL} )" >+ >+RDEPEND=" >+ >=sys-libs/zlib-1.2.8-r1:=[${MULTILIB_USEDEP}] >+ icu? ( >=dev-libs/icu-51.2-r1:=[${MULTILIB_USEDEP}] ) >+ lzma? ( >=app-arch/xz-utils-5.0.5-r1:=[${MULTILIB_USEDEP}] ) >+ python? ( ${PYTHON_DEPS} ) >+ readline? ( sys-libs/readline:= ) >+" >+DEPEND="${RDEPEND} >+ dev-util/gtk-doc-am >+ virtual/pkgconfig >+ hppa? ( >=sys-devel/binutils-2.15.92.0.2 ) >+" >+ >+S="${WORKDIR}/${PN}-${PV%_rc*}" >+ >+MULTILIB_CHOST_TOOLS=( >+ /usr/bin/xml2-config >+) >+ >+src_unpack() { >+ # ${A} isn't used to avoid unpacking of test tarballs into $WORKDIR, >+ # as they are needed as tarballs in ${S}/xstc instead and not unpacked >+ unpack ${P/_rc/-rc}.tar.gz >+ cd "${S}" || die >+ >+ if use test; then >+ cp "${DISTDIR}/${XSTS_TARBALL_1}" \ >+ "${DISTDIR}/${XSTS_TARBALL_2}" \ >+ "${S}"/xstc/ \ >+ || die "Failed to install test tarballs" >+ unpack ${XMLCONF_TARBALL} >+ fi >+} >+ >+src_prepare() { >+ default >+ >+ DOCS=( AUTHORS ChangeLog NEWS README* TODO* ) >+ >+ # Patches needed for prefix support >+ eapply "${FILESDIR}"/${PN}-2.7.1-catalog_path.patch >+ >+ eprefixify catalog.c xmlcatalog.c runtest.c xmllint.c >+ >+ # Fix build for Windows platform >+ # https://bugzilla.gnome.org/show_bug.cgi?id=760456 >+ # eapply "${FILESDIR}"/${PN}-2.8.0_rc1-winnt.patch >+ >+ # Fix python detection, bug #567066 >+ # https://bugzilla.gnome.org/show_bug.cgi?id=760458 >+ eapply "${FILESDIR}"/${PN}-2.9.2-python-ABIFLAG.patch >+ >+ # Fix python tests when building out of tree #565576 >+ eapply "${FILESDIR}"/${PN}-2.9.8-out-of-tree-test.patch >+ >+ # always define LIBXML_THREAD_ENABLED when enabled >+ eapply "${FILESDIR}"/${P}-define-when-threads-enabled.patch >+ >+ if [[ ${CHOST} == *-darwin* ]] ; then >+ # Avoid final linking arguments for python modules >+ sed -i -e '/PYTHON_LIBS/s/ldflags/libs/' configure.ac || die >+ # gcc-apple doesn't grok -Wno-array-bounds >+ sed -i -e 's/-Wno-array-bounds//' configure.ac || die >+ fi >+ >+ # Please do not remove, as else we get references to PORTAGE_TMPDIR >+ # in /usr/lib/python?.?/site-packages/libxml2mod.la among things. >+ # We now need to run eautoreconf at the end to prevent maintainer mode. >+# elibtoolize >+# epunt_cxx # if we don't eautoreconf >+ >+ eautoreconf >+} >+ >+multilib_src_configure() { >+ # filter seemingly problematic CFLAGS (#26320) >+ filter-flags -fprefetch-loop-arrays -funroll-loops >+ >+ # USE zlib support breaks gnome2 >+ # (libgnomeprint for instance fails to compile with >+ # fresh install, and existing) - <azarah@gentoo.org> (22 Dec 2002). >+ >+ # The meaning of the 'debug' USE flag does not apply to the --with-debug >+ # switch (enabling the libxml2 debug module). See bug #100898. >+ >+ # --with-mem-debug causes unusual segmentation faults (bug #105120). >+ >+ libxml2_configure() { >+ ECONF_SOURCE="${S}" econf \ >+ --with-html-subdir=${PF}/html \ >+ $(use_with debug run-debug) \ >+ $(use_with icu) \ >+ $(use_with lzma) \ >+ $(use_enable ipv6) \ >+ $(use_enable static-libs static) \ >+ $(multilib_native_use_with readline) \ >+ $(multilib_native_use_with readline history) \ >+ "$@" >+ } >+ >+ libxml2_py_configure() { >+ mkdir -p "${BUILD_DIR}" || die # ensure python build dirs exist >+ run_in_build_dir libxml2_configure "--with-python=${ROOT%/}${PYTHON}" # odd build system, also see bug #582130 >+ } >+ >+ libxml2_configure --without-python # build python bindings separately >+ >+ if multilib_is_native_abi && use python; then >+ python_foreach_impl libxml2_py_configure >+ fi >+} >+ >+multilib_src_compile() { >+ default >+ if multilib_is_native_abi && use python; then >+ local native_builddir=${BUILD_DIR} >+ python_foreach_impl libxml2_py_emake top_builddir="${native_builddir}" all >+ fi >+} >+ >+multilib_src_test() { >+ emake check >+ multilib_is_native_abi && use python && python_foreach_impl libxml2_py_emake test >+} >+ >+multilib_src_install() { >+ emake DESTDIR="${D}" \ >+ EXAMPLES_DIR="${EPREFIX}"/usr/share/doc/${PF}/examples install >+ >+ if multilib_is_native_abi && use python; then >+ python_foreach_impl libxml2_py_emake \ >+ DESTDIR="${D}" \ >+ docsdir="${EPREFIX}"/usr/share/doc/${PF}/python \ >+ exampledir="${EPREFIX}"/usr/share/doc/${PF}/python/examples \ >+ install >+ python_foreach_impl python_optimize >+ fi >+} >+ >+multilib_src_install_all() { >+ # on windows, xmllint is installed by interix libxml2 in parent prefix. >+ # this is the version to use. the native winnt version does not support >+ # symlinks, which makes repoman fail if the portage tree is linked in >+ # from another location (which is my default). -- mduft >+ if [[ ${CHOST} == *-winnt* ]]; then >+ rm -rf "${ED}"/usr/bin/xmllint >+ rm -rf "${ED}"/usr/bin/xmlcatalog >+ fi >+ >+ rm -rf "${ED}"/usr/share/doc/${P} >+ einstalldocs >+ >+ if ! use examples; then >+ rm -rf "${ED}"/usr/share/doc/${PF}/examples >+ rm -rf "${ED}"/usr/share/doc/${PF}/python/examples >+ fi >+ >+ prune_libtool_files --modules >+} >+ >+pkg_postinst() { >+ # We don't want to do the xmlcatalog during stage1, as xmlcatalog will not >+ # be in / and stage1 builds to ROOT=/tmp/stage1root. This fixes bug #208887. >+ if [[ "${ROOT}" != "/" ]]; then >+ elog "Skipping XML catalog creation for stage building (bug #208887)." >+ else >+ # need an XML catalog, so no-one writes to a non-existent one >+ CATALOG="${EROOT}etc/xml/catalog" >+ >+ # we dont want to clobber an existing catalog though, >+ # only ensure that one is there >+ # <obz@gentoo.org> >+ if [[ ! -e ${CATALOG} ]]; then >+ [[ -d "${EROOT}etc/xml" ]] || mkdir -p "${EROOT}etc/xml" >+ "${EPREFIX}"/usr/bin/xmlcatalog --create > "${CATALOG}" >+ einfo "Created XML catalog in ${CATALOG}" >+ fi >+ fi >+} >+ >+libxml2_py_emake() { >+ pushd "${BUILD_DIR}/python" > /dev/null || die >+ emake "$@" >+ popd > /dev/null >+} >-- >2.19.2 >
You cannot view the attachment while viewing its details because your browser does not support IFRAMEs.
View the attachment on a separate page
.
View Attachment As Diff
View Attachment As Raw
Actions:
View
|
Diff
Attachments on
bug 679046
: 566884