]> git.lyx.org Git - lyx.git/blobdiff - development/cmake/CMakeLists.txt
Changes:
[lyx.git] / development / cmake / CMakeLists.txt
index 101580ce0db636d58b97585fe74fe58204e07e0e..c259f17b75a685b00dd469562a464a382660efc4 100644 (file)
@@ -1,7 +1,7 @@
 # This file is part of LyX, the document processor.
 # Licence details can be found in the file COPYING.
 #
-# Copyright (c) 2006, Peter Kümmel, <syntheticpp@gmx.net>
+# Copyright (c) 2006, Peter Kümmel, <syntheticpp@gmx.net>
 #
 
 cmake_minimum_required(VERSION 2.4)
@@ -23,26 +23,75 @@ set(EXECUTABLE_OUTPUT_PATH  ${CMAKE_BINARY_DIR}/bin)
 # Supress regeneration
 set(CMAKE_SUPPRESS_REGENERATION TRUE)
 
-set(PACKAGE lyx)
-set(PACKAGE_VERSION 1.6svn)
-set(LYX_DATE "2007/2008")
-#TODO
 set(VERSION_INFO "CMake Build")
 
-set(PROGRAM_SUFFIX "")
-set(LYX_ABS_INSTALLED_DATADIR "/usr/local/share/lyx")
-set(LYX_ABS_INSTALLED_LOCALEDIR "/usr/local/share/locale")
-set(LYX_ABS_TOP_SRCDIR "${CMAKE_SOURCE_DIR}")
+# Try to get some informations from configure.ac
 
+include(LyXPaths)              #called here to define the needed TOP_SRC_DIR-variable
+file(STRINGS "${TOP_SRC_DIR}/configure.ac" _config_lines)
 
 if(WIN32)
-       set(USE_WINDOWS_PACKAGING 1)
+  set(USE_WINDOWS_PACKAGING 1)
 elseif(APPLE)
-       set(USE_MACOSX_PACKAGING 1)
+  set(USE_MACOSX_PACKAGING 1)
 else()
-       set(USE_POSIX_PACKAGING 1)
+  set(USE_POSIX_PACKAGING 1)
 endif()
 
+macro(setstripped _varname _value)
+  string(STRIP ${_value} _v)
+  if(USE_POSIX_PACKAGING)
+    string(TOLOWER ${_v} ${_varname})
+  else()
+    set(${_varname} ${_v})
+  endif()
+endmacro(setstripped)
+
+foreach(_c_l ${_config_lines} )
+  if(_c_l MATCHES "^AC_INIT\\(\([^,]+\),\([^,]+\),\([^,]+\)\(.*\)")
+    setstripped(PACKAGE_BASE ${CMAKE_MATCH_1})
+    setstripped(PACKAGE_VERSION ${CMAKE_MATCH_2})
+    if(PACKAGE_VERSION MATCHES "^\([0-9]+\)\\.\([0-9]+\).*$")
+      set(LYX_DIR_VER "LYX_DIR_${CMAKE_MATCH_1}${CMAKE_MATCH_2}x")
+      set(LYX_USERDIR_VER "LYX_USERDIR_${CMAKE_MATCH_1}${CMAKE_MATCH_2}x")
+      set(LYX_INSTALL_SUFFIX "${CMAKE_MATCH_1}.${CMAKE_MATCH_2}")
+    endif()
+  endif()
+  if(_c_l MATCHES "^AC_SUBST\\( *LYX_DATE *, *\\[\\\"(.*)\\\"\\].*")
+    set(LYX_DATE "${CMAKE_MATCH_1}")
+  endif()
+endforeach(_c_l)
+
+if(UseVersionSuffix)
+  message("-- Using versioned PACKAGE. Disable with -DUseVersionSuffix=0")
+  set(PACKAGE ${PACKAGE_BASE}${LYX_INSTALL_SUFFIX})
+  set(PROGRAM_SUFFIX "${LYX_INSTALL_SUFFIX}")
+else()
+  message("-- PACKAGE not versioned, to enable use -DUseVersionSuffix=1")
+  set(PACKAGE ${PACKAGE_BASE})
+  set(PROGRAM_SUFFIX "")
+endif()
+
+if(CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT)
+  # see http://www.cmake.org/pipermail/cmake/2006-October/011559.html
+  if (UNIX)
+    # don't use the default "/usr/local"
+    # but respect the user-choice on the command-line
+    SET(CMAKE_INSTALL_PREFIX
+      "/usr/local/share/lyx${LYX_INSTALL_SUFFIX}" CACHE PATH "LyX install prefix" FORCE)
+  endif()
+  if(WIN32)
+    SET(CMAKE_INSTALL_PREFIX
+      ${CMAKE_INSTALL_PREFIX}/${LYX_INSTALL_SUFFIX} CACHE PATH "LyX install prefix" FORCE)
+  endif()
+endif(CMAKE_INSTALL_PREFIX_INITIALIZED_TO_DEFAULT)
+
+set(LYX_ABS_INSTALLED_DATADIR "${CMAKE_INSTALL_PREFIX}")
+set(LYX_LOCALEDIR "locale")
+set(LYX_ABS_INSTALLED_LOCALEDIR "${LYX_ABS_INSTALLED_DATADIR}/${LYX_LOCALEDIR}")
+set(LYX_ABS_TOP_SRCDIR "${TOP_SRC_DIR}")
+
+
 if(NOT GROUP_CODE)
        #set(GROUP_CODE "The Golden Code")
        set(GROUP_CODE flat)
