diff options
author | Andreas K. Hüttel <dilfridge@gentoo.org> | 2010-11-04 23:15:48 +0000 |
---|---|---|
committer | Andreas K. Hüttel <dilfridge@gentoo.org> | 2010-11-04 23:15:48 +0000 |
commit | 0d4558abf7bb8dccd7f8a214e6d9de29d8f57235 (patch) | |
tree | f759539790ad80bf0d36744187e90d80d7b4daff /media-video | |
parent | Stable x86 wrt bug 343947. (diff) | |
download | gentoo-2-0d4558abf7bb8dccd7f8a214e6d9de29d8f57235.tar.gz gentoo-2-0d4558abf7bb8dccd7f8a214e6d9de29d8f57235.tar.bz2 gentoo-2-0d4558abf7bb8dccd7f8a214e6d9de29d8f57235.zip |
Added upstream patch to build against system boost
(Portage version: 2.1.9.24/cvs/Linux x86_64)
Diffstat (limited to 'media-video')
-rw-r--r-- | media-video/bombono-dvd/ChangeLog | 7 | ||||
-rw-r--r-- | media-video/bombono-dvd/bombono-dvd-0.8.0.ebuild | 5 | ||||
-rw-r--r-- | media-video/bombono-dvd/files/bombono-dvd-0.8.0-boost.patch | 210 |
3 files changed, 220 insertions, 2 deletions
diff --git a/media-video/bombono-dvd/ChangeLog b/media-video/bombono-dvd/ChangeLog index c70c4a3478e2..edcf5cf8a497 100644 --- a/media-video/bombono-dvd/ChangeLog +++ b/media-video/bombono-dvd/ChangeLog @@ -1,6 +1,11 @@ # ChangeLog for media-video/bombono-dvd # Copyright 1999-2010 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/media-video/bombono-dvd/ChangeLog,v 1.4 2010/11/04 22:24:16 dilfridge Exp $ +# $Header: /var/cvsroot/gentoo-x86/media-video/bombono-dvd/ChangeLog,v 1.5 2010/11/04 23:15:48 dilfridge Exp $ + + 04 Nov 2010; Andreas K. Huettel <dilfridge@gentoo.org> + bombono-dvd-0.8.0.ebuild, +files/bombono-dvd-0.8.0-boost.patch: + Added upstream patch to build against system boost. Thanks to Ilya + Muravev, author of bombono-dvd, for the help! *bombono-dvd-0.8.0 (04 Nov 2010) diff --git a/media-video/bombono-dvd/bombono-dvd-0.8.0.ebuild b/media-video/bombono-dvd/bombono-dvd-0.8.0.ebuild index 7c824fdbdb99..9a3a71d21065 100644 --- a/media-video/bombono-dvd/bombono-dvd-0.8.0.ebuild +++ b/media-video/bombono-dvd/bombono-dvd-0.8.0.ebuild @@ -1,6 +1,6 @@ # Copyright 1999-2010 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 -# $Header: /var/cvsroot/gentoo-x86/media-video/bombono-dvd/bombono-dvd-0.8.0.ebuild,v 1.1 2010/11/04 22:24:16 dilfridge Exp $ +# $Header: /var/cvsroot/gentoo-x86/media-video/bombono-dvd/bombono-dvd-0.8.0.ebuild,v 1.2 2010/11/04 23:15:48 dilfridge Exp $ EAPI=2 @@ -30,12 +30,15 @@ RDEPEND=">=x11-libs/gtk+-2.8 DEPEND=">=dev-util/scons-0.96.1 ${RDEPEND}" +PATCHES=( "${FILESDIR}/${P}-boost.patch" ) + src_compile() { # scons options differ from make options -> remove everything except "-jX" and "-j X" local sconsopts=$(echo "${MAKEOPTS}" | sed -ne "/-j/ { s/.*\(-j[[:space:]]*[0-9]\+\).*/\1/; p }") scons CC="$(tc-getCC)" CXX="$(tc-getCXX)" CFLAGS="${CFLAGS}" CXXFLAGS="${CXXFLAGS}" \ LDFLAGS="${LDFLAGS}" ${sconsopts} DESTDIR="${D}" PREFIX="/usr" \ + CPPFLAGS='-UBOOST_SYSTEM_NO_DEPRECATED' USE_EXT_BOOST=1 \ || die 'Please add "${S}/config.opts" when filing bugs reports!' } diff --git a/media-video/bombono-dvd/files/bombono-dvd-0.8.0-boost.patch b/media-video/bombono-dvd/files/bombono-dvd-0.8.0-boost.patch new file mode 100644 index 000000000000..7e08da584446 --- /dev/null +++ b/media-video/bombono-dvd/files/bombono-dvd-0.8.0-boost.patch @@ -0,0 +1,210 @@ +diff --git a/SConstruct b/SConstruct +index fa391c9..4ca4bd1 100644 +--- a/SConstruct ++++ b/SConstruct +@@ -107,6 +107,13 @@ def CalcCommonFlags(): + '_ISOC99_SOURCE' # C99 extentions: snprintf() + ] + ++# ++# Users CPPFLAGS support ++# Because SCons cannot handle -U option (~ #undef) it is done via ++# additional variable named POST_CPPFLAGS ++# ++UserCppFlags = '' ++ + def AdjustConfigOptions(env): + CalcCommonFlags() + +@@ -130,6 +137,7 @@ def AdjustConfigOptions(env): + env.Append(CCFLAGS = BV.CFlags.split()) + env.Append(CXXFLAGS = BV.CxxFlags.split()) + env.Append(LINKFLAGS = BV.LdFlags.split()) ++ env.Append(POST_CPPFLAGS = UserCppFlags.split()) + + # :TODO: set them when need + #env.Replace (PATH = user_options_dict['PATH']) +@@ -185,9 +193,10 @@ def ParseVariables(user_options): + ('DESTDIR', 'Set the intermediate install directory.', ''), + ('CC', 'C compiler.'), + ('CXX', 'C++ compiler.'), +- ('CFLAGS', 'Extra C Compiler flags (for C++ too).', ''), +- ('CXXFLAGS','Extra C++ Compiler flags.', ''), +- ('LDFLAGS', 'Extra Linker flags.', ''), ++ ('CPPFLAGS','Extra CPP flags.', ''), ++ ('CFLAGS', 'Extra C Compiler flags (for C++ too).', ''), ++ ('CXXFLAGS','Extra C++ Compiler flags.', ''), ++ ('LDFLAGS', 'Extra Linker flags.', ''), + (BoolVariable('TEST', + 'Set to 1 if you want to build and run tests.', + 'false')), +@@ -230,6 +239,8 @@ def ParseVariables(user_options): + + BV.Cc = user_options_dict['CC'] + BV.Cxx = user_options_dict['CXX'] ++ global UserCppFlags ++ UserCppFlags = user_options_dict['CPPFLAGS'] + BV.CFlags = user_options_dict['CFLAGS'] + BV.CxxFlags = user_options_dict['CXXFLAGS'] + BV.LdFlags = user_options_dict['LDFLAGS'] +@@ -262,8 +273,10 @@ else: + user_options = Variables(None, BV.Args) + ParseVariables(user_options) + try: ++ def write_name_value(name, val): ++ config.write('%s = %r\n' % (name, val)) + def write_dict_value(name): +- config.write('%s = %r\n' % (name, user_options_dict[name])) ++ write_name_value(name, user_options_dict[name]) + + # save to file + config = open(BV.CfgFile, 'w') +@@ -280,6 +293,7 @@ else: + config.write('\n# Compiler information\n') + config.write('CC = %r\n' % (BV.Cc)) + config.write('CXX = %r\n' % (BV.Cxx)) ++ write_name_value('CPPFLAGS', UserCppFlags) + config.write('CFLAGS = %r\n' % (BV.CFlags)) + config.write('CXXFLAGS = %r\n' % (BV.CxxFlags)) + config.write('LDFLAGS = %r\n' % (BV.LdFlags)) +diff --git a/libs/SConscript b/libs/SConscript +index 043b809..bbb1072 100644 +--- a/libs/SConscript ++++ b/libs/SConscript +@@ -19,7 +19,7 @@ else: + + boost_dict = { 'LIBPATH' : user_options_dict['BOOST_LIBPATH'] } + if BV.IsToBuildQuick(): +- boost_dict['CPP_POST_FLAGS'] = BV.MakeIncludeOptions(user_options_dict['BOOST_INCLUDE'], 1) ++ boost_dict['POST_CPPINCFLAGS'] = BV.MakeIncludeOptions(user_options_dict['BOOST_INCLUDE'], 1) + else: + boost_dict['CPPPATH'] = user_options_dict['BOOST_INCLUDE'] + if not embedded_boost: +diff --git a/src/mgui/author/render.cpp b/src/mgui/author/render.cpp +index c91a244..4310898 100644 +--- a/src/mgui/author/render.cpp ++++ b/src/mgui/author/render.cpp +@@ -453,6 +453,17 @@ static void FFmpegError(const std::string& msg) + Author::Error(FFmpegErrorTemplate(), msg); + } + ++static std::string errno2str() ++{ ++ namespace bs = boost::system; ++#if BOOST_MINOR_VERSION >= 44 ++ const bs::error_category& s_cat = bs::system_category(); ++#else ++ const bs::error_category& s_cat = bs::system_category; // = bs::get_system_category(); ++#endif ++ return bs::error_code(errno, s_cat).message(); ++} ++ + static void WriteAsPPM(int fd, RefPtr<Gdk::Pixbuf> pix, TrackBuf& buf) + { + int wdh = pix->get_width(); +@@ -491,10 +502,7 @@ static void WriteAsPPM(int fd, RefPtr<Gdk::Pixbuf> pix, TrackBuf& buf) + ASSERT( cur - beg == sz ); + //checked_writeall(fd, beg, sz); + if( !writeall(fd, beg, sz) ) +- { +- namespace bs = boost::system; +- FFmpegError(bs::error_code(errno, bs::system_category()).message()); +- } ++ FFmpegError(errno2str()); + } + + std::string FFmpegPostArgs(const std::string& out_fname, bool is_4_3, bool is_pal, +diff --git a/src/mlib/tech.h b/src/mlib/tech.h +index 771c463..0cd9867 100644 +--- a/src/mlib/tech.h ++++ b/src/mlib/tech.h +@@ -27,6 +27,7 @@ + // + #include <boost/current_function.hpp> // для BOOST_CURRENT_FUNCTION + #include <boost/detail/endian.hpp> // для BOOST_XXX_ENDIAN ++#include <boost/version.hpp> // для BOOST_MINOR_VERSION + + // для С-шного кода в С++ + #if defined(__cplusplus) || defined(c_plusplus) +@@ -85,6 +86,8 @@ void AssertImpl(const char* assertion, const char* file, + # error mlib/tech.h: unknown endianness (legacy PDP arch?) + #endif + ++#define BOOST_MINOR_VERSION (BOOST_VERSION / 100 % 1000) ++ + // gcc 4.4 вываливает кучу предупреждений о strict-alias rules + // (только при >= -O2), но чувствую, что неправильно + +diff --git a/src/mlib/tests/turn_on_test_main.h b/src/mlib/tests/turn_on_test_main.h +index fa3e545..f67e4aa 100644 +--- a/src/mlib/tests/turn_on_test_main.h ++++ b/src/mlib/tests/turn_on_test_main.h +@@ -22,12 +22,12 @@ + #ifndef __MLIB_TESTS_TEST_TOTM_H__ + #define __MLIB_TESTS_TEST_TOTM_H__ + +-#include <boost/version.hpp> ++#include <mlib/tech.h> + + // + // for Boost > 1.33 dynamic version begin to be built + // +-#if BOOST_VERSION / 100 % 1000 > 33 ++#if BOOST_MINOR_VERSION > 33 + # ifndef STILL_HAVE_STATIC_BOOST_WITH_MAIN + # define BOOST_TEST_DYN_LINK + # endif +diff --git a/tools/scripts/BuildVars.py b/tools/scripts/BuildVars.py +index fe992e4..59408ac 100644 +--- a/tools/scripts/BuildVars.py ++++ b/tools/scripts/BuildVars.py +@@ -458,12 +458,12 @@ def MakeIncludeOptions(dir_list, to_convert=0): + + def MoveIncludeOptions(dict): + if 'CPPPATH' in dict.keys(): +- dict['CPP_POST_FLAGS'] = MakeIncludeOptions(dict['CPPPATH']) ++ dict['POST_CPPINCFLAGS'] = MakeIncludeOptions(dict['CPPPATH']) + del dict['CPPPATH'] + + def GetDict(name): + dict = UserOptDict[MakeDictName(name)] +- #reduce SCons' C scanner area, CPPPATH -> CPP_POST_FLAGS ++ #reduce SCons' C scanner area, CPPPATH -> POST_CPPINCFLAGS + if IsToBuildQuick(): + MoveIncludeOptions(dict) + return dict +@@ -499,6 +499,9 @@ def IsToBuildQuick(): + + return res + ++def ExtendEnvVariable(env, name, add_name): ++ env[name] = '%s $%s' % (env[name], add_name) ++ + def CreateEnvVersion2(**kw): + tools = ['default', 'AuxTools'] + if kw.has_key('tools'): +@@ -514,6 +517,12 @@ def CreateEnvVersion2(**kw): + # thin archives ('T' option) are to speed up static libraries build + # :TRICKY: libmpeg2.a and etc have to be built directly to build/lib (withour copying/symlinking) + env.Replace(ARFLAGS = str(env['ARFLAGS']) + 'T') ++ ++ # User defines ++ # it is cosmetically better to place POST_CPPFLAGS just after _CPPDEFFLAGS ++ # but 1) extending _CPPDEFFLAGS is bad such way 2) it still works ++ ExtendEnvVariable(env, '_CCCOMCOM', 'POST_CPPFLAGS') ++ + return env + + def MakeMainEnv(): +@@ -562,8 +571,9 @@ def MakeMainEnv(): + suffix = '.pch' if is_clang else '.gch' + env['GCHSUFFIX'] = suffix + +- # 2 - reduce SCons' C scanner area, CPPPATH -> CPP_POST_FLAGS +- env['_CPPINCFLAGS'] = env['_CPPINCFLAGS'] + ' $CPP_POST_FLAGS' ++ # 2 - reduce SCons' C scanner area, CPPPATH -> POST_CPPINCFLAGS ++ #env['_CPPINCFLAGS'] = env['_CPPINCFLAGS'] + ' $POST_CPPINCFLAGS' ++ ExtendEnvVariable(env, '_CPPINCFLAGS', 'POST_CPPINCFLAGS') + else: + def SetPCH(env, header_name, additional_envs=[]): + pass |