]> git.lyx.org Git - lyx.git/blobdiff - development/cmake/src/CMakeLists.txt
Remove AppleSpellChecker.* from non-apple platform
[lyx.git] / development / cmake / src / CMakeLists.txt
index 8b99bc00c6c88421b9ac3b815319dfd5f5e08866..b19f21ab19f7fa690838577d6c54b1c09143afdc 100644 (file)
@@ -4,7 +4,8 @@
 # Copyright (c) 2006, Peter Kümmel, <syntheticpp@gmx.net>
 #
 
-project(lyx)
+set(_lyx ${PACKAGE_BASE}${PROGRAM_SUFFIX})
+project(${_lyx})
 
 include_directories(${TOP_SRC_DIR}/src)
 
@@ -19,47 +20,87 @@ if (UNIX)
 endif()
 
 file(GLOB lyx_sources ${TOP_SRC_DIR}/src/${LYX_CPP_FILES})
+file(GLOB moc_files ${TOP_SRC_DIR}/src/${LYX_MOC_FILES})
+list(REMOVE_ITEM  lyx_sources ${moc_files} .)
 file(GLOB lyx_headers ${TOP_SRC_DIR}/src/${LYX_HPP_FILES})
 
 list(REMOVE_ITEM lyx_sources
-       ${TOP_SRC_DIR}/src/ASpell.cpp
-       ${TOP_SRC_DIR}/src/PSpell.cpp
-       ${TOP_SRC_DIR}/src/ISpell.cpp
+       ${TOP_SRC_DIR}/src/EnchantChecker.cpp
+       ${TOP_SRC_DIR}/src/AspellChecker.cpp
+       ${TOP_SRC_DIR}/src/HunspellChecker.cpp
        ${TOP_SRC_DIR}/src/Variables.cpp
-       ${TOP_SRC_DIR}/src/Section.cpp)
+       ${TOP_SRC_DIR}/src/Section.cpp
+       ${TOP_SRC_DIR}/src/lyxcore.cpp)
+
+if(NOT APPLE)
+  list(REMOVE_ITEM lyx_sources
+    ${TOP_SRC_DIR}/src/AppleSpellChecker.cpp)
+   list(REMOVE_ITEM lyx_headers
+    ${TOP_SRC_DIR}/src/AppleSpellChecker.h)
+endif()
+
+list(REMOVE_ITEM lyx_headers
+       ${TOP_SRC_DIR}/src/EnchantChecker.h
+       ${TOP_SRC_DIR}/src/AspellChecker.h
+       ${TOP_SRC_DIR}/src/HunspellChecker.h
+       ${TOP_SRC_DIR}/src/Variables.h
+       ${TOP_SRC_DIR}/src/Section.h)
+
+if (HUNSPELL_FOUND)
+       list(APPEND lyx_sources ${TOP_SRC_DIR}/src/HunspellChecker.cpp)
+       list(APPEND lyx_headers ${TOP_SRC_DIR}/src/HunspellChecker.h)
+endif()
 
 if (ASPELL_FOUND)
        include_directories(${ASPELL_INCLUDE_DIR})
-       set(lyx_sources ${lyx_sources} ${TOP_SRC_DIR}/src/ASpell.cpp)
+       list(APPEND lyx_sources ${TOP_SRC_DIR}/src/AspellChecker.cpp)
+       list(APPEND lyx_headers ${TOP_SRC_DIR}/src/AspellChecker.h)
+endif()
+
+if (ENCHANT_FOUND)
+  include_directories("${ENCHANT_INCLUDE_DIR}")
+  list(APPEND lyx_sources ${TOP_SRC_DIR}/src/EnchantChecker.cpp)
+  list(APPEND lyx_headers ${TOP_SRC_DIR}/src/EnchantChecker.h)
+endif()
+
+lyx_automoc(${TOP_SRC_DIR}/src/Compare.cpp)
+if (WIN32)
+  lyx_automoc(${TOP_SRC_DIR}/src/Server.cpp)
 endif()
 
 include_directories(${CMAKE_CURRENT_BINARY_DIR}
-       ${ZLIB_INCLUDE_DIR})
+       ${ZLIB_INCLUDE_DIR} ${QT_INCLUDES})
 
 lyx_add_msvc_pch(lyx)
 
 
-if (NOT MERGE_FILES)
-       set(lyx_sources ${lyx_sources})
-else()
+if (LYX_MERGE_FILES)
        lyx_const_touched_files(_allinone  lyx_sources)
        set(lyx_sources ${_allinone_files})
 endif()
 
-if (LYX_LEAK_DETECTION)
+if (LYX_VLD)
        configure_file(${vld_path}/vld.ini ${CMAKE_CURRENT_BINARY_DIR}/vld.ini COPYONLY)
        configure_file(${vld_path}/vld.ini ${CMAKE_CURRENT_BINARY_DIR}/memory_leak_report.txt COPYONLY)
        set(vld_files ${CMAKE_CURRENT_BINARY_DIR}/vld.ini ${CMAKE_CURRENT_BINARY_DIR}/memory_leak_report.txt)
 endif()
 
-add_executable(lyx
+if(WIN32)
+       set(FILE_RC ${CMAKE_SOURCE_DIR}/lyx.rc)
+       message(STATUS "Using icon defined in resource file: ${FILE_RC}")
+endif()
+
+add_executable(${_lyx}
        ${WIN32_CONSOLE}
        ${lyx_sources}
        ${lyx_headers}
        ${vld_files}
+       ${FILE_RC}
 )
 
-target_link_libraries(lyx
+lyx_add_gcc_pch(${_lyx})
+
+target_link_libraries(${_lyx}
        mathed
        insets
        frontends
@@ -71,20 +112,26 @@ target_link_libraries(lyx
        ${QT_QTMAIN_LIBRARY}
        ${vld_dll})
 
+if (HUNSPELL_FOUND)
+        target_link_libraries(${_lyx} ${HUNSPELL_LIBRARY})
+endif()
 if (ASPELL_FOUND)
-       target_link_libraries(lyx ${ASPELL_LIBRARY})
+       target_link_libraries(${_lyx} ${ASPELL_LIBRARY})
+endif()
+if (ENCHANT_FOUND)
+    target_link_libraries(${_lyx} ${ENCHANT_LIBRARY})
 endif()
 
 if (APPLE)
-  target_link_libraries(lyx "-bind_at_load")
-  target_link_libraries(lyx "-framework Carbon")
+  target_link_libraries(${_lyx} "-bind_at_load")
+  target_link_libraries(${_lyx} "-framework Carbon")
 endif()
 
 if (MINGW)
-  target_link_libraries(lyx ole32)
+  target_link_libraries(${_lyx} ole32)
 endif()
 
 project_source_group("${GROUP_CODE}" lyx_sources lyx_headers)
 
-install(TARGETS lyx DESTINATION bin)
+install(TARGETS ${_lyx} DESTINATION bin)