[Cmake-commits] [cmake-commits] david.cole committed FindMFC.cmake 1.5 1.6

cmake-commits at cmake.org cmake-commits at cmake.org
Fri Oct 10 17:43:58 EDT 2008


Update of /cvsroot/CMake/CMake/Modules
In directory public:/mounts/ram/cvs-serv7359

Modified Files:
	FindMFC.cmake 
Log Message:
BUG: Fix for issue #5193. Base result of FindMFC.cmake mostly on a TRY_COMPILE result. Gives accurate answer about whether MFC is available.


Index: FindMFC.cmake
===================================================================
RCS file: /cvsroot/CMake/CMake/Modules/FindMFC.cmake,v
retrieving revision 1.5
retrieving revision 1.6
diff -C 2 -d -r1.5 -r1.6
*** FindMFC.cmake	15 Dec 2005 19:17:42 -0000	1.5
--- FindMFC.cmake	10 Oct 2008 21:43:56 -0000	1.6
***************
*** 1,19 ****
  # - Find MFC on Windows
! # Find the native MFC - i.e. decide if this is an MS VC box.
  #  MFC_FOUND - Was MFC support found
  # You don't need to include anything or link anything to use it.
  
  # Assume no MFC support
! SET( MFC_FOUND "NO" )
! # Add MFC support if win32 and not cygwin and not borland
! IF( WIN32 )
!   IF( NOT CYGWIN )
!     IF( NOT BORLAND )
!       IF( NOT MINGW )
!         SET( MFC_FOUND "YES" )
!       ENDIF( NOT MINGW )
!     ENDIF( NOT BORLAND )
!   ENDIF( NOT CYGWIN )
! ENDIF( WIN32 )
  
  
--- 1,47 ----
  # - Find MFC on Windows
! # Find the native MFC - i.e. decide if an application can link to the MFC
! # libraries.
  #  MFC_FOUND - Was MFC support found
  # You don't need to include anything or link anything to use it.
  
  # Assume no MFC support
! SET(MFC_FOUND "NO")
  
+ # Only attempt the try_compile call if it has a chance to succeed:
+ SET(MFC_ATTEMPT_TRY_COMPILE 0)
+ IF(WIN32 AND NOT UNIX AND NOT BORLAND AND NOT MINGW)
+   SET(MFC_ATTEMPT_TRY_COMPILE 1)
+ ENDIF(WIN32 AND NOT UNIX AND NOT BORLAND AND NOT MINGW)
+ 
+ IF(MFC_ATTEMPT_TRY_COMPILE)
+   IF("MFC_HAVE_MFC" MATCHES "^MFC_HAVE_MFC$")
+     SET(CHECK_INCLUDE_FILE_VAR "afxwin.h")
+     CONFIGURE_FILE(${CMAKE_ROOT}/Modules/CheckIncludeFile.cxx.in
+       ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/CheckIncludeFile.cxx)
+     MESSAGE(STATUS "Looking for MFC")
+     TRY_COMPILE(MFC_HAVE_MFC
+       ${CMAKE_BINARY_DIR}
+       ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/CheckIncludeFile.cxx
+       CMAKE_FLAGS
+       -DCMAKE_MFC_FLAG:STRING=2
+       -DCOMPILE_DEFINITIONS:STRING=-D_AFXDLL
+       OUTPUT_VARIABLE OUTPUT)
+     IF(MFC_HAVE_MFC)
+       MESSAGE(STATUS "Looking for MFC - found")
+       SET(MFC_HAVE_MFC 1 CACHE INTERNAL "Have MFC?")
+       FILE(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeOutput.log
+         "Determining if MFC exists passed with the following output:\n"
+         "${OUTPUT}\n\n")
+     ELSE(MFC_HAVE_MFC)
+       MESSAGE(STATUS "Looking for MFC - not found")
+       SET(MFC_HAVE_MFC 0 CACHE INTERNAL "Have MFC?")
+       FILE(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeError.log
+         "Determining if MFC exists failed with the following output:\n"
+         "${OUTPUT}\n\n")
+     ENDIF(MFC_HAVE_MFC)
+   ENDIF("MFC_HAVE_MFC" MATCHES "^MFC_HAVE_MFC$")
  
+   IF(MFC_HAVE_MFC)
+     SET(MFC_FOUND "YES")
+   ENDIF(MFC_HAVE_MFC)
+ ENDIF(MFC_ATTEMPT_TRY_COMPILE)



More information about the Cmake-commits mailing list