diff options
author | Diego Elio Pettenò <flameeyes@gentoo.org> | 2006-05-28 10:09:32 +0000 |
---|---|---|
committer | Diego Elio Pettenò <flameeyes@gentoo.org> | 2006-05-28 10:09:32 +0000 |
commit | 11892d39e32abd41c65da0010286fc18eb944842 (patch) | |
tree | 1014e8e830e804eef6a089b29dd8242dc2bcaf50 /media-libs | |
parent | Stable on alpha. (diff) | |
download | gentoo-2-11892d39e32abd41c65da0010286fc18eb944842.tar.gz gentoo-2-11892d39e32abd41c65da0010286fc18eb944842.tar.bz2 gentoo-2-11892d39e32abd41c65da0010286fc18eb944842.zip |
Add patch to add support for visibility (with GCC 4.1).
(Portage version: 2.1_rc2-r3)
Diffstat (limited to 'media-libs')
-rw-r--r-- | media-libs/libdts/ChangeLog | 6 | ||||
-rw-r--r-- | media-libs/libdts/files/libdts-0.0.2-visibility.patch | 230 | ||||
-rw-r--r-- | media-libs/libdts/libdts-0.0.2-r3.ebuild | 8 |
3 files changed, 240 insertions, 4 deletions
diff --git a/media-libs/libdts/ChangeLog b/media-libs/libdts/ChangeLog index cd0c7bb98dbd..3d4dd2c02609 100644 --- a/media-libs/libdts/ChangeLog +++ b/media-libs/libdts/ChangeLog @@ -1,6 +1,10 @@ # ChangeLog for media-libs/libdts # Copyright 2000-2006 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/media-libs/libdts/ChangeLog,v 1.28 2006/05/25 02:46:28 flameeyes Exp $ +# $Header: /var/cvsroot/gentoo-x86/media-libs/libdts/ChangeLog,v 1.29 2006/05/28 10:09:32 flameeyes Exp $ + + 28 May 2006; Diego Pettenò <flameeyes@gentoo.org> + +files/libdts-0.0.2-visibility.patch, libdts-0.0.2-r3.ebuild: + Add patch to add support for visibility (with GCC 4.1). 25 May 2006; Diego Pettenò <flameeyes@gentoo.org> libdts-0.0.2-r3.ebuild: Add ~x86-fbsd keyword. diff --git a/media-libs/libdts/files/libdts-0.0.2-visibility.patch b/media-libs/libdts/files/libdts-0.0.2-visibility.patch new file mode 100644 index 000000000000..e8cc1f1a107d --- /dev/null +++ b/media-libs/libdts/files/libdts-0.0.2-visibility.patch @@ -0,0 +1,230 @@ +Index: libdts-0.0.2/configure.ac +=================================================================== +--- libdts-0.0.2.orig/configure.ac ++++ libdts-0.0.2/configure.ac +@@ -139,4 +139,7 @@ builtin([include],[src/configure.incl]) + + AC_C_ATTRIBUTE_ALIGNED + ++CC_ATTRIBUTE_VISIBILITY ++CC_FLAG_VISIBILITY([CFLAGS="$CFLAGS -fvisibility=hidden"]) ++ + AC_OUTPUT +Index: libdts-0.0.2/include/dts.h +=================================================================== +--- libdts-0.0.2.orig/include/dts.h ++++ libdts-0.0.2/include/dts.h +@@ -23,6 +23,14 @@ + #ifndef DTS_H + #define DTS_H + ++#ifndef EXPORTED ++# ifdef SUPPORT_ATTRIBUTE_VISIBILITY ++# define EXPORTED __attribute__((visibility("default"))) ++# else ++# define EXPORTED ++# endif ++#endif ++ + /* x86 accelerations */ + #define MM_ACCEL_X86_MMX 0x80000000 + #define MM_ACCEL_X86_3DNOW 0x40000000 +@@ -64,22 +72,22 @@ typedef struct dts_state_s dts_state_t; + #define DTS_LFE 0x80 + #define DTS_ADJUST_LEVEL 0x100 + +-dts_state_t * dts_init (uint32_t mm_accel); ++dts_state_t * dts_init (uint32_t mm_accel) EXPORTED; + + int dts_syncinfo (dts_state_t *state, uint8_t * buf, int * flags, +- int * sample_rate, int * bit_rate, int *frame_length); ++ int * sample_rate, int * bit_rate, int *frame_length) EXPORTED; + + int dts_frame (dts_state_t * state, uint8_t * buf, int * flags, +- level_t * level, sample_t bias); ++ level_t * level, sample_t bias) EXPORTED; + + void dts_dynrng (dts_state_t * state, +- level_t (* call) (level_t, void *), void * data); ++ level_t (* call) (level_t, void *), void * data) EXPORTED; + +-int dts_blocks_num (dts_state_t * state); +-int dts_block (dts_state_t * state); ++int dts_blocks_num (dts_state_t * state) EXPORTED; ++int dts_block (dts_state_t * state) EXPORTED; + +-sample_t * dts_samples (dts_state_t * state); ++sample_t * dts_samples (dts_state_t * state) EXPORTED; + +-void dts_free (dts_state_t * state); ++void dts_free (dts_state_t * state) EXPORTED; + + #endif /* DTS_H */ +Index: libdts-0.0.2/m4/attributes.m4 +=================================================================== +--- /dev/null ++++ libdts-0.0.2/m4/attributes.m4 +@@ -0,0 +1,163 @@ ++# Functions to check for attributes support in compiler ++ ++AC_DEFUN([CC_ATTRIBUTE_CONSTRUCTOR], [ ++ AC_CACHE_CHECK([if compiler supports __attribute__((constructor))], ++ [cc_cv_attribute_constructor], ++ [AC_COMPILE_IFELSE([ ++ void ctor() __attribute__((constructor)); ++ void ctor() { }; ++ ], ++ [cc_cv_attribute_constructor=yes], ++ [cc_cv_attribute_constructor=no]) ++ ]) ++ ++ if test "x$cc_cv_attribute_constructor" = "xyes"; then ++ AC_DEFINE([SUPPORT_ATTRIBUTE_CONSTRUCTOR], 1, [Define this if the compiler supports the constructor attribute]) ++ $1 ++ else ++ true ++ $2 ++ fi ++]) ++ ++AC_DEFUN([CC_ATTRIBUTE_FORMAT], [ ++ AC_CACHE_CHECK([if compiler supports __attribute__((format(printf, n, n)))], ++ [cc_cv_attribute_format], ++ [AC_COMPILE_IFELSE([ ++ void __attribute__((format(printf, 1, 2))) printflike(const char *fmt, ...) { } ++ ], ++ [cc_cv_attribute_format=yes], ++ [cc_cv_attribute_format=no]) ++ ]) ++ ++ if test "x$cc_cv_attribute_format" = "xyes"; then ++ AC_DEFINE([SUPPORT_ATTRIBUTE_FORMAT], 1, [Define this if the compiler supports the format attribute]) ++ $1 ++ else ++ true ++ $2 ++ fi ++]) ++ ++AC_DEFUN([CC_ATTRIBUTE_FORMAT_ARG], [ ++ AC_CACHE_CHECK([if compiler supports __attribute__((format_arg(printf)))], ++ [cc_cv_attribute_format_arg], ++ [AC_COMPILE_IFELSE([ ++ void __attribute__((format_arg(printf, 1))) gettextlike(const char *fmt) { } ++ ], ++ [cc_cv_attribute_format_arg=yes], ++ [cc_cv_attribute_format_arg=no]) ++ ]) ++ ++ if test "x$cc_cv_attribute_format_arg" = "xyes"; then ++ AC_DEFINE([SUPPORT_ATTRIBUTE_FORMAT_ARG], 1, [Define this if the compiler supports the format_arg attribute]) ++ $1 ++ else ++ true ++ $2 ++ fi ++]) ++ ++AC_DEFUN([CC_ATTRIBUTE_VISIBILITY], [ ++ AC_CACHE_CHECK([if compiler supports __attribute__((visibility("...")))], ++ [cc_cv_attribute_visibility], ++ [AC_COMPILE_IFELSE([ ++ void __attribute__((visibility("internal"))) internal_function() { } ++ void __attribute__((visibility("hidden"))) hidden_function() { } ++ void __attribute__((visibility("default"))) external_function() { } ++ ], ++ [cc_cv_attribute_visibility=yes], ++ [cc_cv_attribute_visibility=no]) ++ ]) ++ ++ if test "x$cc_cv_attribute_visibility" = "xyes"; then ++ AC_DEFINE([SUPPORT_ATTRIBUTE_VISIBILITY], 1, [Define this if the compiler supports the visibility attribute]) ++ $1 ++ else ++ true ++ $2 ++ fi ++]) ++ ++AC_DEFUN([CC_FLAG_VISIBILITY], [ ++ AC_CACHE_CHECK([if compiler supports -fvisibility=hidden], ++ [cc_cv_flag_visibility], ++ [ ++ save_CFLAGS=$CFLAGS ++ CFLAGS="$CFLAGS -fvisibility=hidden" ++ AC_COMPILE_IFELSE([int a;], ++ [cc_cv_flag_visibility=yes], ++ [cc_cv_flag_visibility=no]) ++ CFLAGS="$save_CFLAGS" ++ ]) ++ ++ if test "x$cc_cv_flag_visibility" = "xyes"; then ++ AC_DEFINE([SUPPORT_FLAG_VISIBILITY], 1, [Define this if the compiler supports the -fvisibility flag]) ++ $1 ++ else ++ true ++ $2 ++ fi ++]) ++ ++AC_DEFUN([CC_ATTRIBUTE_NONNULL], [ ++ AC_CACHE_CHECK([if compiler supports __attribute__((nonnull()))], ++ [cc_cv_attribute_nonnull], ++ [AC_COMPILE_IFELSE([ ++ void some_function(void *foo, void *bar) __attribute__((nonnull())); ++ void some_function(void *foo, void *bar) { } ++ ], ++ [cc_cv_attribute_nonnull=yes], ++ [cc_cv_attribute_nonnull=no]) ++ ]) ++ ++ if test "x$cc_cv_attribute_nonnull" = "xyes"; then ++ AC_DEFINE([SUPPORT_ATTRIBUTE_NONNULL], 1, [Define this if the compiler supports the nonnull attribute]) ++ $1 ++ else ++ true ++ $2 ++ fi ++]) ++ ++AC_DEFUN([CC_ATTRIBUTE_UNUSED], [ ++ AC_CACHE_CHECK([if compiler supports __attribute__((unused))], ++ [cc_cv_attribute_unused], ++ [AC_COMPILE_IFELSE([ ++ void some_function(void *foo, __attribute__((unused)) void *bar); ++ ], ++ [cc_cv_attribute_unused=yes], ++ [cc_cv_attribute_unused=no]) ++ ]) ++ ++ if test "x$cc_cv_attribute_unused" = "xyes"; then ++ AC_DEFINE([SUPPORT_ATTRIBUTE_UNUSED], 1, [Define this if the compiler supports the unused attribute]) ++ $1 ++ else ++ true ++ $2 ++ fi ++]) ++ ++AC_DEFUN([CC_FUNC_EXPECT], [ ++ AC_CACHE_CHECK([if compiler has __builtin_expect function], ++ [cc_cv_func_expect], ++ [AC_COMPILE_IFELSE([ ++ int some_function() ++ { ++ int a = 3; ++ return (int)__builtin_expect(a, 3); ++ } ++ ], ++ [cc_cv_func_expect=yes], ++ [cc_cv_func_expect=no]) ++ ]) ++ ++ if test "x$cc_cv_func_expect" = "xyes"; then ++ AC_DEFINE([SUPPORT__BUILTIN_EXPECT], 1, [Define this if the compiler supports __builtin_expect() function]) ++ $1 ++ else ++ true ++ $2 ++ fi ++]) diff --git a/media-libs/libdts/libdts-0.0.2-r3.ebuild b/media-libs/libdts/libdts-0.0.2-r3.ebuild index c744b46c5692..209bac88a064 100644 --- a/media-libs/libdts/libdts-0.0.2-r3.ebuild +++ b/media-libs/libdts/libdts-0.0.2-r3.ebuild @@ -1,8 +1,8 @@ # Copyright 1999-2006 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/media-libs/libdts/libdts-0.0.2-r3.ebuild,v 1.12 2006/05/25 02:46:28 flameeyes Exp $ +# $Header: /var/cvsroot/gentoo-x86/media-libs/libdts/libdts-0.0.2-r3.ebuild,v 1.13 2006/05/28 10:09:32 flameeyes Exp $ -inherit eutils autotools +inherit eutils toolchain-funcs autotools DESCRIPTION="library for decoding DTS Coherent Acoustics streams used in DVD" HOMEPAGE="http://www.videolan.org/dtsdec.html" @@ -20,8 +20,10 @@ src_unpack() { epatch "${FILESDIR}/${P}-libtool.patch" epatch "${FILESDIR}/${P}-freebsd.patch" + [[ $(gcc-major-version)$(gcc-minor-version) -ge 41 ]] && \ + epatch "${FILESDIR}/${P}-visibility.patch" - eautoreconf + AT_M4DIR="m4" eautoreconf } src_compile() { |