summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlexander Neundorf <neundorf@kde.org>2007-07-12 19:00:37 (GMT)
committerAlexander Neundorf <neundorf@kde.org>2007-07-12 19:00:37 (GMT)
commit3e72dbe4c2dab284c563318abb8ae5966817a588 (patch)
treec08a5a5aafb02ccf7efa275f3d54f579a1fcb140
parentd090159318dc2d35e6f9d5568126b8d38c87320f (diff)
downloadCMake-3e72dbe4c2dab284c563318abb8ae5966817a588.zip
CMake-3e72dbe4c2dab284c563318abb8ae5966817a588.tar.gz
CMake-3e72dbe4c2dab284c563318abb8ae5966817a588.tar.bz2
ENH: add macro to test if a member has specified struct, e.g.
check_struct_has_member("struct stat" st_rdev "${CFG_HEADERS}" HAVE_STRUCT_STAT_ST_RDEV) Alex
-rw-r--r--Modules/CMakeLists.txt2
-rw-r--r--Modules/CheckStructHasMember.cmake39
2 files changed, 40 insertions, 1 deletions
diff --git a/Modules/CMakeLists.txt b/Modules/CMakeLists.txt
index c3b5903..c575043 100644
--- a/Modules/CMakeLists.txt
+++ b/Modules/CMakeLists.txt
@@ -1,5 +1,5 @@
# just install the modules
-# new file added, force rerunning cmake
+# new file added, force rerunning cmake #
SUBDIRS(Platform)
INSTALL_FILES(${CMAKE_DATA_DIR}/Modules .*\\.cmake$)
diff --git a/Modules/CheckStructHasMember.cmake b/Modules/CheckStructHasMember.cmake
new file mode 100644
index 0000000..f8a7d32
--- /dev/null
+++ b/Modules/CheckStructHasMember.cmake
@@ -0,0 +1,39 @@
+# - Check if the given struct or class has the specified member variable
+# CHECK_STRUCT_HAS_MEMBER (STRUCT MEMBER HEADER VARIABLE)
+#
+# STRUCT - the name of the struct or class you are interested in
+# MEMBER - the member which existence you want to check
+# HEADER - the header(s) where the prototype should be declared
+# VARIABLE - variable to store the result
+#
+# The following variables may be set before calling this macro to
+# modify the way the check is run:
+#
+# CMAKE_REQUIRED_FLAGS = string of compile command line flags
+# CMAKE_REQUIRED_DEFINITIONS = list of macros to define (-DFOO=bar)
+# CMAKE_REQUIRED_INCLUDES = list of include directories
+#
+# Example: CHECK_STRUCT_HAS_MEMBER("struct timeval" tv_sec sys/select.h HAVE_TIMEVAL_TV_SEC)
+
+
+INCLUDE(CheckCSourceCompiles)
+
+MACRO (CHECK_STRUCT_HAS_MEMBER _STRUCT _MEMBER _HEADER _RESULT)
+ SET(_INCLUDE_FILES)
+ FOREACH (it ${_HEADER})
+ SET(_INCLUDE_FILES "${_INCLUDE_FILES}#include <${it}>\n")
+ ENDFOREACH (it)
+
+ SET(_CHECK_STRUCT_MEMBER_SOURCE_CODE "
+${_INCLUDE_FILES}
+int main()
+{
+ ${_STRUCT}* tmp;
+ tmp->${_MEMBER};
+ return 0;
+}
+")
+ CHECK_C_SOURCE_COMPILES("${_CHECK_STRUCT_MEMBER_SOURCE_CODE}" ${_RESULT})
+
+ENDMACRO (CHECK_STRUCT_HAS_MEMBER)
+