Fixing cmake conf so that we can use all warnings

This includes using a workaround for a CMake bug.
This commit is contained in:
Strahinja Val Markovic 2012-07-04 21:24:16 -07:00
parent a9eb277da1
commit 570267bbe0
3 changed files with 26 additions and 15 deletions

View File

@ -21,10 +21,11 @@
# #
# bcp call: bcp boost/python.hpp boost/bind.hpp boost/lambda/lambda.hpp boost/exception/all.hpp boost/tuple/tuple_io.hpp boost/tuple/tuple_comparison.hpp boost/regex.hpp boost/foreach.hpp boost/smart_ptr.hpp boost/algorithm/string_regex.hpp boost/thread.hpp boost/unordered_map.hpp boost/unordered_set.hpp boost/format.hpp boost/ptr_container/ptr_container.hpp ../BoostParts # bcp call: bcp boost/python.hpp boost/bind.hpp boost/lambda/lambda.hpp boost/exception/all.hpp boost/tuple/tuple_io.hpp boost/tuple/tuple_comparison.hpp boost/regex.hpp boost/foreach.hpp boost/smart_ptr.hpp boost/algorithm/string_regex.hpp boost/thread.hpp boost/unordered_map.hpp boost/unordered_set.hpp boost/format.hpp boost/ptr_container/ptr_container.hpp ../BoostParts
# WARNING: When doing this from fresh boost sources, note that # WARNING: When doing this from fresh boost sources, note that in the file
# in the file /boost/config/user.hpp the BOOST_ALL_NO_LIB # /boost/config/user.hpp the BOOST_ALL_NO_LIB define has been uncommented.
# define has been uncommented. Otherwise, we will get linker # Otherwise, we will get linker errors on MSVC because of boost auto-linking. If
# errors on MSVC because of boost auto-linking. # you don't care about Windows then feel free to use the raw boost version of
# /boost/config/user.hpp
cmake_minimum_required( VERSION 2.8 ) cmake_minimum_required( VERSION 2.8 )
@ -64,6 +65,7 @@ endif()
############################################################################# #############################################################################
include_directories( include_directories(
SYSTEM
${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_CURRENT_SOURCE_DIR}
${PYTHON_INCLUDE_DIRS} ${PYTHON_INCLUDE_DIRS}
) )
@ -73,7 +75,9 @@ add_library( BoostParts ${SOURCES} )
############################################################################# #############################################################################
if( CMAKE_COMPILER_IS_GNUCXX OR COMPILER_IS_CLANG ) if( CMAKE_COMPILER_IS_GNUCXX OR COMPILER_IS_CLANG )
add_definitions( -Wno-parentheses-equality ) # No warnings. We just use Boost as is so warnings coming from it are just
# noise.
add_definitions( -w )
endif() endif()
############################################################################# #############################################################################

View File

@ -21,6 +21,10 @@ project( indexer )
find_package( PythonLibs REQUIRED ) find_package( PythonLibs REQUIRED )
# This is a workaround for a CMake bug with include_directories(SYSTEM ...)
# on Mac OS X. Bug report: http://public.kitware.com/Bug/view.php?id=10837
set( CMAKE_INCLUDE_SYSTEM_FLAG_CXX "-isystem " )
# The SYSTEM flag makes sure that -isystem[header path] is passed to the # The SYSTEM flag makes sure that -isystem[header path] is passed to the
# compiler instead of the standard -I[header path]. Headers included with # compiler instead of the standard -I[header path]. Headers included with
# -isystem do not generate warnings (and they shouldn't; e.g. boost warnings are # -isystem do not generate warnings (and they shouldn't; e.g. boost warnings are
@ -42,6 +46,8 @@ if( to_remove )
list( REMOVE_ITEM SOURCES ${to_remove} ) list( REMOVE_ITEM SOURCES ${to_remove} )
endif() endif()
#############################################################################
add_library( ${PROJECT_NAME} SHARED add_library( ${PROJECT_NAME} SHARED
${SOURCES} ${SOURCES}
) )
@ -51,6 +57,11 @@ target_link_libraries( ${PROJECT_NAME}
${PYTHON_LIBRARIES} ${PYTHON_LIBRARIES}
) )
#############################################################################
# We don't want the "lib" prefix, it can screw up python when it tries to search
# for our module
set_target_properties( ${PROJECT_NAME} PROPERTIES PREFIX "") set_target_properties( ${PROJECT_NAME} PROPERTIES PREFIX "")
# Even on macs, we want a .so extension instead of a .dylib which is what cmake # Even on macs, we want a .so extension instead of a .dylib which is what cmake
@ -61,7 +72,7 @@ if ( NOT WIN32 )
endif() endif()
set_target_properties( ${PROJECT_NAME} PROPERTIES set_target_properties( ${PROJECT_NAME} PROPERTIES
LIBRARY_OUTPUT_DIRECTORY ${PROJECT_SOURCE_DIR}/../../python) LIBRARY_OUTPUT_DIRECTORY ${PROJECT_SOURCE_DIR}/../../python )
if ( CMAKE_CXX_COMPILER_ID STREQUAL "Clang" ) if ( CMAKE_CXX_COMPILER_ID STREQUAL "Clang" )
set( COMPILER_IS_CLANG true ) set( COMPILER_IS_CLANG true )
@ -69,8 +80,7 @@ endif()
if( CMAKE_COMPILER_IS_GNUCXX OR COMPILER_IS_CLANG ) if( CMAKE_COMPILER_IS_GNUCXX OR COMPILER_IS_CLANG )
# We want all warnings, and warnings should be treated as errors # We want all warnings, and warnings should be treated as errors
# TODO: this breaks with boost; fix it! add_definitions( -Wall -Wextra -Werror )
#add_definitions( -Wall -Wextra -Werror )
endif() endif()
add_subdirectory( tests ) add_subdirectory( tests )

View File

@ -23,17 +23,14 @@ if ( COMPILER_IS_CLANG )
add_definitions( -Wno-long-long -Wno-variadic-macros ) add_definitions( -Wno-long-long -Wno-variadic-macros )
endif() endif()
# For whatever reason, cmake does something stupid with pthread detection on
# Mac which makes gtest go stupid too, so we turn of pthread use in gtest; we
# don't really need it either way
if ( APPLE )
add_definitions( -DGTEST_HAS_PTHREAD=0 )
endif()
add_subdirectory( gmock ) add_subdirectory( gmock )
include_directories( include_directories(
${indexer_SOURCE_DIR} ${indexer_SOURCE_DIR}
)
include_directories(
SYSTEM
${gtest_SOURCE_DIR} ${gtest_SOURCE_DIR}
${gtest_SOURCE_DIR}/include ${gtest_SOURCE_DIR}/include
${gmock_SOURCE_DIR} ${gmock_SOURCE_DIR}