X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=development%2Fcmake%2FInstall.cmake;h=d2ff5eb77ca4ddf7fea49e4dfa767f14aa8acd97;hb=75ffcc8e866de04b076c81d78003a86efca98e4e;hp=ac39d8bd63bf41c22f3b8889a03117e1ed588a92;hpb=90f3c110c71b8cdf5523b6f4de2a5e771bc8fd23;p=lyx.git diff --git a/development/cmake/Install.cmake b/development/cmake/Install.cmake index ac39d8bd63..d2ff5eb77c 100755 --- a/development/cmake/Install.cmake +++ b/development/cmake/Install.cmake @@ -2,7 +2,21 @@ # TODO: set correct path in call to cmake # e.g. cmake /usr/src/lyx/lyx-devel/development/cmake -DCMAKE_INSTALL_PREFIX=/usr/local/share/lyx2.0 -Dnls=1 -message(STATUS "Installing to ${CMAKE_INSTALL_PREFIX}, defined by CMAKE_INSTALL_PREFIX") +if(NOT(LYX_BUNDLE) AND APPLE) + message(STATUS "Installing to ${CMAKE_INSTALL_PREFIX}, defined by CMAKE_INSTALL_PREFIX") +endif() +set(OSX_BUNDLE_FILES "") + +# Install files into OS X bundle +macro(lyx_install_osx basedir files) + if(LYX_BUNDLE_PROPERTY_MODE STREQUAL "ON") + foreach(file ${files}) + set_source_files_properties("${file}" PROPERTIES MACOSX_PACKAGE_LOCATION "Resources/${basedir}") + endforeach() + else() + list(APPEND OSX_BUNDLE_FILES "${files}") + endif() +endmacro(lyx_install_osx) # the macro scans the directories "_parent_src_dir/_dir/_current_dir" for *._file_type files # and installs the files in CMAKE_INSTALL_PREFIX/_current_dir @@ -27,17 +41,30 @@ macro(lyx_install _parent_src_dir _gl_dir _file_type) file(GLOB _item_list ${_current_dir}/${_file_type}) #cmake bug: globbing with * also returns directories on Windows set(files_list ${_item_list}) + set(program_list) foreach(_current_item ${_item_list}) - if(IS_DIRECTORY ${_current_item}) - #message(STATUS "removing ${_current_item}") - if(files_list) + if(files_list) + if(IS_DIRECTORY ${_current_item}) + #message(STATUS "removing dir ${_current_item}") list(REMOVE_ITEM files_list "${_current_item}") - endif() + else() + if(_current_item MATCHES "/\\.[^/]+$") + #message(STATUS "removing hidden ${_current_item}") + list(REMOVE_ITEM files_list "${_current_item}") + endif() + if(_current_item MATCHES "\\.in$") + #message(STATUS "removing .in file ${_current_item}") + list(REMOVE_ITEM files_list "${_current_item}") + endif() + if(_current_item MATCHES "\\.py$") + list(REMOVE_ITEM files_list "${_current_item}") + list(APPEND program_list "${_current_item}") + endif() + endif() endif() endforeach(_current_item) if(files_list) - list(REMOVE_ITEM files_list "${_current_dir}/.svn") - list(REMOVE_ITEM files_list "${_current_dir}/Makefile.in") + list(REMOVE_ITEM files_list "${_current_dir}/lyx.svg") list(REMOVE_ITEM files_list "${_current_dir}/Makefile.am") list(REMOVE_ITEM files_list "${_current_dir}/layouttranslations") GET_FILENAME_COMPONENT(_base_dir ${_current_dir} NAME) @@ -46,8 +73,22 @@ macro(lyx_install _parent_src_dir _gl_dir _file_type) endif() #message(STATUS "install ${LYX_DATA_SUBDIR}${_dir}/${_base_dir}: ${files_list} ") #message(STATUS "install at ${CMAKE_INSTALL_PREFIX}/${LYX_DATA_SUBDIR}${_dir}/${_base_dir}") - install(FILES ${files_list} DESTINATION ${LYX_DATA_SUBDIR}${_dir}/${_base_dir}) + if(APPLE) + lyx_install_osx("${_dir}/${_based_dir}" "${files_list}") + else() + install(FILES ${files_list} DESTINATION ${LYX_DATA_SUBDIR}${_dir}/${_base_dir}) + endif(APPLE) endif() + if(program_list) + if(_glob_dir STREQUAL ".") + set(_base_dir .) + endif() + if(APPLE) + lyx_install_osx("${_dir}/${_based_dir}" "${program_list}") + else() + install(PROGRAMS ${program_list} DESTINATION ${LYX_DATA_SUBDIR}${_dir}/${_base_dir}) + endif(APPLE) + endif() endforeach(_current_dir) endforeach(_glob_dir) endforeach(_dir) @@ -69,7 +110,7 @@ lyx_install(${TOP_SRC_DIR}/lib doc/${_all_languages} * clipart) lyx_install(${TOP_SRC_DIR}/lib examples * . ${_all_languages}) lyx_install(${TOP_SRC_DIR}/lib fonts * .) -lyx_install(${TOP_SRC_DIR}/lib images * . math commands attic classic oxygen) +lyx_install(${TOP_SRC_DIR}/lib images * . math ipa commands attic classic oxygen) lyx_install(${TOP_SRC_DIR}/lib kbd * .) lyx_install(${TOP_SRC_DIR}/lib layouts * .) lyx_install(${TOP_SRC_DIR}/lib lyx2lyx *.py .) @@ -79,3 +120,19 @@ lyx_install(${TOP_SRC_DIR}/lib templates * . attic springer thesis) lyx_install(${TOP_SRC_DIR}/lib tex * .) lyx_install(${TOP_SRC_DIR}/lib ui * .) lyx_install(${TOP_SRC_DIR}/lib . * .) + +# Install +if(APPLE) + lyx_install(${TOP_SRC_DIR}/development/MacOSX . *.sdef .) + lyx_install(${TOP_SRC_DIR}/development/MacOSX . *.icns .) + lyx_install(${TOP_SRC_DIR}/development/MacOSX . qt.conf .) +endif() + +install(PROGRAMS ${TOP_SRC_DIR}/lib/scripts/listerrors DESTINATION scripts) + +if(UNIX) + set(program_suffix ${PROGRAM_SUFFIX}) + configure_file(${TOP_SRC_DIR}/lib/lyx.desktop.in lyx${PROGRAM_SUFFIX}.desktop) + install(FILES ${CMAKE_CURRENT_BINARY_DIR}/lyx${PROGRAM_SUFFIX}.desktop DESTINATION applications) + install(FILES ${TOP_SRC_DIR}/lib/images/lyx.svg RENAME lyx${PROGRAM_SUFFIX}.svg DESTINATION images) +endif()