@@ -52,7 +101,6 @@ endif()
 set(LYX_CPP_FILES *.cpp)
 set(LYX_HPP_FILES *.h)
 
-include(LyXPaths)
 include(LyXMacros)
 include(ProjectSourceGroup)
 
@@ -130,7 +178,7 @@ find_package(ZLIB REQUIRED)
 
 if(all OR aspell)
        set(aspell TRUE CACHE TYPE STRING)
-       find_package(ASPELL REQUIRED)   
+       find_package(ASPELL REQUIRED)
 else()
        find_package(ASPELL)
 endif()
@@ -178,16 +226,17 @@ if(WIN32)
        endif()
 endif()
 
-set(PROGRAM_SUFFIX "\"\"")
-set(LYX_ABS_TOP_SRCDIR "${CMAKE_SOURCE_DIR}")
-set(LYX_ABS_INSTALLED_DATADIR "/usr/local/share/lyx")
-set(LYX_ABS_INSTALLED_LOCALEDIR "/usr/local/share/locale")
-
 message("")
-message("----- PROGRAM_SUFFIX              : ${PROGRAM_SUFFIX}")
-message("----- LYX_ABS_TOP_SRCDIR          : ${LYX_ABS_TOP_SRCDIR}")
-message("----- LYX_ABS_INSTALLED_DATADIR   : ${LYX_ABS_INSTALLED_DATADIR}")
-message("----- LYX_ABS_INSTALLED_LOCALEDIR : ${LYX_ABS_INSTALLED_LOCALEDIR}")
+foreach(_v PACKAGE PACKAGE_VERSION
+    PROGRAM_SUFFIX LYX_DATE LYX_DIR_VER LYX_USERDIR_VER
+    LYX_ABS_TOP_SRCDIR
+    LYX_ABS_INSTALLED_DATADIR LYX_ABS_INSTALLED_LOCALEDIR LYX_INSTALL_SUFFIX)
+  if(NOT DEFINED ${_v})
+    message(FATAL_ERROR "${_v} not defined")
+  endif()
+  string(SUBSTRING "${_v}                            " 0 28 _v1)
+  message("----- ${_v1}: ${${_v}}")
+endforeach(_v)
 message("")
 
 
@@ -303,6 +352,13 @@ if(MSVC)
        
 endif()
 
+
+if(nls OR all)
+  find_package(LyXGettext REQUIRED)
+  include_directories(${TOP_SRC_DIR}/po)
+  add_subdirectory(po)
+endif()
+
 # compiler tests, config.h generation
 if(MSVC AND NOT CONFIGURECHECKS)
        configure_file(configCompiler.h.msvc ${CMAKE_BINARY_DIR}/configCompiler.h)
@@ -316,14 +372,9 @@ 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)
-     
-include_directories( 
-       ${CMAKE_BINARY_DIR} 
-       ${TOP_SRC_DIR}/src 
+include_directories(
+       ${CMAKE_BINARY_DIR}
+       ${TOP_SRC_DIR}/src
        ${TOP_SRC_DIR}/boost)
 
 add_subdirectory(boost)
@@ -332,5 +383,10 @@ if(NOT use_external_libintl)
 endif()
 add_subdirectory(src)
 
+add_subdirectory(man)
+add_subdirectory(doc)
+add_subdirectory(lyx2lyx)
+add_subdirectory(scripts)
+
 include(../Install)