mirror of
https://github.com/ThePhD/sol2.git
synced 2024-03-22 13:10:44 +08:00
these cmake details are starting to get unruly...
This commit is contained in:
parent
7056156273
commit
6f80e271d7
@ -63,10 +63,10 @@ if (MSVC)
|
|||||||
endif()
|
endif()
|
||||||
else()
|
else()
|
||||||
if (PLATFORM MATCHES "x86")
|
if (PLATFORM MATCHES "x86")
|
||||||
list(APPEND CMAKE_C_FLAGS "-m32")
|
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -m32")
|
||||||
list(APPEND CMAKE_CXX_FLAGS "-m32")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -m32")
|
||||||
list(APPEND CMAKE_EXE_LINKER_FLAGS "-m32")
|
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -m32")
|
||||||
list(APPEND CMAKE_SHARED_LINKER_FLAGS "-m32")
|
set(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -m32")
|
||||||
endif()
|
endif()
|
||||||
add_compile_options(-Wno-unknown-warning -Wno-unknown-warning-option -Wall -Wextra -Wpedantic -pedantic -pedantic-errors)
|
add_compile_options(-Wno-unknown-warning -Wno-unknown-warning-option -Wall -Wextra -Wpedantic -pedantic -pedantic-errors)
|
||||||
endif()
|
endif()
|
||||||
@ -110,6 +110,7 @@ set(PLATFORM "x64" CACHE STRING "Target platform to compile for when building bi
|
|||||||
option(CI "Enable build of tests" OFF)
|
option(CI "Enable build of tests" OFF)
|
||||||
option(TESTS "Enable build of tests" OFF)
|
option(TESTS "Enable build of tests" OFF)
|
||||||
option(EXAMPLES "Enable build of examples" OFF)
|
option(EXAMPLES "Enable build of examples" OFF)
|
||||||
|
option(INTEROP_EXAMPLES "Enable build of interop examples" OFF)
|
||||||
option(SINGLE "Enable build of single header files" ON)
|
option(SINGLE "Enable build of single header files" ON)
|
||||||
option(DOCS "Enable build of documentation" OFF)
|
option(DOCS "Enable build of documentation" OFF)
|
||||||
# Single tests and examples tests will only be turned on if both SINGLE and TESTS are defined
|
# Single tests and examples tests will only be turned on if both SINGLE and TESTS are defined
|
||||||
@ -117,8 +118,12 @@ CMAKE_DEPENDENT_OPTION(TESTS_SINGLE "Enable build of tests using the generated s
|
|||||||
"SINGLE;TESTS" OFF)
|
"SINGLE;TESTS" OFF)
|
||||||
CMAKE_DEPENDENT_OPTION(EXAMPLES_SINGLE "Enable build of examples using the generated single headers" OFF
|
CMAKE_DEPENDENT_OPTION(EXAMPLES_SINGLE "Enable build of examples using the generated single headers" OFF
|
||||||
"SINGLE;EXAMPLES" OFF)
|
"SINGLE;EXAMPLES" OFF)
|
||||||
|
CMAKE_DEPENDENT_OPTION(INTEROP_EXAMPLES_SINGLE "Enable build of examples using the generated single headers" OFF
|
||||||
|
"SINGLE;INTEROP_EXAMPLES" OFF)
|
||||||
CMAKE_DEPENDENT_OPTION(TESTS_EXAMPLES "Enable build of examples as tests" ON
|
CMAKE_DEPENDENT_OPTION(TESTS_EXAMPLES "Enable build of examples as tests" ON
|
||||||
"EXAMPLES" OFF)
|
"EXAMPLES" OFF)
|
||||||
|
CMAKE_DEPENDENT_OPTION(TESTS_INTEROP_EXAMPLES "Enable build of interop examples as tests" ON
|
||||||
|
"EXAMPLES;INTEROP_EXAMPLES" OFF)
|
||||||
|
|
||||||
|
|
||||||
# # # sol2 Library
|
# # # sol2 Library
|
||||||
@ -204,14 +209,14 @@ if (CI)
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
# # # Tests, Examples and other CI suites that come with sol2
|
# # # Tests, Examples and other CI suites that come with sol2
|
||||||
if (TESTS OR TESTS_SINGLE OR TESTS_EXAMPLES OR EXAMPLES OR EXAMPLES_SINGLE)
|
if (TESTS OR TESTS_SINGLE OR TESTS_EXAMPLES OR TESTS_INTEROP_EXAMPLES OR EXAMPLES OR EXAMPLES_SINGLE OR INTEROP_EXAMPLES)
|
||||||
# # # Libraries
|
# # # Libraries
|
||||||
# Here, we pull in all the necessary libraries for building examples and tests
|
# Here, we pull in all the necessary libraries for building examples and tests
|
||||||
# Find threading library
|
# Find threading library
|
||||||
if (NOT MSVC)
|
if (NOT MSVC)
|
||||||
set(THREADS_PREFER_PTHREAD_FLAG TRUE)
|
#set(THREADS_PREFER_PTHREAD_FLAG TRUE)
|
||||||
endif()
|
endif()
|
||||||
find_package(Threads)
|
find_package(Threads REQUIRED)
|
||||||
|
|
||||||
string(TOLOWER ${LUA_VERSION} NORMALIZED_LUA_VERSION)
|
string(TOLOWER ${LUA_VERSION} NORMALIZED_LUA_VERSION)
|
||||||
# Find way to get Lua: build if requested, or attempt to build if no matching version is found
|
# Find way to get Lua: build if requested, or attempt to build if no matching version is found
|
||||||
@ -238,7 +243,7 @@ if (TESTS OR TESTS_SINGLE OR TESTS_EXAMPLES OR EXAMPLES OR EXAMPLES_SINGLE)
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
# # Enable test harness for regular, example or single tests
|
# # Enable test harness for regular, example or single tests
|
||||||
if (TESTS OR TESTS_SINGLE OR TESTS_EXAMPLES)
|
if (TESTS OR TESTS_SINGLE OR TESTS_EXAMPLES OR TESTS_INTEROP_EXAMPLES)
|
||||||
# enable ctest
|
# enable ctest
|
||||||
message(STATUS "sol2 testing enabled")
|
message(STATUS "sol2 testing enabled")
|
||||||
enable_testing()
|
enable_testing()
|
||||||
@ -246,7 +251,7 @@ if (TESTS OR TESTS_SINGLE OR TESTS_EXAMPLES OR EXAMPLES OR EXAMPLES_SINGLE)
|
|||||||
|
|
||||||
# # # Examples
|
# # # Examples
|
||||||
# # Enable examples to be built against the library
|
# # Enable examples to be built against the library
|
||||||
if (EXAMPLES OR TESTS_EXAMPLES OR EXAMPLES_SINGLE)
|
if (EXAMPLES OR TESTS_EXAMPLES OR EXAMPLES_SINGLE OR INTEROP_EXAMPLES OR INTEROP_EXAMPLES_SINGLE OR TEST_INTEROP_EXAMPLES)
|
||||||
# NOTE: will also add to tests if TESTS is defined
|
# NOTE: will also add to tests if TESTS is defined
|
||||||
message(STATUS "sol2 adding examples...")
|
message(STATUS "sol2 adding examples...")
|
||||||
add_subdirectory(examples "${CMAKE_BINARY_DIR}/examples")
|
add_subdirectory(examples "${CMAKE_BINARY_DIR}/examples")
|
||||||
|
@ -186,13 +186,15 @@ else ()
|
|||||||
# make sure to apply -pagezero_size 10000 -image_base 100000000 (done later for XCode Targets)
|
# make sure to apply -pagezero_size 10000 -image_base 100000000 (done later for XCode Targets)
|
||||||
set(LUA_JIT_MAKE_BUILD_MODIFICATIONS "LUAJIT_T=${LUA_JIT_EXE_FILENAME}")
|
set(LUA_JIT_MAKE_BUILD_MODIFICATIONS "LUAJIT_T=${LUA_JIT_EXE_FILENAME}")
|
||||||
list(APPEND LUA_JIT_MAKE_BUILD_MODIFICATIONS "LUAJIT_A=${LUA_JIT_LIB_FILENAME}")
|
list(APPEND LUA_JIT_MAKE_BUILD_MODIFICATIONS "LUAJIT_A=${LUA_JIT_LIB_FILENAME}")
|
||||||
set(LUA_JIT_MAKE_CFLAGS_MODIFICATIONS "CFLAGS= ")
|
set(LUA_JIT_MAKE_CFLAGS_MODIFICATIONS "")
|
||||||
|
set(LUA_JIT_MAKE_HOST_CFLAGS_MODIFICATIONS "")
|
||||||
|
set(LUA_JIT_MAKE_TARGET_CFLAGS_MODIFICATIONS "")
|
||||||
if (BUILD_LUA_AS_DLL)
|
if (BUILD_LUA_AS_DLL)
|
||||||
list(APPEND LUA_JIT_MAKE_BUILD_MODIFICATIONS "LUAJIT_SO=${LUA_JIT_DLL_FILENAME}" "TARGET_SONAME=${LUA_JIT_DLL_FILENAME}" "TARGET_DYLIBNAME=${LUA_JIT_DLL_FILENAME}" "TARGET_DLLNAME=${LUA_JIT_DLL_FILENAME}")
|
list(APPEND LUA_JIT_MAKE_BUILD_MODIFICATIONS "LUAJIT_SO=${LUA_JIT_DLL_FILENAME}" "TARGET_SONAME=${LUA_JIT_DLL_FILENAME}" "TARGET_DYLIBNAME=${LUA_JIT_DLL_FILENAME}" "TARGET_DLLNAME=${LUA_JIT_DLL_FILENAME}")
|
||||||
list(APPEND LUA_JIT_MAKE_BUILD_MODIFICATIONS "BUILDMODE=dynamic")
|
list(APPEND LUA_JIT_MAKE_BUILD_MODIFICATIONS "BUILDMODE=dynamic")
|
||||||
else()
|
else()
|
||||||
list(APPEND LUA_JIT_MAKE_BUILD_MODIFICATIONS "BUILDMODE=static")
|
list(APPEND LUA_JIT_MAKE_BUILD_MODIFICATIONS "BUILDMODE=static")
|
||||||
set(LUA_JIT_MAKE_CFLAGS_MODIFICATIONS "${LUA_JIT_MAKE_CFLAGS_MODIFICATIONS}-fPIC ")
|
set(LUA_JIT_MAKE_TARGET_CFLAGS_MODIFICATIONS "${LUA_JIT_MAKE_TARGET_CFLAGS_MODIFICATIONS} -fPIC")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(LUA_JIT_PREBUILT_DLL ${LUA_JIT_DLL_FILENAME})
|
set(LUA_JIT_PREBUILT_DLL ${LUA_JIT_DLL_FILENAME})
|
||||||
@ -203,9 +205,12 @@ else ()
|
|||||||
list(APPEND LUA_JIT_MAKE_BUILD_MODIFICATIONS "HOST_SYS=Windows" "TARGET_SYS=Windows")
|
list(APPEND LUA_JIT_MAKE_BUILD_MODIFICATIONS "HOST_SYS=Windows" "TARGET_SYS=Windows")
|
||||||
endif()
|
endif()
|
||||||
if (PLATFORM MATCHES "x86")
|
if (PLATFORM MATCHES "x86")
|
||||||
set(LUA_JIT_MAKE_CFLAGS_MODIFICATIONS "${LUA_JIT_MAKE_CFLAGS_MODIFICATIONS}-m32 ")
|
set(LUA_JIT_MAKE_CFLAGS_MODIFICATIONS "${LUA_JIT_MAKE_CFLAGS_MODIFICATIONS} -m32")
|
||||||
|
set(LUA_JIT_MAKE_HOST_CFLAGS_MODIFICATIONS "${LUA_JIT_MAKE_HOST_CFLAGS_MODIFICATIONS} -m32")
|
||||||
endif()
|
endif()
|
||||||
list(APPEND LUA_JIT_MAKE_BUILD_MODIFICATIONS ${LUA_JIT_MAKE_CFLAGS_MODIFICATIONS})
|
list(APPEND LUA_JIT_MAKE_BUILD_MODIFICATIONS "CFLAGS=${LUA_JIT_MAKE_CFLAGS_MODIFICATIONS}")
|
||||||
|
list(APPEND LUA_JIT_MAKE_BUILD_MODIFICATIONS "TARGET_CFLAGS=${LUA_JIT_MAKE_TARGET_CFLAGS_MODIFICATIONS}")
|
||||||
|
list(APPEND LUA_JIT_MAKE_BUILD_MODIFICATIONS "HOST_CFLAGS=${LUA_JIT_MAKE_CFLAGS_MODIFICATIONS}")
|
||||||
|
|
||||||
set(LUA_JIT_BUILD_COMMAND BUILD_COMMAND "${MAKE_PROGRAM}" ${LUA_JIT_MAKE_BUILD_MODIFICATIONS})
|
set(LUA_JIT_BUILD_COMMAND BUILD_COMMAND "${MAKE_PROGRAM}" ${LUA_JIT_MAKE_BUILD_MODIFICATIONS})
|
||||||
endif()
|
endif()
|
||||||
|
@ -26,11 +26,13 @@
|
|||||||
# just add the subdirectory
|
# just add the subdirectory
|
||||||
add_subdirectory(require_dll_example)
|
add_subdirectory(require_dll_example)
|
||||||
|
|
||||||
# # interop examples
|
if (INTEROP_EXAMPLES)
|
||||||
add_subdirectory(interop/kaguya)
|
# # interop examples
|
||||||
add_subdirectory(interop/tolua)
|
add_subdirectory(interop/kaguya)
|
||||||
add_subdirectory(interop/LuaBridge)
|
add_subdirectory(interop/tolua)
|
||||||
add_subdirectory(interop/luwra)
|
add_subdirectory(interop/LuaBridge)
|
||||||
|
add_subdirectory(interop/luwra)
|
||||||
|
endif(INTEROP_EXAMPLES)
|
||||||
|
|
||||||
# # single-source compilable examples
|
# # single-source compilable examples
|
||||||
|
|
||||||
@ -86,12 +88,14 @@ function (MAKE_EXAMPLE example_source_file is_single)
|
|||||||
install(TARGETS ${example_name} RUNTIME DESTINATION bin)
|
install(TARGETS ${example_name} RUNTIME DESTINATION bin)
|
||||||
endfunction(MAKE_EXAMPLE)
|
endfunction(MAKE_EXAMPLE)
|
||||||
|
|
||||||
foreach(example_source_file ${EXAMPLES_SRC})
|
if (EXAMPLES)
|
||||||
|
foreach(example_source_file ${EXAMPLES_SRC})
|
||||||
MAKE_EXAMPLE(${example_source_file} FALSE)
|
MAKE_EXAMPLE(${example_source_file} FALSE)
|
||||||
endforeach()
|
endforeach()
|
||||||
|
|
||||||
if (SOL2_SINGLE_FOUND AND EXAMPLES_SINGLE)
|
if (SOL2_SINGLE_FOUND AND EXAMPLES_SINGLE)
|
||||||
foreach(example_source_file ${EXAMPLES_SRC})
|
foreach(example_source_file ${EXAMPLES_SRC})
|
||||||
MAKE_EXAMPLE(${example_source_file} TRUE)
|
MAKE_EXAMPLE(${example_source_file} TRUE)
|
||||||
endforeach()
|
endforeach()
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
@ -40,6 +40,6 @@ function (make_luabridge_interop_example target_library is_single)
|
|||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
make_luabridge_interop_example(sol2 FALSE)
|
make_luabridge_interop_example(sol2 FALSE)
|
||||||
if (TESTS_SINGLE)
|
if (SOL2_SINGLE_FOUND AND INTEROP_EXAMPLES_SINGLE)
|
||||||
make_luabridge_interop_example(sol2_single TRUE)
|
make_luabridge_interop_example(sol2_single TRUE)
|
||||||
endif()
|
endif()
|
||||||
|
@ -34,12 +34,12 @@ function (make_kaguya_interop_example target_library is_single)
|
|||||||
if (NOT MSVC)
|
if (NOT MSVC)
|
||||||
target_compile_options(${example_name} PRIVATE -Wno-noexcept-type)
|
target_compile_options(${example_name} PRIVATE -Wno-noexcept-type)
|
||||||
endif()
|
endif()
|
||||||
if (TESTS_EXAMPLES)
|
if (TESTS_INTEROP_EXAMPLES)
|
||||||
add_test(NAME ${example_name} COMMAND ${example_name})
|
add_test(NAME ${example_name} COMMAND ${example_name})
|
||||||
endif()
|
endif()
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
make_kaguya_interop_example(sol2 FALSE)
|
make_kaguya_interop_example(sol2 FALSE)
|
||||||
if (TESTS_SINGLE)
|
if (SOL2_SINGLE_FOUND AND INTEROP_EXAMPLES_SINGLE)
|
||||||
make_kaguya_interop_example(sol2_single TRUE)
|
make_kaguya_interop_example(sol2_single TRUE)
|
||||||
endif()
|
endif()
|
||||||
|
@ -40,6 +40,6 @@ function (make_luwra_interop_example target_library is_single)
|
|||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
make_luwra_interop_example(sol2 FALSE)
|
make_luwra_interop_example(sol2 FALSE)
|
||||||
if (TESTS_SINGLE)
|
if (SOL2_SINGLE_FOUND AND INTEROP_EXAMPLES_SINGLE)
|
||||||
make_luwra_interop_example(sol2_single TRUE)
|
make_luwra_interop_example(sol2_single TRUE)
|
||||||
endif()
|
endif()
|
||||||
|
@ -40,6 +40,6 @@ function(make_tolua_interop_example target_library is_single)
|
|||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
make_tolua_interop_example(sol2 FALSE)
|
make_tolua_interop_example(sol2 FALSE)
|
||||||
if (TESTS_SINGLE)
|
if (SOL2_SINGLE_FOUND AND INTEROP_EXAMPLES_SINGLE)
|
||||||
make_tolua_interop_example(sol2_single TRUE)
|
make_tolua_interop_example(sol2_single TRUE)
|
||||||
endif()
|
endif()
|
@ -50,6 +50,13 @@ echo -en "travis_fold:start:build_preparation.1\r"
|
|||||||
source ./sol2.compiler.vars
|
source ./sol2.compiler.vars
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [ ${LUA_VERSION} =~ '5.3' ]
|
||||||
|
then
|
||||||
|
export INTEROP_DEFINES=-DINTEROP_EXAMPLES=ON -DTESTS_INTEROP_EXAMPLES=ON -DINTEROP_EXAMPLES_SINGLE=ON
|
||||||
|
else
|
||||||
|
export INTEROP_DEFINES=
|
||||||
|
fi
|
||||||
|
|
||||||
mkdir -p Debug Release
|
mkdir -p Debug Release
|
||||||
|
|
||||||
export build_type_cc=-DCMAKE_C_COMPILER\=${CC}
|
export build_type_cc=-DCMAKE_C_COMPILER\=${CC}
|
||||||
@ -70,7 +77,7 @@ echo -en "travis_fold:end:build_preparation.2\r"
|
|||||||
|
|
||||||
echo -en "travis_fold:start:build.debug\r"
|
echo -en "travis_fold:start:build.debug\r"
|
||||||
cd Debug
|
cd Debug
|
||||||
cmake ${SOL2_DIR} -G Ninja -DCMAKE_BUILD_TYPE=Debug ${build_type_cc} ${build_type_cxx} -DLUA_VERSION="${LUA_VERSION}" -DCI=ON -DPLATFORM=${PLATFORM} -DBUILD_LUA=ON -DBUILD_LUA_AS_DLL=OFF -DTESTS=ON -DEXAMPLES=ON -DSINGLE=ON -DTESTS_EXAMPLES=ON -DEXAMPLES_SINGLE=ON -DTESTS_SINGLE=ON
|
cmake ${SOL2_DIR} -G Ninja -DCMAKE_BUILD_TYPE=Debug ${build_type_cc} ${build_type_cxx} -DLUA_VERSION="${LUA_VERSION}" -DCI=ON -DPLATFORM=${PLATFORM} -DBUILD_LUA=ON -DBUILD_LUA_AS_DLL=OFF -DTESTS=ON -DEXAMPLES=ON -DSINGLE=ON -DTESTS_EXAMPLES=ON -DEXAMPLES_SINGLE=ON -DTESTS_SINGLE=ON ${INTEROP_DEFINES}
|
||||||
cmake --build . --config Debug
|
cmake --build . --config Debug
|
||||||
echo -en "travis_fold:end:build.debug\r"
|
echo -en "travis_fold:end:build.debug\r"
|
||||||
echo -en "travis_fold:start:test.debug\r"
|
echo -en "travis_fold:start:test.debug\r"
|
||||||
@ -80,7 +87,7 @@ echo -en "travis_fold:end:test.debug\r"
|
|||||||
|
|
||||||
echo "travis_fold:start:build.release\r"
|
echo "travis_fold:start:build.release\r"
|
||||||
cd Release
|
cd Release
|
||||||
cmake ${SOL2_DIR} -G Ninja -DCMAKE_BUILD_TYPE=Release ${build_type_cc} ${build_type_cxx} -DLUA_VERSION="${LUA_VERSION}" -DCI=ON -DPLATFORM=${PLATFORM} -DBUILD_LUA=ON -DBUILD_LUA_AS_DLL=OFF -DTESTS=ON -DEXAMPLES=ON -DSINGLE=ON -DTESTS_EXAMPLES=ON -DEXAMPLES_SINGLE=ON -DTESTS_SINGLE=ON
|
cmake ${SOL2_DIR} -G Ninja -DCMAKE_BUILD_TYPE=Release ${build_type_cc} ${build_type_cxx} -DLUA_VERSION="${LUA_VERSION}" -DCI=ON -DPLATFORM=${PLATFORM} -DBUILD_LUA=ON -DBUILD_LUA_AS_DLL=OFF -DTESTS=ON -DEXAMPLES=ON -DSINGLE=ON -DTESTS_EXAMPLES=ON -DEXAMPLES_SINGLE=ON -DTESTS_SINGLE=ON ${INTEROP_DEFINES}
|
||||||
cmake --build . --config Release
|
cmake --build . --config Release
|
||||||
echo -en "travis_fold:end:build.release\r"
|
echo -en "travis_fold:end:build.release\r"
|
||||||
echo -en "travis_fold:start:test.release\r"
|
echo -en "travis_fold:start:test.release\r"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user