]> git.lyx.org Git - lyx.git/blobdiff - development/cmake/CMakeLists.txt
cmake part of bug 3527, with macro USE_WCHAR_T
[lyx.git] / development / cmake / CMakeLists.txt
index e9bfb7964b9fa4e73fb3a8bd59040ed409e75d2c..e09111ab389c9c746c2a854170ce4bed4f72a252 100644 (file)
@@ -4,7 +4,8 @@
 # Copyright (c) 2006, Peter Kümmel, <syntheticpp@gmx.net>
 #
 
-CMAKE_MINIMUM_REQUIRED(VERSION 2.4.4 FATAL_ERROR)
+#not really needed
+#CMAKE_MINIMUM_REQUIRED(VERSION 2.4.4 FATAL_ERROR)
 
 
 # where to look first for cmake modules, before ${CMAKE_ROOT}/Modules/ is checked
@@ -20,6 +21,8 @@ set(VERSION_INFO "CMake Build")
 
 if(WIN32)
        set(USE_WINDOWS_PACKAGING 1)
+elseif(APPLE)
+       set(USE_MACOSX_PACKAGING 1)
 else(WIN32)
        set(USE_POSIX_PACKAGING 1)
 endif(WIN32)
@@ -29,23 +32,67 @@ if(NOT GROUP_CODE)
        set(GROUP_CODE flat)
 endif(NOT GROUP_CODE)
 
+# lyx's source files
+set(LYX_CPP_FILES *.cpp)
+set(LYX_HPP_FILES *.h)
+
 include(LyXPaths)
 include(LyXMacros)
 include(ProjectSourceGroup)
 
-if(merge OR MERGE_FILES)
-       if(NOT MERGE_FILES)
-               set(MERGE_FILES TRUE CACHE TYPE STRING FORCE)
-       endif(NOT MERGE_FILES)
+if(merge)
+       set(merge 1 CACHE TYPE STRING FORCE)
+       set(MERGE_FILES 1 CACHE TYPE STRING FORCE)
        message(STATUS "")
-       message(STATUS "will merge all *.C files of a project into one file (exception: qt4 and boost_regex files )")
+       message(STATUS "will merge all *.cpp files of a project into two files, disable with -Dmerge=0")
        message(STATUS "")
-endif(merge OR MERGE_FILES)    
+       set(disable-pch  1)
+else(merge)
+       set(merge 0 CACHE TYPE STRING FORCE)
+       set(MERGE_FILES 0 CACHE TYPE STRING FORCE)
+       message(STATUS "enable merging files with -Dmerge=1")
+endif(merge)   
+
 
+set(CMAKE_BUILD_TYPE)
+if(profile)
+       set(CMAKE_BUILD_TYPE Profile CACHE TYPE STRING FORCE)
+       set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -pg" CACHE TYPE STRING FORCE)
+       set(profile)
+endif(profile)
 if(release)
-       set(CMAKE_BUILD_TYPE Release)
+       set(CMAKE_BUILD_TYPE Release CACHE TYPE STRING FORCE)
        set(release)
-endif(release) 
+endif(release)
+if(debug)
+       set(CMAKE_BUILD_TYPE Debug CACHE TYPE STRING FORCE)
+endif(debug)
+
+if(shared)
+       set(library_type SHARED)
+       message(STATUS "building shared libraries")
+else(shared)
+       set(library_type STATIC)
+endif(shared)
+
+if(UNIX)
+       if(NOT quiet)
+               set(CMAKE_VERBOSE_MAKEFILE ON CACHE TYPE STRING FORCE)
+               message(STATUS "verbose Makefile, disable with -Dquiet=1")
+               message(STATUS "")
+       endif(NOT quiet)
+       set(LYX_CXX_FLAGS -Wall)
+       if(stdlib-debug)
+               set(LYX_CXX_FLAGS "${LYX_CXX_FLAGS} -D_GLIBCXX_DEBUG -D_GLIBCXX_DEBUG_PEDANTIC")
+       endif(stdlib-debug)
+       if(concept-checks)
+               set(LYX_CXX_FLAGS "${LYX_CXX_FLAGS} -D_GLIBCPP_CONCEPT_CHECKS")
+       endif(concept-checks)
+       set(CMAKE_CXX_FLAGS          "${LYX_CXX_FLAGS}" CACHE TYPE STRING FORCE)
+       set(CMAKE_CXX_FLAGS_DEBUG    "${LYX_CXX_FLAGS} -O -g -D_DEBUG" CACHE TYPE STRING FORCE)
+       set(CMAKE_CXX_FLAGS_RELEASE  "${LYX_CXX_FLAGS} -O3 -DNDEBUG" CACHE TYPE STRING FORCE)
+       set(CMAKE_CXX_FLAGS_PROFILE  "${CMAKE_CXX_FLAGS_RELEASE} -pg" CACHE TYPE STRING FORCE)
+endif(UNIX)
 
 
 set(qt_postfix qt4)
@@ -57,8 +104,6 @@ if(MERGE_FILES)
 endif(MERGE_FILES)
 
 find_package(ZLIB REQUIRED)
-find_package(ICONV REQUIRED)
-add_definitions(-DHAVE_ICONV=1)
 
 if(all OR aspell)
        set(aspell TRUE CACHE TYPE STRING)
