]> git.lyx.org Git - lyx.git/blobdiff - development/cmake/CMakeLists.txt
installer:
[lyx.git] / development / cmake / CMakeLists.txt
index c190b0f212f23c5178665b8ea03455b792a4cbd0..e09111ab389c9c746c2a854170ce4bed4f72a252 100644 (file)
@@ -21,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)
@@ -30,37 +32,54 @@ 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 two 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)
 if(debug)
-       set(CMAKE_BUILD_TYPE 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)
+               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)
@@ -160,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}")
@@ -188,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}")
@@ -240,3 +254,7 @@ include_directories(
 add_subdirectory(boost)
 add_subdirectory(intl)
 add_subdirectory(src)
+
+
+include(../Install)
+