|
|
@@ -6,12 +6,21 @@
|
|
|
# as a default compiler
|
|
|
|
|
|
IF(NOT CMAKE_C_COMPILER)
|
|
|
- FIND_PROGRAM(CMAKE_C_COMPILER_FULLPATH NAMES $ENV{CC} ${CMAKE_GENERATOR_CC} gcc cc cl bcc )
|
|
|
- GET_FILENAME_COMPONENT(CMAKE_C_COMPILER ${CMAKE_C_COMPILER_FULLPATH} NAME)
|
|
|
+ SET(CMAKE_C_COMPILER_LIST ${CMAKE_GENERATOR_CC} gcc cc cl bcc )
|
|
|
+ IF($ENV{CC} MATCHES ".+")
|
|
|
+ SET(CMAKE_C_COMPILER_LIST $ENV{CXX})
|
|
|
+ ENDIF($ENV{CC} MATCHES ".+")
|
|
|
+ FIND_PROGRAM(CMAKE_C_COMPILER_FULLPATH NAMES ${CMAKE_C_COMPILER_LIST} )
|
|
|
+ GET_FILENAME_COMPONENT(CMAKE_C_COMPILER_INIT
|
|
|
+ ${CMAKE_C_COMPILER_FULLPATH} NAME)
|
|
|
# set this to notfound right after so that it is searched for each time this
|
|
|
# file is included
|
|
|
- SET(CMAKE_C_COMPILER_FULLPATH NOTFOUND CACHE INTERNAL "full path to c compiler" FORCE)
|
|
|
- SET(CMAKE_C_COMPILER ${CMAKE_C_COMPILER} CACHE STRING "C++ compiler")
|
|
|
+ SET(CMAKE_C_COMPILER ${CMAKE_C_COMPILER_INIT} CACHE STRING "C compiler")
|
|
|
+ IF($ENV{CC} MATCHES ".+")
|
|
|
+ IF(NOT CMAKE_C_COMPILER)
|
|
|
+ MESSAGE(SEND_ERROR "Could not find compiler set in environment variable CC:\n$ENV{CC}, make sure CC does not have flags in it, use CFLAGS instead.")
|
|
|
+ ENDIF(NOT CMAKE_C_COMPILER)
|
|
|
+ ENDIF($ENV{CC} MATCHES ".+")
|
|
|
ENDIF(NOT CMAKE_C_COMPILER)
|
|
|
MARK_AS_ADVANCED(CMAKE_C_COMPILER)
|
|
|
FIND_PROGRAM(CMAKE_AR NAMES ar PATHS /bin /usr/bin /usr/local/bin)
|
|
|
@@ -25,7 +34,7 @@ MARK_AS_ADVANCED(CMAKE_RANLIB)
|
|
|
EXEC_PROGRAM(${CMAKE_C_COMPILER} ARGS -E ${CMAKE_ROOT}/Modules/CMakeTestGNU.c OUTPUT_VARIABLE CMAKE_COMPILER_OUTPUT RETURN_VALUE CMAKE_COMPILER_RETURN)
|
|
|
IF(NOT CMAKE_COMPILER_RETURN)
|
|
|
IF(${CMAKE_COMPILER_OUTPUT} MATCHES ".*THIS_IS_GNU.*" )
|
|
|
- SET(CMAKE_COMPILER_IS_GNUGCC 1)
|
|
|
+ SET(CMAKE_COMPILER_IS_GNUCC 1)
|
|
|
ENDIF(${CMAKE_COMPILER_OUTPUT} MATCHES ".*THIS_IS_GNU.*" )
|
|
|
ENDIF(NOT CMAKE_COMPILER_RETURN)
|
|
|
|