@@ -109,7 +154,7 @@ message("----- LOCALEDIR     : ${LOCALEDIR}")
 message("")
 
 if(MSVC)
-       ADD_DEFINITIONS(-D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE) 
+       ADD_DEFINITIONS(-D_CRT_SECURE_NO_DEPRECATE -D_CRT_NONSTDC_NO_DEPRECATE -DNOMINMAX)      
        # disable checked iterators for msvc release builds to get maximum speed
        set(CMAKE_CXX_FLAGS_RELEASE  "${CMAKE_CXX_FLAGS_RELEASE} /D_SECURE_SCL=0")
 endif(MSVC)
@@ -134,18 +179,13 @@ else(MSVC AND NOT disable-pch)
        endmacro(lyx_add_msvc_pch)
 endif(MSVC AND NOT disable-pch)
 
-if(MSVC)
+if(MSVC)       
        if(WALL)
                set(WALL 1 CACHE TYPE STRING FORCE)
-               set(DISABLEWALL 0 CACHE TYPE STRING FORCE)
-       else(WALL)
-               set(DISABLEWALL 1 CACHE TYPE STRING FORCE)
-       endif(WALL)
-       
-       if(NOT DISABLEWALL)
-       
+               
                # Use the highest warning level
                set(CMAKE_CXX_WARNING_LEVEL 4 CACHE TYPE STRING FORCE)
+               set(WARNING_LEVEL_MESSAGE "(switch to warning level 3 with -DWALL=0)")
                
                if(CMAKE_CXX_FLAGS MATCHES "/W[0-4]")
                        STRING(REGEX REPLACE "/W[0-4]" "/W4" CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS}")
@@ -162,28 +202,28 @@ if(MSVC)
                # add here warnings which should produce an error /weXXXX
                SET(MSVC_W_ERROR   "/we4101 /we4189")
                # add here warnings which should be disabled /wdXXXX
-               SET(MSVC_W_DISABLE "/wd4800 /wd4996 /wd4311 /wd4312 /wd4505 /wd4267 /wd4512 /wd4245 /wd4127")
+               SET(MSVC_W_DISABLE "/wd4800 /wd4996 /wd4311 /wd4312 /wd4505 /wd4267 /wd4512 /wd4245 /wd4127 /wd4180")
                
                set(CMAKE_CXX_FLAGS_DEBUG    "${CMAKE_CXX_FLAGS_DEBUG}         /Wp64 ${MSVC_W_ERROR} ${MSVC_W_DISABLE}")
                set(CMAKE_CXX_FLAGS_RELEASE  "${CMAKE_CXX_FLAGS_RELEASE}       /Wp64 ${MSVC_W_ERROR} ${MSVC_W_DISABLE}")
                set(CMAKE_CXX_FLAGS_MINSIZEREL  "${CMAKE_CXX_FLAGS_MINSIZEREL} /Wp64 ${MSVC_W_ERROR} ${MSVC_W_DISABLE}")
                
-       else(NOT DISABLEWALL)   
-       
-               set(DISABLEWALL 1 CACHE TYPE STRING FORCE)
+       else(WALL)      
+               set(WALL 0 CACHE TYPE STRING FORCE)
+               
                set(CMAKE_CXX_WARNING_LEVEL 3 CACHE TYPE STRING FORCE)
                set(WARNING_LEVEL_MESSAGE "(switch to warning level 4 with -DWALL=1)")
        
                # add here warnings which should produce an error /weXXXX
                SET(MSVC_W_ERROR   "/we4101 /we4189")
                # add here warnings which should be disabled /wdXXXX
-               SET(MSVC_W_DISABLE "/wd4800 /wd4996 /wd4267")
+               SET(MSVC_W_DISABLE "/wd4800 /wd4996 /wd4267 /wd4180")
                
                set(CMAKE_CXX_FLAGS_DEBUG    "${CMAKE_CXX_FLAGS_DEBUG}         ${MSVC_W_ERROR} ${MSVC_W_DISABLE}")
                set(CMAKE_CXX_FLAGS_RELEASE  "${CMAKE_CXX_FLAGS_RELEASE}       ${MSVC_W_ERROR} ${MSVC_W_DISABLE}")
                set(CMAKE_CXX_FLAGS_MINSIZEREL  "${CMAKE_CXX_FLAGS_MINSIZEREL} ${MSVC_W_ERROR} ${MSVC_W_DISABLE}")
                
-       endif(NOT DISABLEWALL)
+       endif(WALL)
        
        message("----- Warning level      : ${CMAKE_CXX_WARNING_LEVEL}  ${WARNING_LEVEL_MESSAGE}")
        message("----- Warnings as errors : ${MSVC_W_ERROR}")
@@ -196,6 +236,10 @@ endif(MSVC)
 include(ConfigureChecks.cmake)
 configure_file(config.h.cmake ${CMAKE_BINARY_DIR}/config.h )
 
+find_package(ICONV REQUIRED)
+add_definitions(-DHAVE_ICONV=1)
+
+
 #TODO: insource is not the best place
 configure_file(${TOP_SRC_DIR}/lib/lyx2lyx/lyx2lyx_version.py.in 
                ${TOP_SRC_DIR}/lib/lyx2lyx/lyx2lyx_version.py)
@@ -210,3 +254,7 @@ include_directories(
 add_subdirectory(boost)
 add_subdirectory(intl)
 add_subdirectory(src)
+
+
+include(../Install)
+