tetromino    14/05/02 21:51:12

  Modified:             metadata.xml ChangeLog cairo-9999.ebuild
  Added:                cairo-1.12.16-r3.ebuild
  Log:
  Fix firefox crash (bug #507478, thanks to Jaak Ristioja and Patrice 
Levesque). Make lto optional (but enabled by default because cairo is a 
performance-critical library) and check for enough memory for it (bug #467278, 
thanks to Alex). Fix build with USE="opengl -X" (bug #483574, thanks to Sergey 
Popov).
  
  (Portage version: 2.2.10/cvs/Linux x86_64, signed Manifest commit with key 
CF0ADD61)

Revision  Changes    Path
1.29                 x11-libs/cairo/metadata.xml

file : 
http://sources.gentoo.org/viewvc.cgi/gentoo-x86/x11-libs/cairo/metadata.xml?rev=1.29&view=markup
plain: 
http://sources.gentoo.org/viewvc.cgi/gentoo-x86/x11-libs/cairo/metadata.xml?rev=1.29&content-type=text/plain
diff : 
http://sources.gentoo.org/viewvc.cgi/gentoo-x86/x11-libs/cairo/metadata.xml?r1=1.28&r2=1.29

Index: metadata.xml
===================================================================
RCS file: /var/cvsroot/gentoo-x86/x11-libs/cairo/metadata.xml,v
retrieving revision 1.28
retrieving revision 1.29
diff -u -r1.28 -r1.29
--- metadata.xml        20 Apr 2014 18:00:01 -0000      1.28
+++ metadata.xml        2 May 2014 21:51:12 -0000       1.29
@@ -19,6 +19,9 @@
     <flag name="gles2">Use OpenGL ES 2 backend for acceleration.</flag>
     <flag name="glib">Compile with GLib Object System support</flag>
     <flag name="legacy-drivers">Include the buggy gradients patch (for legacy 
drivers, such as nvidia-drivers older than 304.30)</flag>
+       <flag name="lto">Try to build with Link-Time Optimization if supported 
by
+               the compiler. This is recommended by upstream, but can cause 
build
+               failure in some environments and on machines with little 
memory.</flag>
     <flag name="openvg">Use OpenVG for backend acceleration</flag>
     <flag name="valgrind">Built-in support to mark memory regions</flag>
     <flag name="xlib-xcb">Use XCB renderer backend for acceleration over 
xlib</flag>



1.376                x11-libs/cairo/ChangeLog

file : 
http://sources.gentoo.org/viewvc.cgi/gentoo-x86/x11-libs/cairo/ChangeLog?rev=1.376&view=markup
plain: 
http://sources.gentoo.org/viewvc.cgi/gentoo-x86/x11-libs/cairo/ChangeLog?rev=1.376&content-type=text/plain
diff : 
http://sources.gentoo.org/viewvc.cgi/gentoo-x86/x11-libs/cairo/ChangeLog?r1=1.375&r2=1.376

Index: ChangeLog
===================================================================
RCS file: /var/cvsroot/gentoo-x86/x11-libs/cairo/ChangeLog,v
retrieving revision 1.375
retrieving revision 1.376
diff -u -r1.375 -r1.376
--- ChangeLog   2 May 2014 09:51:49 -0000       1.375
+++ ChangeLog   2 May 2014 21:51:12 -0000       1.376
@@ -1,6 +1,20 @@
 # ChangeLog for x11-libs/cairo
 # Copyright 1999-2014 Gentoo Foundation; Distributed under the GPL v2
-# $Header: /var/cvsroot/gentoo-x86/x11-libs/cairo/ChangeLog,v 1.375 2014/05/02 
09:51:49 tommy Exp $
+# $Header: /var/cvsroot/gentoo-x86/x11-libs/cairo/ChangeLog,v 1.376 2014/05/02 
21:51:12 tetromino Exp $
+
+*cairo-1.12.16-r3 (02 May 2014)
+
+  02 May 2014; Alexandre Rostovtsev <tetrom...@gentoo.org>
+  +cairo-1.12.16-r3.ebuild, cairo-9999.ebuild,
+  +files/cairo-1.12.16-all-clipped-1.patch,
+  +files/cairo-1.12.16-all-clipped-2.patch,
+  +files/cairo-1.12.16-all-clipped-3.patch,
+  +files/cairo-1.12.16-lto-optional.patch, metadata.xml:
+  Fix firefox crash (bug #507478, thanks to Jaak Ristioja and Patrice
+  Levesque). Make lto optional (but enabled by default because cairo is a
+  performance-critical library) and check for enough memory for it (bug
+  #467278, thanks to Alex). Fix build with USE="opengl -X" (bug #483574, thanks
+  to Sergey Popov).
 
   02 May 2014; Thomas Sachau (Tommy[D]) <to...@gentoo.org>
   cairo-1.10.2-r3.ebuild, cairo-1.12.14-r4.ebuild, cairo-1.12.16-r2.ebuild,



