diff options
Diffstat (limited to 'Tests/LoadCommand')
-rw-r--r-- | Tests/LoadCommand/CMakeLists.txt | 6 | ||||
-rw-r--r-- | Tests/LoadCommand/LoadedCommand.cxx | 33 | ||||
-rw-r--r-- | Tests/LoadCommand/LoadedCommand.h.in | 3 |
3 files changed, 28 insertions, 14 deletions
diff --git a/Tests/LoadCommand/CMakeLists.txt b/Tests/LoadCommand/CMakeLists.txt index 1d261be..f69d292 100644 --- a/Tests/LoadCommand/CMakeLists.txt +++ b/Tests/LoadCommand/CMakeLists.txt @@ -5,6 +5,7 @@ SET (TEST_COMMAND_TEST1 1) INCLUDE (${CMAKE_ROOT}/Modules/CheckTypeSize.cmake) CHECK_TYPE_SIZE(char SIZEOF_CHAR) +CHECK_TYPE_SIZE(short SIZEOF_SHORT) INCLUDE (CheckFunctionExists) CHECK_FUNCTION_EXISTS(printf HAVE_PRINTF) @@ -55,8 +56,9 @@ ELSE (COMPILE_OK) MESSAGE("failed to compile CMAKE_LOADED_COMMANDS") ENDIF (COMPILE_OK) -IF (TEST_DEF) +# TEST_DEF is set by the loaded command cmTestCommand.c +IF (TEST_DEF AND SOME_CACHE_VARIABLE) ADD_DEFINITIONS(-DCMAKE_IS_FUN) -ENDIF (TEST_DEF) +ENDIF (TEST_DEF AND SOME_CACHE_VARIABLE) ADD_EXECUTABLE (LoadedCommand LoadedCommand.cxx) diff --git a/Tests/LoadCommand/LoadedCommand.cxx b/Tests/LoadCommand/LoadedCommand.cxx index 04daff0..c58bcf1 100644 --- a/Tests/LoadCommand/LoadedCommand.cxx +++ b/Tests/LoadCommand/LoadedCommand.cxx @@ -1,30 +1,41 @@ #include "LoadedCommand.h" #include <stdio.h> +int testSizeOf(int s1, int s2) +{ + return s1 - s2; +} + int main () { + int ret = 0; #ifdef HAVE_VSBLABLA printf("Should not be able to find vsblabla\n"); - return 1; + ret = 1; #endif #if !defined( HAVE_PRINTF ) printf("Should be able to find printf\n"); - return 1; + ret= 1; #endif #if !defined( ADDED_DEFINITION ) printf("Should have ADDED_DEFINITION defined\n"); - return 1; + ret= 1; +#endif +#if !defined(CMAKE_IS_FUN) + printf("Loaded Command was not built with CMAKE_IS_FUN: failed.\n"); + ret = 1; #endif - if(SIZEOF_CHAR != 1) + if(testSizeOf(SIZEOF_CHAR, sizeof(char))) { - printf("Size of char is not one, something is broken\n"); + printf("Size of char is broken.\n"); + ret = 1; } - -#ifdef CMAKE_IS_FUN - return SIZEOF_CHAR-1; -#else - return SIZEOF_SHORT; -#endif + if(testSizeOf(SIZEOF_SHORT, sizeof(short))) + { + printf("Size of short is broken.\n"); + ret = 1; + } + return ret; } diff --git a/Tests/LoadCommand/LoadedCommand.h.in b/Tests/LoadCommand/LoadedCommand.h.in index b910e49..7a0a15d 100644 --- a/Tests/LoadCommand/LoadedCommand.h.in +++ b/Tests/LoadCommand/LoadedCommand.h.in @@ -1,5 +1,6 @@ /* Check for size of types */ #cmakedefine SIZEOF_CHAR ${SIZEOF_CHAR} +#cmakedefine SIZEOF_SHORT ${SIZEOF_SHORT} /* Check for functions */ #cmakedefine HAVE_PRINTF @@ -9,4 +10,4 @@ #cmakedefine HAVE_SYS_PRCTL_H /* Check for libraries */ -#cmakedefine HAVE_LIBM
\ No newline at end of file +#cmakedefine HAVE_LIBM |