Tweak the cmake interaction between CMAKE_BUILD_TYPE and LLVM_ENABLE_ASSERTIONS.
authorDuncan Sands <baldrick@free.fr>
Wed, 17 Jul 2013 09:34:51 +0000 (09:34 +0000)
committerDuncan Sands <baldrick@free.fr>
Wed, 17 Jul 2013 09:34:51 +0000 (09:34 +0000)
commit80f122fefb62a9520ac58d94135215a4d4ca909f
treefb2d3e9e1b5a8b4ad1931302ea6f04b8e16e361e
parent9ced602cc67e33e7e6136325f1503037ace2b1a6
Tweak the cmake interaction between CMAKE_BUILD_TYPE and LLVM_ENABLE_ASSERTIONS.
The issue is that CMAKE_BUILD_TYPE=RelWithDebInfo LLVM_ENABLE_ASSERTIONS=ON was
not building with assertions enabled.  (I was unable to find what in the LLVM
source tree was adding -DNDEBUG to the build line in this case, so decided that
it must be cmake itself that was adding it - this may depend on the cmake
version).  The fix treats any mode that is not Debug as being the same as
Release for this purpose (previously it was being assumed that cmake would only
add -DNDEBUG for Release and not for RelWithDebInfo or MinSizeRel).  If other
versions of cmake don't add -DNDEBUG for RelWithDebInfo then that's OK: with
this change you just get a useless but harmless -UNDEBUG or -DNDEBUG.

llvm-svn: 186499
llvm/CMakeLists.txt
llvm/cmake/modules/HandleLLVMOptions.cmake