1.42                 x11-libs/cairo/cairo-9999.ebuild

file : 
http://sources.gentoo.org/viewvc.cgi/gentoo-x86/x11-libs/cairo/cairo-9999.ebuild?rev=1.42&view=markup
plain: 
http://sources.gentoo.org/viewvc.cgi/gentoo-x86/x11-libs/cairo/cairo-9999.ebuild?rev=1.42&content-type=text/plain
diff : 
http://sources.gentoo.org/viewvc.cgi/gentoo-x86/x11-libs/cairo/cairo-9999.ebuild?r1=1.41&r2=1.42

Index: cairo-9999.ebuild
===================================================================
RCS file: /var/cvsroot/gentoo-x86/x11-libs/cairo/cairo-9999.ebuild,v
retrieving revision 1.41
retrieving revision 1.42
diff -u -r1.41 -r1.42
--- cairo-9999.ebuild   2 May 2014 09:51:49 -0000       1.41
+++ cairo-9999.ebuild   2 May 2014 21:51:12 -0000       1.42
@@ -1,10 +1,10 @@
 # Copyright 1999-2014 Gentoo Foundation
 # Distributed under the terms of the GNU General Public License v2
-# $Header: /var/cvsroot/gentoo-x86/x11-libs/cairo/cairo-9999.ebuild,v 1.41 
2014/05/02 09:51:49 tommy Exp $
+# $Header: /var/cvsroot/gentoo-x86/x11-libs/cairo/cairo-9999.ebuild,v 1.42 
2014/05/02 21:51:12 tetromino Exp $
 
 EAPI=5
 
-inherit eutils flag-o-matic autotools multilib-minimal
+inherit check-reqs eutils flag-o-matic autotools multilib-minimal
 
 if [[ ${PV} == *9999* ]]; then
        inherit git-2
@@ -20,7 +20,7 @@
 HOMEPAGE="http://cairographics.org/";
 LICENSE="|| ( LGPL-2.1 MPL-1.1 )"
 SLOT="0"
-IUSE="X aqua debug directfb drm gallium gles2 +glib legacy-drivers opengl 
openvg qt4 static-libs +svg valgrind xcb xlib-xcb"
+IUSE="X aqua debug directfb drm gallium gles2 +glib legacy-drivers +lto opengl 
openvg qt4 static-libs +svg valgrind xcb xlib-xcb"
 # gtk-doc regeneration doesn't seem to work with out-of-source builds
 #[[ ${PV} == *9999* ]] && IUSE="${IUSE} doc" # API docs are provided in 
tarball, no need to regenerate
 
@@ -86,10 +86,37 @@
        /usr/include/cairo/cairo-directfb.h
 )
 
