From 25f6a4277132293092d86b8c8376f864ed969126 Mon Sep 17 00:00:00 2001 From: Kevin Sapper Date: Tue, 10 Mar 2020 21:22:23 +0100 Subject: [PATCH 1/3] Problem: CMake release mode disables asserts by default Solution: Check for the NDEBUG flag and enforce asserts are always enabled as the ensure the invariants for method are fulfilled and programs don't run into unexpected behaviour when skipping them. --- zproject_class.gsl | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/zproject_class.gsl b/zproject_class.gsl index 77ac68f3..ddcd6d26 100644 --- a/zproject_class.gsl +++ b/zproject_class.gsl @@ -502,6 +502,16 @@ $(project.GENERATED_WARNING_HEADER:) // Platform definitions, must come first #include "platform.h" +// Asserts check the invariants of methods. If they're not +// fulfilled the program should fail fast. Therefore enforce them! +#ifdef NDEBUG + #undef NDEBUG + #include + #define NDEBUG +#else + #include +#endif + // External API #include "../include/$(project.header:)" From 63c0e621938acc388e1d27efdc917c11fc47d68c Mon Sep 17 00:00:00 2001 From: Kevin Sapper Date: Tue, 10 Mar 2020 21:30:32 +0100 Subject: [PATCH 2/3] Problem: Dependent JNI libs will not be build on windows travis ci Solution: If bindings/jni dir exists for dependency then build and publish the library --- zproject_travis.gsl | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/zproject_travis.gsl b/zproject_travis.gsl index 81a62d78..db486eba 100644 --- a/zproject_travis.gsl +++ b/zproject_travis.gsl @@ -818,6 +818,10 @@ windows) choco install openjdk export JAVA_HOME="C:\\Program Files\\OpenJDK\\jdk-13.0.2" export BUILD_PREFIX=$TEMP/ci_build + # Build will fail if processes are still running at the end of the script. + # Gradle by default starts a daemon so consequtive builds are faster. + # Therefore instruct gradle not to use its daemon. + export GRADLE_OPTS=-Dorg.gradle.daemon=false cd .. @@ -834,6 +838,12 @@ windows) cmake --build . --config Release --target install cd ../.. + if [ -d "$(use.project)/bindings/jni" ]; then + cd $(use.project)/bindings/jni + ./gradlew publishToMavenLocal -PbuildPrefix=$BUILD_PREFIX --info + cd ../../.. + fi + .endfor cd $(project.name) mkdir build @@ -845,10 +855,6 @@ windows) cd $(project.name) cd bindings/jni - # Build will fail if processes are still running at the end of the script. - # Gradle by default starts a daemon so consequtive builds are faster. - # Therefore instruct gradle not to use its daemon. - export GRADLE_OPTS=-Dorg.gradle.daemon=false ./gradlew build jar -PbuildPrefix=$BUILD_PREFIX -x test --info ./gradlew publishToMavenLocal -PbuildPrefix=$BUILD_PREFIX --info From a45d967b78ccfa831bc1df4a0363a94a95e95cde Mon Sep 17 00:00:00 2001 From: Luca Boccassi Date: Fri, 13 Mar 2020 10:03:16 +0000 Subject: [PATCH 3/3] Problem: zproject out of date with zproject Solution: regenerate --- CMakeLists.txt | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/CMakeLists.txt b/CMakeLists.txt index e5770065..02ccbec7 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -165,6 +165,13 @@ foreach(TEST_CLASS ${TEST_CLASSES}) NAME ${TEST_CLASS} COMMAND zproject_selftest --continue --verbose --test ${TEST_CLASS} ) + IF (WIN32 AND CMAKE_PREFIX_PATH) + file(TO_NATIVE_PATH "${CMAKE_PREFIX_PATH}" CMAKE_PREFIX_PATH_WIN) + set_tests_properties( + ${TEST_CLASS} + PROPERTIES ENVIRONMENT "PATH=%PATH%\;${CMAKE_PREFIX_PATH_WIN}\\bin" + ) + ENDIF (WIN32 AND CMAKE_PREFIX_PATH) set_tests_properties( ${TEST_CLASS} PROPERTIES TIMEOUT ${CLASSTEST_TIMEOUT}