From d5e229702a7bfd39b548109a1797da8905b66fc5 Mon Sep 17 00:00:00 2001 From: Marius Kintel Date: Sun, 6 Nov 2011 21:54:17 +0100 Subject: Compile common sources into static libs to shorten compilation time diff --git a/tests/CMakeLists.txt b/tests/CMakeLists.txt index fb007cc..6b1383b 100644 --- a/tests/CMakeLists.txt +++ b/tests/CMakeLists.txt @@ -151,6 +151,12 @@ BISON_TARGET(OpenSCADparser ../src/parser.y ${CMAKE_CURRENT_BINARY_DIR}/parser_y ADD_FLEX_BISON_DEPENDENCY(OpenSCADlexer OpenSCADparser) set_source_files_properties(${CMAKE_CURRENT_BINARY_DIR}/parser_yacc.c PROPERTIES LANGUAGE "CXX") +if (NOT $ENV{MACOSX_DEPLOY_DIR} STREQUAL "") + set(CGAL_DIR "$ENV{MACOSX_DEPLOY_DIR}/lib/CGAL") + set(CMAKE_MODULE_PATH "${CGAL_DIR}") +endif() +find_package(CGAL REQUIRED) +include_directories(${CGAL_INCLUDE_DIRS}) # Internal includes include_directories(../src) @@ -180,9 +186,7 @@ set(CORE_SOURCES ../src/surface.cc ../src/control.cc ../src/render.cc - ../src/import.cc ../src/dxfdata.cc - ../src/dxftess.cc ../src/dxfdim.cc ../src/linearextrude.cc ../src/rotateextrude.cc @@ -191,23 +195,31 @@ set(CORE_SOURCES ${FLEX_OpenSCADlexer_OUTPUTS} ${BISON_OpenSCADparser_OUTPUTS}) +set(NOCGAL_SOURCES + ../src/dxftess.cc + ../src/import.cc + ../src/export.cc) + +set(CGAL_SOURCES + ${NOCGAL_SOURCES} + ../src/CSGTermEvaluator.cc + ../src/CGAL_Nef_polyhedron.cc + ../src/cgalutils.cc + ../src/CGALEvaluator.cc + ../src/CGALCache.cc + ../src/PolySetCGALEvaluator.cc + ../src/qhash.cc + ../src/CGAL_Nef_polyhedron_DxfData.cc + ../src/cgaladv_minkowski2.cc + ../src/cgaladv_convexhull2.cc) + set(COMMON_SOURCES - ${CORE_SOURCES} - ../src/export.cc ../src/nodedumper.cc ../src/traverser.cc ../src/PolySetEvaluator.cc ../src/PolySetCache.cc ../src/Tree.cc - lodepng.cpp - ${FLEX_OpenSCADlexer_OUTPUTS} - ${BISON_OpenSCADparser_OUTPUTS}) - -# -# echotest -# -add_executable(echotest echotest.cc ${CORE_SOURCES}) -target_link_libraries(echotest ${QT_LIBRARIES} ${OPENGL_LIBRARY}) + lodepng.cpp) # # Offscreen OpenGL context source code @@ -223,6 +235,29 @@ elseif(WIN32) set(OFFSCREEN_CTX_SOURCE "OffscreenContextWGL.cc") endif() +set(OFFSCREEN_SOURCES + OffscreenView.cc + ${OFFSCREEN_CTX_SOURCE} + imageutils.cc + fbo.cc + system-gl.cc) + +add_library(tests-core STATIC ${CORE_SOURCES}) +add_library(tests-common STATIC ${COMMON_SOURCES}) +target_link_libraries(tests-common tests-core) +add_library(tests-cgal STATIC ${CGAL_SOURCES}) +set_target_properties(tests-cgal PROPERTIES COMPILE_FLAGS "-DENABLE_CGAL ${CGAL_CXX_FLAGS_INIT}") +target_link_libraries(tests-cgal tests-common) +add_library(tests-nocgal STATIC ${NOCGAL_SOURCES}) +target_link_libraries(tests-nocgal tests-common) +add_library(tests-offscreen STATIC ${OFFSCREEN_SOURCES}) + +# +# echotest +# +add_executable(echotest echotest.cc) +target_link_libraries(echotest tests-nocgal tests-core ${QT_LIBRARIES} ${OPENGL_LIBRARY}) + # # Yangli Hector Yee's PerceptualDiff code # @@ -232,75 +267,50 @@ add_executable(yee_compare yee_compare.cpp lodepng.cpp) # # dumptest # -add_executable(dumptest dumptest.cc ${COMMON_SOURCES}) -target_link_libraries(dumptest ${QT_LIBRARIES} ${OPENGL_LIBRARY}) +add_executable(dumptest dumptest.cc) +target_link_libraries(dumptest tests-common tests-nocgal ${QT_LIBRARIES} ${OPENGL_LIBRARY}) # # csgtexttest # -add_executable(csgtexttest csgtexttest.cc CSGTextRenderer.cc CSGTextCache.cc ../src/qhash.cc ${COMMON_SOURCES}) -target_link_libraries(csgtexttest ${QT_LIBRARIES} ${OPENGL_LIBRARY}) +add_executable(csgtexttest csgtexttest.cc CSGTextRenderer.cc CSGTextCache.cc ../src/qhash.cc) +target_link_libraries(csgtexttest tests-common tests-nocgal ${QT_LIBRARIES} ${OPENGL_LIBRARY}) # # csgtermtest # -add_executable(csgtermtest csgtermtest.cc ../src/CSGTermEvaluator.cc ${COMMON_SOURCES}) -target_link_libraries(csgtermtest ${QT_LIBRARIES} ${OPENGL_LIBRARY}) - -if (NOT $ENV{MACOSX_DEPLOY_DIR} STREQUAL "") - set(CGAL_DIR "$ENV{MACOSX_DEPLOY_DIR}/lib/CGAL") - set(CMAKE_MODULE_PATH "${CGAL_DIR}") -endif() -find_package(CGAL REQUIRED) -include_directories(${CGAL_INCLUDE_DIRS}) +add_executable(csgtermtest csgtermtest.cc ../src/CSGTermEvaluator.cc) +target_link_libraries(csgtermtest tests-common tests-nocgal ${QT_LIBRARIES} ${OPENGL_LIBRARY}) # # cgaltest # -add_executable(cgaltest cgaltest.cc ../src/CGAL_Nef_polyhedron.cc ../src/cgalutils.cc ../src/CSGTermEvaluator.cc - ../src/CGALEvaluator.cc ../src/CGALCache.cc ../src/PolySetCGALEvaluator.cc ../src/qhash.cc - ../src/CGAL_Nef_polyhedron_DxfData.cc ../src/cgaladv_minkowski2.cc ../src/cgaladv_convexhull2.cc - ${COMMON_SOURCES}) +add_executable(cgaltest cgaltest.cc) set_target_properties(cgaltest PROPERTIES COMPILE_FLAGS "-DENABLE_CGAL ${CGAL_CXX_FLAGS_INIT}") -target_link_libraries(cgaltest ${CGAL_LIBRARY} ${CGAL_3RD_PARTY_LIBRARIES} ${QT_LIBRARIES} ${OPENGL_LIBRARY}) +target_link_libraries(cgaltest tests-cgal ${CGAL_LIBRARY} ${CGAL_3RD_PARTY_LIBRARIES} ${QT_LIBRARIES} ${OPENGL_LIBRARY}) # # cgalpngtest # -add_executable(cgalpngtest cgalpngtest.cc OffscreenView.cc bboxhelp.cc ${OFFSCREEN_CTX_SOURCE} imageutils.cc fbo.cc system-gl.cc - ../src/CGALRenderer.cc ../src/CGAL_Nef_polyhedron.cc ../src/cgalutils.cc - ../src/CSGTermEvaluator.cc ../src/CGALEvaluator.cc ../src/CGALCache.cc - ../src/PolySetCGALEvaluator.cc ../src/qhash.cc - ../src/CGAL_Nef_polyhedron_DxfData.cc ../src/cgaladv_minkowski2.cc ../src/cgaladv_convexhull2.cc - ${COMMON_SOURCES}) +add_executable(cgalpngtest cgalpngtest.cc bboxhelp.cc ../src/CGALRenderer.cc) set_target_properties(cgalpngtest PROPERTIES COMPILE_FLAGS "-DENABLE_CGAL ${CGAL_CXX_FLAGS_INIT}") -target_link_libraries(cgalpngtest ${CGAL_LIBRARY} ${CGAL_3RD_PARTY_LIBRARIES} ${QT_LIBRARIES} ${GLEW_LIBRARY} ${COCOA_LIBRARY} ${OPENGL_LIBRARY}) +target_link_libraries(cgalpngtest tests-offscreen tests-cgal ${CGAL_LIBRARY} ${CGAL_3RD_PARTY_LIBRARIES} ${QT_LIBRARIES} ${GLEW_LIBRARY} ${COCOA_LIBRARY} ${OPENGL_LIBRARY}) # # opencsgtest # -add_executable(opencsgtest opencsgtest.cc csgtestcore.cc OffscreenView.cc ${OFFSCREEN_CTX_SOURCE} imageutils.cc fbo.cc system-gl.cc - ../src/OpenCSGRenderer.cc ../src/ThrownTogetherRenderer.cc - ../src/CSGTermEvaluator.cc ../src/CGAL_Nef_polyhedron.cc ../src/cgalutils.cc - ../src/CGALEvaluator.cc ../src/CGALCache.cc ../src/PolySetCGALEvaluator.cc ../src/qhash.cc - ../src/CGAL_Nef_polyhedron_DxfData.cc ../src/cgaladv_minkowski2.cc ../src/cgaladv_convexhull2.cc - ${COMMON_SOURCES}) +add_executable(opencsgtest opencsgtest.cc csgtestcore.cc ../src/OpenCSGRenderer.cc ../src/ThrownTogetherRenderer.cc) set_target_properties(opencsgtest PROPERTIES COMPILE_FLAGS "-DENABLE_OPENCSG -DENABLE_CGAL ${CGAL_CXX_FLAGS_INIT}") -target_link_libraries(opencsgtest ${CGAL_LIBRARY} ${CGAL_3RD_PARTY_LIBRARIES} ${QT_LIBRARIES} ${OPENCSG_LIBRARY} ${GLEW_LIBRARY} ${COCOA_LIBRARY} ${OPENGL_LIBRARY}) +target_link_libraries(opencsgtest tests-offscreen tests-cgal ${CGAL_LIBRARY} ${CGAL_3RD_PARTY_LIBRARIES} ${QT_LIBRARIES} ${OPENCSG_LIBRARY} ${GLEW_LIBRARY} ${COCOA_LIBRARY} ${OPENGL_LIBRARY}) # # throwntogethertest # -add_executable(throwntogethertest throwntogethertest.cc csgtestcore.cc OffscreenView.cc ${OFFSCREEN_CTX_SOURCE} imageutils.cc fbo.cc system-gl.cc - ../src/OpenCSGRenderer.cc ../src/ThrownTogetherRenderer.cc - ../src/CSGTermEvaluator.cc ../src/CGAL_Nef_polyhedron.cc ../src/cgalutils.cc - ../src/CGALEvaluator.cc ../src/CGALCache.cc ../src/PolySetCGALEvaluator.cc ../src/qhash.cc - ../src/CGAL_Nef_polyhedron_DxfData.cc ../src/cgaladv_minkowski2.cc ../src/cgaladv_convexhull2.cc - ${COMMON_SOURCES}) +add_executable(throwntogethertest throwntogethertest.cc csgtestcore.cc ../src/OpenCSGRenderer.cc ../src/ThrownTogetherRenderer.cc) set_target_properties(throwntogethertest PROPERTIES COMPILE_FLAGS "-DENABLE_OPENCSG -DENABLE_CGAL ${CGAL_CXX_FLAGS_INIT}") -target_link_libraries(throwntogethertest ${CGAL_LIBRARY} ${CGAL_3RD_PARTY_LIBRARIES} ${QT_LIBRARIES} ${OPENCSG_LIBRARY} ${GLEW_LIBRARY} ${COCOA_LIBRARY} ${OPENGL_LIBRARY}) +target_link_libraries(throwntogethertest tests-offscreen tests-cgal ${CGAL_LIBRARY} ${CGAL_3RD_PARTY_LIBRARIES} ${QT_LIBRARIES} ${OPENCSG_LIBRARY} ${GLEW_LIBRARY} ${COCOA_LIBRARY} ${OPENGL_LIBRARY}) # -- cgit v0.10.1 From 04c77e156041e1de5250305c36cf0e983c80888e Mon Sep 17 00:00:00 2001 From: Marius Kintel Date: Sun, 6 Nov 2011 21:54:48 +0100 Subject: Ignore *.a diff --git a/tests/.gitignore b/tests/.gitignore index 6b839c5..8ad2fdc 100644 --- a/tests/.gitignore +++ b/tests/.gitignore @@ -1,3 +1,4 @@ +*.a *-output CMakeFiles CMakeCache.txt -- cgit v0.10.1 From 5c502e51d4a1ffac56e898e619247d52269d14bd Mon Sep 17 00:00:00 2001 From: Marius Kintel Date: Sun, 6 Nov 2011 21:52:49 +0100 Subject: dependency fix; order of linkage diff --git a/tests/CMakeLists.txt b/tests/CMakeLists.txt index 6b1383b..7cfaf9d 100644 --- a/tests/CMakeLists.txt +++ b/tests/CMakeLists.txt @@ -173,7 +173,6 @@ set(CORE_SOURCES ../src/func.cc ../src/module.cc ../src/node.cc - ../src/builtin.cc ../src/context.cc ../src/csgterm.cc ../src/polyset.cc @@ -196,6 +195,7 @@ set(CORE_SOURCES ${BISON_OpenSCADparser_OUTPUTS}) set(NOCGAL_SOURCES + ../src/builtin.cc ../src/dxftess.cc ../src/import.cc ../src/export.cc) -- cgit v0.10.1