+CHECKREQS_MEMORY="768M"
+
+pkg_pretend() {
+       if [[ ${MERGE_TYPE} != "binary" ]] && use lto; then
+               einfo "Checking for sufficient memory to build $PN with USE=lto"
+               check-reqs_pkg_pretend
+       fi
+}
+
+pkg_setup() {
+       if [[ ${MERGE_TYPE} != "binary" ]] && use lto; then
+               check-reqs_pkg_setup
+       fi
+}
+
 src_prepare() {
        epatch "${FILESDIR}"/${PN}-1.8.8-interix.patch
        use legacy-drivers && epatch 
"${FILESDIR}"/${PN}-1.10.0-buggy_gradients.patch
        epatch "${FILESDIR}"/${PN}-respect-fontconfig.patch
+
+       # bug #507478, https://bugs.freedesktop.org/show_bug.cgi?id=77931
+       epatch "${FILESDIR}"/${PN}-1.12.16-all-clipped-3.patch
+
+       # allow the automagically injected -flto flag to be not injected
+       epatch "${FILESDIR}"/${PN}-1.12.16-lto-optional.patch
+
+       # tests and perf tools require X, bug #483574
+       if ! use X; then
+               sed -e '/^SUBDIRS/ s#boilerplate test perf# #' -i Makefile.am 
|| die
+       fi
+
        epatch_user
 
        # Slightly messed build system YAY
@@ -139,6 +166,7 @@
                $(use_enable gallium) \
                $(use_enable gles2 glesv2) \
                $(use_enable glib gobject) \
+               $(use_enable lto) \
                $(use_enable openvg vg) \
                $(use_enable opengl gl) \
                $(use_enable qt4 qt) \



1.1                  x11-libs/cairo/cairo-1.12.16-r3.ebuild

file : 
http://sources.gentoo.org/viewvc.cgi/gentoo-x86/x11-libs/cairo/cairo-1.12.16-r3.ebuild?rev=1.1&view=markup
plain: 
http://sources.gentoo.org/viewvc.cgi/gentoo-x86/x11-libs/cairo/cairo-1.12.16-r3.ebuild?rev=1.1&content-type=text/plain

Index: cairo-1.12.16-r3.ebuild
===================================================================
# Copyright 1999-2014 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
# $Header: /var/cvsroot/gentoo-x86/x11-libs/cairo/cairo-1.12.16-r3.ebuild,v 1.1 
2014/05/02 21:51:12 tetromino Exp $

EAPI=5

inherit check-reqs eutils flag-o-matic autotools multilib-minimal

if [[ ${PV} == *9999* ]]; then
        inherit git-2
        EGIT_REPO_URI="git://anongit.freedesktop.org/git/cairo"
        SRC_URI=""
        KEYWORDS=""
else
        SRC_URI="http://cairographics.org/releases/${P}.tar.xz";
        KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~mips ~ppc ~ppc64 ~s390 ~sh 
~sparc ~x86 ~amd64-fbsd ~x86-fbsd ~x86-freebsd ~x86-interix ~amd64-linux 
~arm-linux ~x86-linux ~ppc-macos ~x64-macos ~x86-macos ~sparc-solaris 
~sparc64-solaris ~x64-solaris ~x86-solaris"
fi

DESCRIPTION="A vector graphics library with cross-device output support"
HOMEPAGE="http://cairographics.org/";
LICENSE="|| ( LGPL-2.1 MPL-1.1 )"
SLOT="0"
IUSE="X aqua debug directfb drm gallium gles2 +glib legacy-drivers +lto opengl 
openvg qt4 static-libs +svg valgrind xcb xlib-xcb"
# gtk-doc regeneration doesn't seem to work with out-of-source builds
#[[ ${PV} == *9999* ]] && IUSE="${IUSE} doc" # API docs are provided in 
tarball, no need to regenerate

# Test causes a circular depend on gtk+... since gtk+ needs cairo but test 
needs gtk+ so we need to block it
RESTRICT="test"

RDEPEND="dev-libs/lzo[${MULTILIB_USEDEP}]
        media-libs/fontconfig[${MULTILIB_USEDEP}]
        media-libs/freetype:2[${MULTILIB_USEDEP}]
        media-libs/libpng:0=[${MULTILIB_USEDEP}]
        sys-libs/zlib[${MULTILIB_USEDEP}]
        >=x11-libs/pixman-0.28.0[${MULTILIB_USEDEP}]
        directfb? ( dev-libs/DirectFB )
        gles2? ( media-libs/mesa[gles2,${MULTILIB_USEDEP}] )
        glib? ( >=dev-libs/glib-2.28.6:2[${MULTILIB_USEDEP}] )
        opengl? ( || ( media-libs/mesa[egl,${MULTILIB_USEDEP}] 
media-libs/opengl-apple ) )
        openvg? ( media-libs/mesa[openvg,${MULTILIB_USEDEP}] )
        qt4? ( >=dev-qt/qtgui-4.8:4 )
        X? (
                >=x11-libs/libXrender-0.6[${MULTILIB_USEDEP}]
                x11-libs/libXext[${MULTILIB_USEDEP}]
                x11-libs/libX11[${MULTILIB_USEDEP}]
                drm? (
                        >=virtual/udev-136[${MULTILIB_USEDEP}]
                        gallium? ( media-libs/mesa[gallium,${MULTILIB_USEDEP}] )
                )
        )
        xcb? (
                x11-libs/libxcb[${MULTILIB_USEDEP}]
        )
        abi_x86_32? (
                !<=app-emulation/emul-linux-x86-gtklibs-20131008-r1
                !app-emulation/emul-linux-x86-gtklibs[-abi_x86_32(-)]
        )"
DEPEND="${RDEPEND}
        virtual/pkgconfig
        >=sys-devel/libtool-2
        X? (
                x11-proto/renderproto[${MULTILIB_USEDEP}]
                drm? (
                        x11-proto/xproto[${MULTILIB_USEDEP}]
                        >=x11-proto/xextproto-7.1[${MULTILIB_USEDEP}]
                )
        )"
#[[ ${PV} == *9999* ]] && DEPEND="${DEPEND}
#       doc? (
#               >=dev-util/gtk-doc-1.6
#               ~app-text/docbook-xml-dtd-4.2
#       )"

# drm module requires X
# for gallium we need to enable drm
REQUIRED_USE="
        drm? ( X )
        gallium? ( drm )
        gles2? ( !opengl )
        openvg? ( || ( gles2 opengl ) )
        xlib-xcb? ( xcb )
"

MULTILIB_WRAPPED_HEADERS=(
        /usr/include/cairo/cairo-features.h
        /usr/include/cairo/cairo-directfb.h
)

CHECKREQS_MEMORY="768M"

pkg_pretend() {
        if [[ ${MERGE_TYPE} != "binary" ]] && use lto; then
                einfo "Checking for sufficient memory to build $PN with USE=lto"
                check-reqs_pkg_pretend
        fi
}

pkg_setup() {
        if [[ ${MERGE_TYPE} != "binary" ]] && use lto; then
                check-reqs_pkg_setup
        fi
}

src_prepare() {
        epatch "${FILESDIR}"/${PN}-1.8.8-interix.patch
        use legacy-drivers && epatch 
"${FILESDIR}"/${PN}-1.10.0-buggy_gradients.patch
        epatch "${FILESDIR}"/${PN}-respect-fontconfig.patch

        # all-clipped handling from 1.13
        epatch "${FILESDIR}"/${PN}-1.12.16-all-clipped-{1,2}.patch
        # bug #507478, https://bugs.freedesktop.org/show_bug.cgi?id=77931
        epatch "${FILESDIR}"/${PN}-1.12.16-all-clipped-3.patch

        # allow the automagically injected -flto flag to be not injected
        epatch "${FILESDIR}"/${PN}-1.12.16-lto-optional.patch

        # tests and perf tools require X, bug #483574
        if ! use X; then
                sed -e '/^SUBDIRS/ s#boilerplate test perf# #' -i Makefile.am 
|| die
        fi

        epatch_user

        # Slightly messed build system YAY
        if [[ ${PV} == *9999* ]]; then
                touch boilerplate/Makefile.am.features
                touch src/Makefile.am.features
                touch ChangeLog
        fi

        # We need to run elibtoolize to ensure correct so versioning on FreeBSD
        # upgraded to an eautoreconf for the above interix patch.
        eautoreconf
}

multilib_src_configure() {
        local myopts

        [[ ${CHOST} == *-interix* ]] && append-flags -D_REENTRANT

        use elibc_FreeBSD && myopts+=" --disable-symbol-lookup"

        # TODO: remove this (and add USE-dep) when DirectFB is converted,
        # bug #484248 -- but beware of the circular dep.
        if ! multilib_is_native_abi; then
                myopts+=" --disable-directfb"
        fi

        # TODO: remove this (and add USE-dep) when qtgui is converted, bug 
#498010
        if ! multilib_is_native_abi; then
                myopts+=" --disable-qt"
        fi

        # [[ ${PV} == *9999* ]] && myopts+=" $(use_enable doc gtk-doc)"

        ECONF_SOURCE="${S}" \
        econf \
                --disable-dependency-tracking \
                $(use_with X x) \
                $(use_enable X tee) \
                $(use_enable X xlib) \
                $(use_enable X xlib-xrender) \
                $(use_enable aqua quartz) \
                $(use_enable aqua quartz-image) \
                $(use_enable debug test-surfaces) \
                $(use_enable drm) \
                $(use_enable directfb) \
                $(use_enable gallium) \
                $(use_enable gles2 glesv2) \
                $(use_enable glib gobject) \
                $(use_enable lto) \
                $(use_enable openvg vg) \
                $(use_enable opengl gl) \
                $(use_enable qt4 qt) \
                $(use_enable static-libs static) \
                $(use_enable svg) \
                $(use_enable valgrind) \
                $(use_enable xcb) \
                $(use_enable xcb xcb-shm) \
                $(use_enable xlib-xcb) \
                --enable-ft \
                --enable-pdf \
                --enable-png \
                --enable-ps \
                ${myopts}
}

multilib_src_install() {
        # parallel make install fails
        emake -j1 DESTDIR="${D}" install
}

multilib_src_install_all() {
        prune_libtool_files --all
        einstalldocs
}

pkg_postinst() {
        if use !xlib-xcb; then
                if has_version net-misc/nxserver-freenx \
                                || has_version net-misc/x2goserver; then
                        ewarn "cairo-1.12 is known to cause GTK+ errors with NX 
servers."
                        ewarn "Enable USE=\"xlib-xcb\" if you notice incorrect 
behavior in GTK+"
                        ewarn "applications that are running inside NX 
sessions. For details, see"
                        ewarn "https://bugs.gentoo.org/441878 or 
https://bugs.freedesktop.org/59173";
                fi
        fi
}




Reply via email to