summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlbrecht Schlosser <albrechts.fltk@online.de>2022-04-09 17:19:20 +0200
committerAlbrecht Schlosser <albrechts.fltk@online.de>2022-04-09 17:19:20 +0200
commit9e147fe8c0eb94d3781300a2f52bc1855f7f98e2 (patch)
treeeb8d7d8a894099d64e7b2dc8c601fa5f8bca16dc
parent223bf6309b8591843246a966fe5ed23dbab34110 (diff)
Fix build of test/unittests with shared libraries
- set variables UNITTEST_LIBS and UNITTEST_LIBS_SHARED appropriately - use these variables in build instructions This includes normal and shared builds with and w/o OpenGL.
-rw-r--r--test/CMakeLists.txt33
1 files changed, 19 insertions, 14 deletions
diff --git a/test/CMakeLists.txt b/test/CMakeLists.txt
index f52af5cba..7e295e879 100644
--- a/test/CMakeLists.txt
+++ b/test/CMakeLists.txt
@@ -139,6 +139,13 @@ CREATE_EXAMPLE (tile tile.cxx fltk)
CREATE_EXAMPLE (tiled_image tiled_image.cxx fltk)
CREATE_EXAMPLE (tree tree.fl fltk)
CREATE_EXAMPLE (twowin twowin.cxx fltk)
+CREATE_EXAMPLE (utf8 utf8.cxx fltk)
+CREATE_EXAMPLE (valuators valuators.fl fltk)
+CREATE_EXAMPLE (windowfocus windowfocus.cxx fltk)
+CREATE_EXAMPLE (wizard wizard.cxx fltk)
+
+# unittests uses multiple source files and can be built with or w/o OpenGL and "shared"
+
SET (UNITTEST_SRCS
unittests.cxx
unittest_about.cxx
@@ -155,20 +162,18 @@ SET (UNITTEST_SRCS
unittest_simple_terminal.cxx
)
if (OPENGL_FOUND)
- CREATE_EXAMPLE (unittests "${UNITTEST_SRCS}" "fltk_gl;fltk;${OPENGL_LIBRARIES}") # opt. Fl_Gl_Window
-else()
- CREATE_EXAMPLE (unittests "${UNITTEST_SRCS}" fltk) # w/o Fl_Gl_Window
-endif()
-CREATE_EXAMPLE (utf8 utf8.cxx fltk)
-CREATE_EXAMPLE (valuators valuators.fl fltk)
-CREATE_EXAMPLE (windowfocus windowfocus.cxx fltk)
-CREATE_EXAMPLE (wizard wizard.cxx fltk)
+ set (UNITTEST_LIBS fltk_gl fltk ${OPENGL_LIBRARIES})
+ set (UNITTEST_LIBS_SHARED fltk_gl_SHARED fltk_SHARED ${OPENGL_LIBRARIES})
+else ()
+ set (UNITTEST_LIBS fltk)
+ set (UNITTEST_LIBS_SHARED fltk_SHARED)
+endif ()
+CREATE_EXAMPLE (unittests "${UNITTEST_SRCS}" "${UNITTEST_LIBS}")
# create additional test programs (used by developers for testing)
+
if (extra_tests)
- # message ("")
foreach (name ${extra_tests})
- # message (STATUS "Will build additional test program ${name}")
create_example (${name} ${name}.cxx "fltk_images;fltk_gl;fltk")
endforeach ()
endif ()
@@ -213,11 +218,11 @@ if (OPTION_BUILD_SHARED_LIBS)
add_library (CALL_MAIN OBJECT EXCLUDE_FROM_ALL ../src/fl_call_main.c)
# define a list of shared targets so we can set COMPILE_DEFINITIONS in a loop
- set (SHARED_TARGETS)
+ set (SHARED_TARGETS "")
CREATE_EXAMPLE (hello-shared hello.cxx "fltk_SHARED;CALL_MAIN")
CREATE_EXAMPLE (pixmap_browser-shared pixmap_browser.cxx "fltk_SHARED;CALL_MAIN")
- CREATE_EXAMPLE (unittests-shared unittests.cxx "fltk_SHARED;CALL_MAIN")
+ CREATE_EXAMPLE (unittests-shared "${UNITTEST_SRCS}" "${UNITTEST_LIBS_SHARED};CALL_MAIN")
list (APPEND SHARED_TARGETS hello pixmap_browser unittests)
@@ -229,7 +234,7 @@ if (OPTION_BUILD_SHARED_LIBS)
endif (OPENGL_FOUND)
- # apply property COMPILE_DEFINITIONS in a loop for all necessary source files
+ # apply property COMPILE_DEFINITIONS "-D FL_DLL" in a loop for all necessary source files
foreach (tgt ${SHARED_TARGETS})
target_compile_definitions (${tgt}-shared PRIVATE "FL_DLL")
endforeach ()
@@ -238,7 +243,7 @@ if (OPTION_BUILD_SHARED_LIBS)
CREATE_EXAMPLE (hello-shared hello.cxx fltk_SHARED)
CREATE_EXAMPLE (pixmap_browser-shared pixmap_browser.cxx "fltk_images_SHARED;fltk_SHARED")
- CREATE_EXAMPLE (unittests-shared unittests.cxx fltk_SHARED)
+ CREATE_EXAMPLE (unittests-shared "${UNITTEST_SRCS}" "${UNITTEST_LIBS_SHARED}")
if (OPENGL_FOUND)
CREATE_EXAMPLE (glpuzzle-shared glpuzzle.cxx "fltk_gl_SHARED;fltk_SHARED;${OPENGL_LIBRARIES}")