Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/extern
diff options
context:
space:
mode:
authorSergey Sharybin <sergey.vfx@gmail.com>2014-03-25 13:07:19 +0400
committerSergey Sharybin <sergey.vfx@gmail.com>2014-03-25 13:08:22 +0400
commitcf148edb26d98d1b4a2c0b319c13223a0250092e (patch)
treec206cd20a9d9cae95022f36d36b79817700f9681 /extern
parentddc959691a41b4b151a7e9df0eb7267e2d8f77a3 (diff)
Followup to Ceres changes -- need to update bundling script
Diffstat (limited to 'extern')
-rwxr-xr-xextern/libmv/third_party/ceres/bundle.sh90
1 files changed, 25 insertions, 65 deletions
diff --git a/extern/libmv/third_party/ceres/bundle.sh b/extern/libmv/third_party/ceres/bundle.sh
index f6e60848907..7cb6b9beefd 100755
--- a/extern/libmv/third_party/ceres/bundle.sh
+++ b/extern/libmv/third_party/ceres/bundle.sh
@@ -174,60 +174,27 @@ if(WITH_OPENMP)
)
endif()
-include(CheckIncludeFileCXX)
-CHECK_INCLUDE_FILE_CXX(unordered_map HAVE_STD_UNORDERED_MAP_HEADER)
+TEST_UNORDERED_MAP_SUPPORT()
if(HAVE_STD_UNORDERED_MAP_HEADER)
- # Even so we've found unordered_map header file it doesn't
- # mean unordered_map and unordered_set will be declared in
- # std namespace.
- #
- # Namely, MSVC 2008 have unordered_map header which declares
- # unordered_map class in std::tr1 namespace. In order to support
- # this, we do extra check to see which exactly namespace is
- # to be used.
-
- include(CheckCXXSourceCompiles)
- CHECK_CXX_SOURCE_COMPILES("#include <unordered_map>
- int main() {
- std::unordered_map<int, int> map;
- return 0;
- }"
- HAVE_UNURDERED_MAP_IN_STD_NAMESPACE)
- if(HAVE_UNURDERED_MAP_IN_STD_NAMESPACE)
+ if(HAVE_UNORDERED_MAP_IN_STD_NAMESPACE)
add_definitions(-DCERES_STD_UNORDERED_MAP)
- message(STATUS "Found unordered_map/set in std namespace.")
else()
- CHECK_CXX_SOURCE_COMPILES("#include <unordered_map>
- int main() {
- std::tr1::unordered_map<int, int> map;
- return 0;
- }"
- HAVE_UNURDERED_MAP_IN_TR1_NAMESPACE)
- if(HAVE_UNURDERED_MAP_IN_TR1_NAMESPACE)
+ if(HAVE_UNORDERED_MAP_IN_TR1_NAMESPACE)
add_definitions(-DCERES_STD_UNORDERED_MAP_IN_TR1_NAMESPACE)
- message(STATUS "Found unordered_map/set in std::tr1 namespace.")
else()
- message(STATUS "Found <unordered_map> but cannot find either std::unordered_map "
- "or std::tr1::unordered_map.")
- message(STATUS "Replacing unordered_map/set with map/set (warning: slower!)")
add_definitions(-DCERES_NO_UNORDERED_MAP)
+ message(STATUS "Replacing unordered_map/set with map/set (warning: slower!)")
endif()
endif()
else()
- CHECK_INCLUDE_FILE_CXX("tr1/unordered_map" UNORDERED_MAP_IN_TR1_NAMESPACE)
- if(UNORDERED_MAP_IN_TR1_NAMESPACE)
+ if(HAVE_UNORDERED_MAP_IN_TR1_NAMESPACE)
add_definitions(-DCERES_TR1_UNORDERED_MAP)
- message(STATUS "Found unordered_map/set in std::tr1 namespace.")
else()
- message(STATUS "Unable to find <unordered_map> or <tr1/unordered_map>. ")
- message(STATUS "Replacing unordered_map/set with map/set (warning: slower!)")
add_definitions(-DCERES_NO_UNORDERED_MAP)
+ message(STATUS "Replacing unordered_map/set with map/set (warning: slower!)")
endif()
endif()
-unset(HAVE_UNURDERED_MAP_IN_TR1_NAMESPACE)
-unset(HAVE_STD_UNORDERED_MAP_HEADER)
-
blender_add_lib(extern_ceres "\${SRC}" "\${INC}" "\${INC_SYS}")
EOF
@@ -241,6 +208,8 @@ cat > SConscript << EOF
import sys
import os
+from unordered_map import test_unordered_map
+
Import('env')
src = []
@@ -261,35 +230,26 @@ defs.append('CERES_HAVE_RWLOCK')
if env['WITH_BF_OPENMP']:
defs.append('CERES_USE_OPENMP')
+def define_unordered_map(conf):
+ found, namespace, include_prefix = test_unordered_map(conf)
+ if found:
+ if not include_prefix:
+ if namespace == 'std':
+ defs.append('CERES_STD_UNORDERED_MAP')
+ return True
+ elif namespace == 'std::tr1':
+ defs.append('CERES_STD_UNORDERED_MAP_IN_TR1_NAMESPACE')
+ return True
+ else:
+ if namespace == 'std::tr1':
+ defs.append('CERES_TR1_UNORDERED_MAP')
+ return True
+ return False
+
conf = Configure(env)
-if conf.CheckCXXHeader("unordered_map"):
- # Even so we've found unordered_map header file it doesn't
- # mean unordered_map and unordered_set will be declared in
- # std namespace.
- #
- # Namely, MSVC 2008 have unordered_map header which declares
- # unordered_map class in std::tr1 namespace. In order to support
- # this, we do extra check to see which exactly namespace is
- # to be used.
-
- if conf.CheckType('std::unordered_map<int, int>', language = 'CXX', includes="#include <unordered_map>"):
- defs.append('CERES_STD_UNORDERED_MAP')
- print("-- Found unordered_map/set in std namespace.")
- elif conf.CheckType('std::tr1::unordered_map<int, int>', language = 'CXX', includes="#include <unordered_map>"):
- defs.append('CERES_STD_UNORDERED_MAP_IN_TR1_NAMESPACE')
- print("-- Found unordered_map/set in std::tr1 namespace.")
- else:
- print("-- Found <unordered_map> but can not find neither std::unordered_map nor std::tr1::unordered_map.")
- print("-- Replacing unordered_map/set with map/set (warning: slower!)")
- defs.append('CERES_NO_UNORDERED_MAP')
-elif conf.CheckCXXHeader("tr1/unordered_map"):
- defs.append('CERES_TR1_UNORDERED_MAP')
- print("-- Found unordered_map/set in std::tr1 namespace.")
-else:
- print("-- Unable to find <unordered_map> or <tr1/unordered_map>. ")
+if not define_unordered_map(conf):
print("-- Replacing unordered_map/set with map/set (warning: slower!)")
defs.append('CERES_NO_UNORDERED_MAP')
-
env = conf.Finish()
incs = '. ../../ ../../../Eigen3 ./include ./internal ../gflags'