#=============================================================================
# Copyright 2009 Kitware, Inc.
#
# Distributed under the OSI-approved BSD License (the "License");
# see accompanying file Copyright.txt for details.
#
# This software is distributed WITHOUT ANY WARRANTY; without even the
# implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
# See the License for more information.
#=============================================================================
# (To distribute this file outside of CMake, substitute the full
# License text for the above reference.)
# This file is included in CMakeSystemSpecificInformation.cmake if
# the Eclipse CDT4 extra generator has been selected.
FIND_PROGRAM ( CMAKE_ECLIPSE_EXECUTABLE NAMES eclipse DOC "The Eclipse executable" )
# This variable is used by the Eclipse generator and appended to the make invocation commands.
SET ( CMAKE_ECLIPSE_MAKE_ARGUMENTS "" CACHE STRING "Additional command line arguments when Eclipse invokes make. Enter e.g. -j<some_number> to get parallel builds" )
# This variable is used by the Eclipse generator in out-of-source builds only.
SET ( ECLIPSE_CDT4_GENERATE_SOURCE_PROJECT FALSE CACHE BOOL "If enabled, CMake will generate a source project for Eclipse in CMAKE_SOURCE_DIR" )
MARK_AS_ADVANCED ( ECLIPSE_CDT4_GENERATE_SOURCE_PROJECT )
# The Eclipse generator needs to know the standard include path
# so that Eclipse ca find the headers at runtime and parsing etc. works better
# This is done here by actually running gcc with the options so it prints its
# system include directories, which are parsed then and stored in the cache.
MACRO ( _DETERMINE_GCC_SYSTEM_INCLUDE_DIRS _lang _resultIncludeDirs _resultDefines )
SET ( ${ _resultIncludeDirs } )
SET ( _gccOutput )
FILE ( WRITE "${CMAKE_BINARY_DIR}/CMakeFiles/dummy" "\n" )
IF ( ${ _lang } STREQUAL "c++" )
SET ( _compilerExecutable "${CMAKE_CXX_COMPILER}" )
ELSE ( ${ _lang } STREQUAL "c++" )
SET ( _compilerExecutable "${CMAKE_C_COMPILER}" )
ENDIF ( ${ _lang } STREQUAL "c++" )
EXECUTE_PROCESS ( COMMAND ${ _compilerExecutable } -v -E -x ${ _lang } -dD dummy
W O R K I N G _ D I R E C T O R Y $ { C M A K E _ B I N A R Y _ D I R } / C M a k e F i l e s
E R R O R _ V A R I A B L E _ g c c O u t p u t
O U T P U T _ V A R I A B L E _ g c c S t d o u t )
FILE ( REMOVE "${CMAKE_BINARY_DIR}/CMakeFiles/dummy" )
# First find the system include dirs:
IF ( "${_gccOutput}" MATCHES "> search starts here[^\n]+\n *(.+ *\n) *End of (search) list" )
# split the output into lines and then remove leading and trailing spaces from each of them:
STRING ( REGEX MATCHALL "[^\n]+\n" _includeLines "${CMAKE_MATCH_1}" )
FOREACH ( nextLine ${ _includeLines } )
STRING ( STRIP "${nextLine}" _includePath )
LIST ( APPEND ${ _resultIncludeDirs } "${_includePath}" )
ENDFOREACH ( nextLine )
ENDIF ( "${_gccOutput}" MATCHES "> search starts here[^\n]+\n *(.+ *\n) *End of (search) list" )
# now find the builtin macros:
STRING ( REGEX MATCHALL "#define[^\n]+\n" _defineLines "${_gccStdout}" )
# A few example lines which the regexp below has to match properly:
# #define MAX(a,b) ((a) > (b) ? (a) : (b))
# #define __fastcall __attribute__((__fastcall__))
# #define FOO (23)
# #define __UINTMAX_TYPE__ long long unsigned int
# #define __UINTMAX_TYPE__ long long unsigned int
# #define __i386__ 1
FOREACH ( nextLine ${ _defineLines } )
STRING ( REGEX MATCH "^#define +([A-Za-z_][A-Za-z0-9_]*)(\\([^\\)]+\\))? +(.+) *$" _dummy "${nextLine}" )
SET ( _name "${CMAKE_MATCH_1}${CMAKE_MATCH_2}" )
STRING ( STRIP "${CMAKE_MATCH_3}" _value )
#MESSAGE(STATUS "m1: -${CMAKE_MATCH_1}- m2: -${CMAKE_MATCH_2}- m3: -${CMAKE_MATCH_3}-")
LIST ( APPEND ${ _resultDefines } "${_name}" )
IF ( _value )
LIST ( APPEND ${ _resultDefines } "${_value}" )
ELSE ( )
LIST ( APPEND ${ _resultDefines } " " )
ENDIF ( )
ENDFOREACH ( nextLine )
ENDMACRO ( _DETERMINE_GCC_SYSTEM_INCLUDE_DIRS _lang )
# Save the current LC_ALL, LC_MESSAGES, and LANG environment variables and set them
# to "C" that way GCC's "search starts here" text is in English and we can grok it.
SET ( _orig_lc_all $ENV{ LC_ALL } )
SET ( _orig_lc_messages $ENV{ LC_MESSAGES } )
SET ( _orig_lang $ENV{ LANG } )
IF ( _orig_lc_all )
SET ( ENV{LC_ALL} C )
ENDIF ( _orig_lc_all )
IF ( _orig_lc_messages )
SET ( ENV{LC_MESSAGES} C )
ENDIF ( _orig_lc_messages )
IF ( _orig_lang )
SET ( ENV{LANG} C )
ENDIF ( _orig_lang )
# Now check for C, works for gcc and Intel compiler at least
IF ( NOT CMAKE_ECLIPSE_C_SYSTEM_INCLUDE_DIRS )
IF ( "${CMAKE_C_COMPILER_ID}" MATCHES GNU OR "${CMAKE_C_COMPILER_ID}" MATCHES Intel )
_DETERMINE_GCC_SYSTEM_INCLUDE_DIRS ( c _dirs _defines )
SET ( CMAKE_ECLIPSE_C_SYSTEM_INCLUDE_DIRS "${_dirs}" CACHE INTERNAL "C compiler system include directories" )
SET ( CMAKE_ECLIPSE_C_SYSTEM_DEFINED_MACROS "${_defines}" CACHE INTERNAL "C compiler system defined macros" )
ENDIF ( "${CMAKE_C_COMPILER_ID}" MATCHES GNU OR "${CMAKE_C_COMPILER_ID}" MATCHES Intel )
ENDIF ( NOT CMAKE_ECLIPSE_C_SYSTEM_INCLUDE_DIRS )
# And now the same for C++
IF ( NOT CMAKE_ECLIPSE_CXX_SYSTEM_INCLUDE_DIRS )
IF ( "${CMAKE_CXX_COMPILER_ID}" MATCHES GNU OR "${CMAKE_CXX_COMPILER_ID}" MATCHES Intel )
_DETERMINE_GCC_SYSTEM_INCLUDE_DIRS ( c++ _dirs _defines )
SET ( CMAKE_ECLIPSE_CXX_SYSTEM_INCLUDE_DIRS "${_dirs}" CACHE INTERNAL "CXX compiler system include directories" )
SET ( CMAKE_ECLIPSE_CXX_SYSTEM_DEFINED_MACROS "${_defines}" CACHE INTERNAL "CXX compiler system defined macros" )
ENDIF ( "${CMAKE_CXX_COMPILER_ID}" MATCHES GNU OR "${CMAKE_CXX_COMPILER_ID}" MATCHES Intel )
ENDIF ( NOT CMAKE_ECLIPSE_CXX_SYSTEM_INCLUDE_DIRS )
# Restore original LC_ALL, LC_MESSAGES, and LANG
IF ( _orig_lc_all )
SET ( ENV{LC_ALL} ${ _orig_lc_all } )
ENDIF ( _orig_lc_all )
IF ( _orig_lc_messages )
SET ( ENV{LC_MESSAGES} ${ _orig_lc_messages } )
ENDIF ( _orig_lc_messages )
IF ( _orig_lang )
SET ( ENV{LANG} ${ _orig_lang } )
ENDIF ( _orig_lang )