On Mac OS X one shouldn't do this kind of detection during configure step, because as has been mentioned a single file can be compiled multiple times for different architectures during one single compiler invocation. The size of void* and even endianness can change. It is preferable to have a central config.h.in (or similar) containing something like this:

#if defined(__APPLE__)
#  if defined(__i386__)
#    undef HAVE_64_BIT
#    undef HAVE_BIG_ENDIAN
#  elif defined(__ppc__)
#    undef HAVE_64_BIT
#    define HAVE_BIG_ENDIAN
#  elif defined(__x86_64__)
#    define HAVE_64_BIT
#    undef HAVE_BIG_ENDIAN
#  elif defined(__ppc64__)
#    define HAVE_64_BIT
#    define HAVE_BIG_ENDIAN
#  else
     // oops
#    error "Unknown architecture!"
#  endif
#else
#  cmakedefine HAVE_64_BIT
#  cmakedefine HAVE_BIG_ENDIAN
#endif


On NOT APPLE platforms you do the normal thing in your CMakeLists.txt:

if( NOT APPLE )
  # check 64 bit
  if( CMAKE_SIZEOF_VOID_P EQUALS 4 )
    set( HAVE_64_BIT 0 )
  else( CMAKE_SIZEOF_VOID_P EQUALS 4 )
    set( HAVE_64_BIT 1 )
  endif( CMAKE_SIZEOF_VOID_P EQUALS 4 )

  # check endianness
  include( TestBigEndian )
  test_big_endian( HAVE_BIG_ENDIAN )
  if( HAVE_BIG_ENDIAN )
    set( HAVE_BIG_ENDIAN 1 )
  else( HAVE_BIG_ENDIAN )
    set( HAVE_BIG_ENDIAN 0 )
  endif( HAVE_BIG_ENDIAN )
endif( NOT APPLE )

# configure config.h
configure_file( ${CMAKE_SOURCE_DIR}/config.h.in ${CMAKE_BINARY_DIR}/ config.h )
include_directories( ${CMAKE_BINARY_DIR} )


HTH

Michael

On 12. Jun, 2009, at 15:01, David Cole wrote:

CMake does not warn.
And actually, I think I have to back-track on my statement a little bit.

Whether or not a TRY_COMPILE "works" for a multiple arch / config build *depends* entirely on what you are trying to compile and what result you are expecting to get out of it. If you do a try compile on some code to detect
the presence of a function, for example, that should work fine on a
universal binary build (presuming the function you're trying to link against
is present in universal binary form in the library it lives in...).

The thing that won't work on a multiple arch/config build is trying to
detect the size of something or the presence/absence of something where the
thing you're trying to measure is different in the different archs /
configs. If it's uniform across all archs/configs then you can measure it and get an answer that makes sense for all archs/configs. If not, then you
can't.

Does that make sense?

So... CMake does not warn because it does not know whether what you are
attempting to measure is valid or not. It's up to you to "do the right
thing" in these sorts of situations.

You already know that if you are building a universal binary with both
32-bit and 64-bit architectures in it that it makes no sense to "measure" the size of "void*" at CMake time. You know this because you know there is
more than one answer depending on which one runs.


Hope this clarifies things even further, (rather than muddying anybody's
waters...)

David


On Thu, Jun 11, 2009 at 6:56 PM, Sean McBride <s...@rogue- research.com>wrote:

On 6/11/09 5:25 PM, David Cole said:

TRY_COMPILE works fine for cross compiles, just not for *mutiple
configs/architectures "simultaneously"* compiles...

Thanks for the clarification, that language is clearer.

Does CMake detect and warn in such cases? (it is after all the common
case on OS X.)

Cheers,

--
____________________________________________________________
Sean McBride, B. Eng                 s...@rogue-research.com
Rogue Research                        www.rogue-research.com
Mac Software Developer              Montréal, Québec, Canada



_______________________________________________
Powered by www.kitware.com

Visit other Kitware open-source projects at 
http://www.kitware.com/opensource/opensource.html

Please keep messages on-topic and check the CMake FAQ at: 
http://www.cmake.org/Wiki/CMake_FAQ

Follow this link to subscribe/unsubscribe:
http://www.cmake.org/mailman/listinfo/cmake

_______________________________________________
Powered by www.kitware.com

Visit other Kitware open-source projects at 
http://www.kitware.com/opensource/opensource.html

Please keep messages on-topic and check the CMake FAQ at: 
http://www.cmake.org/Wiki/CMake_FAQ

Follow this link to subscribe/unsubscribe:
http://www.cmake.org/mailman/listinfo/cmake

Reply via email to