Date: Tue, 10 Sep 2013 15:40:27 +0000 (UTC) From: Baptiste Daroussin <bapt@FreeBSD.org> To: ports-committers@freebsd.org, svn-ports-all@freebsd.org, svn-ports-head@freebsd.org Subject: svn commit: r326912 - in head/graphics: opencv-core opencv/files Message-ID: <201309101540.r8AFeRqN006164@svn.freebsd.org>
next in thread | raw e-mail | index | archive | help
Author: bapt Date: Tue Sep 10 15:40:26 2013 New Revision: 326912 URL: http://svnweb.freebsd.org/changeset/ports/326912 Log: Fix opencv-core with libc++ Submitted by: theraven Added: head/graphics/opencv/files/patch-modules__ts__include__opencv2__ts__ts_gtest.h (contents, props changed) Modified: head/graphics/opencv-core/Makefile Modified: head/graphics/opencv-core/Makefile ============================================================================== --- head/graphics/opencv-core/Makefile Tue Sep 10 15:31:48 2013 (r326911) +++ head/graphics/opencv-core/Makefile Tue Sep 10 15:40:26 2013 (r326912) @@ -4,4 +4,9 @@ _BUILDING_OPENCV_CORE= yes MASTERDIR= ${.CURDIR}/../opencv +_COMPVERSION!= ${CC} --version +.if ${_COMPVERSION:Mclang} +CXXFLAGS+= -std=gnu++11 -Wno-error -Wno-c++11-narrowing +.endif + .include "${MASTERDIR}/Makefile" Added: head/graphics/opencv/files/patch-modules__ts__include__opencv2__ts__ts_gtest.h ============================================================================== --- /dev/null 00:00:00 1970 (empty, because file is newly added) +++ head/graphics/opencv/files/patch-modules__ts__include__opencv2__ts__ts_gtest.h Tue Sep 10 15:40:26 2013 (r326912) @@ -0,0 +1,268 @@ +--- ./modules/ts/include/opencv2/ts/ts_gtest.h.orig 2013-09-01 01:03:57.000000000 +0100 ++++ ./modules/ts/include/opencv2/ts/ts_gtest.h 2013-09-01 01:03:38.000000000 +0100 +@@ -53,6 +53,7 @@ + + #include <limits> + #include <vector> ++#include <unistd.h> + + // Copyright 2005, Google Inc. + // All rights reserved. +@@ -543,7 +544,7 @@ + // Author: wan@google.com (Zhanyong Wan) + + // Implements a subset of TR1 tuple needed by Google Test and Google Mock. +- ++#define GTEST_INCLUDE_GTEST_INTERNAL_GTEST_TUPLE_H_ 1 + #ifndef GTEST_INCLUDE_GTEST_INTERNAL_GTEST_TUPLE_H_ + #define GTEST_INCLUDE_GTEST_INTERNAL_GTEST_TUPLE_H_ + +@@ -1504,11 +1505,31 @@ + // <tr1/functional>. Hence the following #define is a hack to prevent + // <tr1/functional> from being included. + #define _TR1_FUNCTIONAL 1 ++#if __has_include(<tuple>) ++#include <tuple> ++namespace gtest { ++ using ::std::tuple; ++} ++#else + #include <tr1/tuple> ++namespace gtest { ++ using ::std::tr1::tuple; ++} ++#endif + #undef _TR1_FUNCTIONAL // Allows the user to #include + // <tr1/functional> if he chooses to. + #else +-#include <tr1/tuple> // NOLINT ++#if __has_include(<tuple>) ++#include <tuple> ++namespace gtest { ++ using ::std::tuple; ++} ++#else ++#include <tr1/tuple> ++namespace gtest { ++ using ::std::tr1::tuple; ++} ++#endif + #endif // !GTEST_HAS_RTTI && GTEST_GCC_VER_ < 40302 + + #else +@@ -11951,9 +11972,9 @@ + // + template <typename T1, typename T2> + class CartesianProductGenerator2 +- : public ParamGeneratorInterface< ::std::tr1::tuple<T1, T2> > { ++ : public ParamGeneratorInterface< gtest::tuple<T1, T2> > { + public: +- typedef ::std::tr1::tuple<T1, T2> ParamType; ++ typedef gtest::tuple<T1, T2> ParamType; + + CartesianProductGenerator2(const ParamGenerator<T1>& g1, + const ParamGenerator<T2>& g2) +@@ -12066,9 +12087,9 @@ + + template <typename T1, typename T2, typename T3> + class CartesianProductGenerator3 +- : public ParamGeneratorInterface< ::std::tr1::tuple<T1, T2, T3> > { ++ : public ParamGeneratorInterface< gtest::tuple<T1, T2, T3> > { + public: +- typedef ::std::tr1::tuple<T1, T2, T3> ParamType; ++ typedef gtest::tuple<T1, T2, T3> ParamType; + + CartesianProductGenerator3(const ParamGenerator<T1>& g1, + const ParamGenerator<T2>& g2, const ParamGenerator<T3>& g3) +@@ -12198,9 +12219,9 @@ + + template <typename T1, typename T2, typename T3, typename T4> + class CartesianProductGenerator4 +- : public ParamGeneratorInterface< ::std::tr1::tuple<T1, T2, T3, T4> > { ++ : public ParamGeneratorInterface< gtest::tuple<T1, T2, T3, T4> > { + public: +- typedef ::std::tr1::tuple<T1, T2, T3, T4> ParamType; ++ typedef gtest::tuple<T1, T2, T3, T4> ParamType; + + CartesianProductGenerator4(const ParamGenerator<T1>& g1, + const ParamGenerator<T2>& g2, const ParamGenerator<T3>& g3, +@@ -12349,9 +12370,9 @@ + + template <typename T1, typename T2, typename T3, typename T4, typename T5> + class CartesianProductGenerator5 +- : public ParamGeneratorInterface< ::std::tr1::tuple<T1, T2, T3, T4, T5> > { ++ : public ParamGeneratorInterface< gtest::tuple<T1, T2, T3, T4, T5> > { + public: +- typedef ::std::tr1::tuple<T1, T2, T3, T4, T5> ParamType; ++ typedef gtest::tuple<T1, T2, T3, T4, T5> ParamType; + + CartesianProductGenerator5(const ParamGenerator<T1>& g1, + const ParamGenerator<T2>& g2, const ParamGenerator<T3>& g3, +@@ -12517,10 +12538,10 @@ + template <typename T1, typename T2, typename T3, typename T4, typename T5, + typename T6> + class CartesianProductGenerator6 +- : public ParamGeneratorInterface< ::std::tr1::tuple<T1, T2, T3, T4, T5, ++ : public ParamGeneratorInterface< gtest::tuple<T1, T2, T3, T4, T5, + T6> > { + public: +- typedef ::std::tr1::tuple<T1, T2, T3, T4, T5, T6> ParamType; ++ typedef gtest::tuple<T1, T2, T3, T4, T5, T6> ParamType; + + CartesianProductGenerator6(const ParamGenerator<T1>& g1, + const ParamGenerator<T2>& g2, const ParamGenerator<T3>& g3, +@@ -12703,10 +12724,10 @@ + template <typename T1, typename T2, typename T3, typename T4, typename T5, + typename T6, typename T7> + class CartesianProductGenerator7 +- : public ParamGeneratorInterface< ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, ++ : public ParamGeneratorInterface< gtest::tuple<T1, T2, T3, T4, T5, T6, + T7> > { + public: +- typedef ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, T7> ParamType; ++ typedef gtest::tuple<T1, T2, T3, T4, T5, T6, T7> ParamType; + + CartesianProductGenerator7(const ParamGenerator<T1>& g1, + const ParamGenerator<T2>& g2, const ParamGenerator<T3>& g3, +@@ -12906,10 +12927,10 @@ + template <typename T1, typename T2, typename T3, typename T4, typename T5, + typename T6, typename T7, typename T8> + class CartesianProductGenerator8 +- : public ParamGeneratorInterface< ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, ++ : public ParamGeneratorInterface< gtest::tuple<T1, T2, T3, T4, T5, T6, + T7, T8> > { + public: +- typedef ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, T7, T8> ParamType; ++ typedef gtest::tuple<T1, T2, T3, T4, T5, T6, T7, T8> ParamType; + + CartesianProductGenerator8(const ParamGenerator<T1>& g1, + const ParamGenerator<T2>& g2, const ParamGenerator<T3>& g3, +@@ -13128,10 +13149,10 @@ + template <typename T1, typename T2, typename T3, typename T4, typename T5, + typename T6, typename T7, typename T8, typename T9> + class CartesianProductGenerator9 +- : public ParamGeneratorInterface< ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, ++ : public ParamGeneratorInterface< gtest::tuple<T1, T2, T3, T4, T5, T6, + T7, T8, T9> > { + public: +- typedef ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, T7, T8, T9> ParamType; ++ typedef gtest::tuple<T1, T2, T3, T4, T5, T6, T7, T8, T9> ParamType; + + CartesianProductGenerator9(const ParamGenerator<T1>& g1, + const ParamGenerator<T2>& g2, const ParamGenerator<T3>& g3, +@@ -13367,10 +13388,10 @@ + template <typename T1, typename T2, typename T3, typename T4, typename T5, + typename T6, typename T7, typename T8, typename T9, typename T10> + class CartesianProductGenerator10 +- : public ParamGeneratorInterface< ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, ++ : public ParamGeneratorInterface< gtest::tuple<T1, T2, T3, T4, T5, T6, + T7, T8, T9, T10> > { + public: +- typedef ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> ParamType; ++ typedef gtest::tuple<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> ParamType; + + CartesianProductGenerator10(const ParamGenerator<T1>& g1, + const ParamGenerator<T2>& g2, const ParamGenerator<T3>& g3, +@@ -13632,8 +13653,8 @@ + CartesianProductHolder2(const Generator1& g1, const Generator2& g2) + : g1_(g1), g2_(g2) {} + template <typename T1, typename T2> +- operator ParamGenerator< ::std::tr1::tuple<T1, T2> >() const { +- return ParamGenerator< ::std::tr1::tuple<T1, T2> >( ++ operator ParamGenerator< gtest::tuple<T1, T2> >() const { ++ return ParamGenerator< gtest::tuple<T1, T2> >( + new CartesianProductGenerator2<T1, T2>( + static_cast<ParamGenerator<T1> >(g1_), + static_cast<ParamGenerator<T2> >(g2_))); +@@ -13654,8 +13675,8 @@ + const Generator3& g3) + : g1_(g1), g2_(g2), g3_(g3) {} + template <typename T1, typename T2, typename T3> +- operator ParamGenerator< ::std::tr1::tuple<T1, T2, T3> >() const { +- return ParamGenerator< ::std::tr1::tuple<T1, T2, T3> >( ++ operator ParamGenerator< gtest::tuple<T1, T2, T3> >() const { ++ return ParamGenerator< gtest::tuple<T1, T2, T3> >( + new CartesianProductGenerator3<T1, T2, T3>( + static_cast<ParamGenerator<T1> >(g1_), + static_cast<ParamGenerator<T2> >(g2_), +@@ -13679,8 +13700,8 @@ + const Generator3& g3, const Generator4& g4) + : g1_(g1), g2_(g2), g3_(g3), g4_(g4) {} + template <typename T1, typename T2, typename T3, typename T4> +- operator ParamGenerator< ::std::tr1::tuple<T1, T2, T3, T4> >() const { +- return ParamGenerator< ::std::tr1::tuple<T1, T2, T3, T4> >( ++ operator ParamGenerator< gtest::tuple<T1, T2, T3, T4> >() const { ++ return ParamGenerator< gtest::tuple<T1, T2, T3, T4> >( + new CartesianProductGenerator4<T1, T2, T3, T4>( + static_cast<ParamGenerator<T1> >(g1_), + static_cast<ParamGenerator<T2> >(g2_), +@@ -13706,8 +13727,8 @@ + const Generator3& g3, const Generator4& g4, const Generator5& g5) + : g1_(g1), g2_(g2), g3_(g3), g4_(g4), g5_(g5) {} + template <typename T1, typename T2, typename T3, typename T4, typename T5> +- operator ParamGenerator< ::std::tr1::tuple<T1, T2, T3, T4, T5> >() const { +- return ParamGenerator< ::std::tr1::tuple<T1, T2, T3, T4, T5> >( ++ operator ParamGenerator< gtest::tuple<T1, T2, T3, T4, T5> >() const { ++ return ParamGenerator< gtest::tuple<T1, T2, T3, T4, T5> >( + new CartesianProductGenerator5<T1, T2, T3, T4, T5>( + static_cast<ParamGenerator<T1> >(g1_), + static_cast<ParamGenerator<T2> >(g2_), +@@ -13737,8 +13758,8 @@ + : g1_(g1), g2_(g2), g3_(g3), g4_(g4), g5_(g5), g6_(g6) {} + template <typename T1, typename T2, typename T3, typename T4, typename T5, + typename T6> +- operator ParamGenerator< ::std::tr1::tuple<T1, T2, T3, T4, T5, T6> >() const { +- return ParamGenerator< ::std::tr1::tuple<T1, T2, T3, T4, T5, T6> >( ++ operator ParamGenerator< gtest::tuple<T1, T2, T3, T4, T5, T6> >() const { ++ return ParamGenerator< gtest::tuple<T1, T2, T3, T4, T5, T6> >( + new CartesianProductGenerator6<T1, T2, T3, T4, T5, T6>( + static_cast<ParamGenerator<T1> >(g1_), + static_cast<ParamGenerator<T2> >(g2_), +@@ -13770,9 +13791,9 @@ + : g1_(g1), g2_(g2), g3_(g3), g4_(g4), g5_(g5), g6_(g6), g7_(g7) {} + template <typename T1, typename T2, typename T3, typename T4, typename T5, + typename T6, typename T7> +- operator ParamGenerator< ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, ++ operator ParamGenerator< gtest::tuple<T1, T2, T3, T4, T5, T6, + T7> >() const { +- return ParamGenerator< ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, T7> >( ++ return ParamGenerator< gtest::tuple<T1, T2, T3, T4, T5, T6, T7> >( + new CartesianProductGenerator7<T1, T2, T3, T4, T5, T6, T7>( + static_cast<ParamGenerator<T1> >(g1_), + static_cast<ParamGenerator<T2> >(g2_), +@@ -13808,9 +13829,9 @@ + g8_(g8) {} + template <typename T1, typename T2, typename T3, typename T4, typename T5, + typename T6, typename T7, typename T8> +- operator ParamGenerator< ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, T7, ++ operator ParamGenerator< gtest::tuple<T1, T2, T3, T4, T5, T6, T7, + T8> >() const { +- return ParamGenerator< ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, T7, T8> >( ++ return ParamGenerator< gtest::tuple<T1, T2, T3, T4, T5, T6, T7, T8> >( + new CartesianProductGenerator8<T1, T2, T3, T4, T5, T6, T7, T8>( + static_cast<ParamGenerator<T1> >(g1_), + static_cast<ParamGenerator<T2> >(g2_), +@@ -13849,9 +13870,9 @@ + g9_(g9) {} + template <typename T1, typename T2, typename T3, typename T4, typename T5, + typename T6, typename T7, typename T8, typename T9> +- operator ParamGenerator< ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, T7, T8, ++ operator ParamGenerator< gtest::tuple<T1, T2, T3, T4, T5, T6, T7, T8, + T9> >() const { +- return ParamGenerator< ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, T7, T8, ++ return ParamGenerator< gtest::tuple<T1, T2, T3, T4, T5, T6, T7, T8, + T9> >( + new CartesianProductGenerator9<T1, T2, T3, T4, T5, T6, T7, T8, T9>( + static_cast<ParamGenerator<T1> >(g1_), +@@ -13893,9 +13914,9 @@ + g9_(g9), g10_(g10) {} + template <typename T1, typename T2, typename T3, typename T4, typename T5, + typename T6, typename T7, typename T8, typename T9, typename T10> +- operator ParamGenerator< ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, T7, T8, ++ operator ParamGenerator< gtest::tuple<T1, T2, T3, T4, T5, T6, T7, T8, + T9, T10> >() const { +- return ParamGenerator< ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, T7, T8, ++ return ParamGenerator< gtest::tuple<T1, T2, T3, T4, T5, T6, T7, T8, + T9, T10> >( + new CartesianProductGenerator10<T1, T2, T3, T4, T5, T6, T7, T8, T9, + T10>(
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201309101540.r8AFeRqN006164>