X-Git-Url: https://git.lyx.org/gitweb/?a=blobdiff_plain;f=po%2FCMakeLists.txt;h=4d70d24042cd6ca141a91b222f6a509adf4ee6ae;hb=9633b1b9c5f9d272766f382e8e9365b8d6bea546;hp=5b0b46a12b49c869736bf46fe1294dc9c39cf1b6;hpb=06782542413c999ff35f7ee1f62b11f988cdfa0c;p=lyx.git diff --git a/po/CMakeLists.txt b/po/CMakeLists.txt index 5b0b46a12b..4d70d24042 100755 --- a/po/CMakeLists.txt +++ b/po/CMakeLists.txt @@ -89,22 +89,26 @@ add_gettext_python(layouttranslations lib/layouts *.layout *.inc *.module) ADD_CUSTOM_COMMAND( OUTPUT "${CMAKE_CURRENT_BINARY_DIR}/${_lyxname}.cat.pot" COMMAND ${LYX_PYTHON_EXECUTABLE} - ARGS "${TOP_CMAKE_PATH}/po/cat.py" ${_py_sources} > "${CMAKE_CURRENT_BINARY_DIR}/${_lyxname}.cat.pot" + ARGS "${TOP_CMAKE_PATH}/po/cat.py" ${_py_sources} > "${CMAKE_CURRENT_BINARY_DIR}/${_lyxname}.cat_tmp.pot" COMMAND ${LYX_PYTHON_EXECUTABLE} - ARGS "${TOP_CMAKE_PATH}/po/dos2unix.py" "${CMAKE_CURRENT_BINARY_DIR}/${_lyxname}.cat.pot" + ARGS "${TOP_CMAKE_PATH}/po/dos2unix.py" "${CMAKE_CURRENT_BINARY_DIR}/${_lyxname}.cat_tmp.pot" + COMMAND ${CMAKE_COMMAND} -E copy_if_different + "${CMAKE_CURRENT_BINARY_DIR}/${_lyxname}.cat_tmp.pot" "${CMAKE_CURRENT_BINARY_DIR}/${_lyxname}.cat.pot" DEPENDS ${_py_sources} ) ADD_CUSTOM_COMMAND( OUTPUT "${CMAKE_CURRENT_BINARY_DIR}/${_lyxname}.fmt.pot" COMMAND ${GETTEXT_MSGUNIQ_EXECUTABLE} - ARGS -o "${CMAKE_CURRENT_BINARY_DIR}/${_lyxname}.fmt.pot" "${CMAKE_CURRENT_BINARY_DIR}/${_lyxname}.cat.pot" + ARGS -o "${CMAKE_CURRENT_BINARY_DIR}/${_lyxname}.fmt_tmp.pot" "${CMAKE_CURRENT_BINARY_DIR}/${_lyxname}.cat.pot" + COMMAND ${CMAKE_COMMAND} -E copy_if_different + "${CMAKE_CURRENT_BINARY_DIR}/${_lyxname}.fmt_tmp.pot" "${CMAKE_CURRENT_BINARY_DIR}/${_lyxname}.fmt.pot" DEPENDS "${CMAKE_CURRENT_BINARY_DIR}/${_lyxname}.cat.pot" ) SET(_potfiles_dep) -file(WRITE ${CMAKE_CURRENT_BINARY_DIR}/POTFILES.in "") +file(WRITE ${CMAKE_CURRENT_BINARY_DIR}/POTFILES.in.tmp "") file(GLOB_RECURSE _tmp_potfiles RELATIVE ${TOP_SRC_DIR}/ ${TOP_SRC_DIR}/src/*.h ${TOP_SRC_DIR}/src/*.cpp ${TOP_SRC_DIR}/src/*.cpp.in) list(SORT _tmp_potfiles) # list(REMOVE_ITEM _tmp_potfiles src/support/Package.cpp) @@ -114,13 +118,18 @@ foreach(_f ${_tmp_potfiles}) # will stay the same. # Relevant files are files containing the string '_(".*")' LIST(APPEND _potfiles_dep "${TOP_SRC_DIR}/${_f}") - file(APPEND ${CMAKE_CURRENT_BINARY_DIR}/POTFILES.in "${_f}\n") + file(APPEND ${CMAKE_CURRENT_BINARY_DIR}/POTFILES.in.tmp "${_f}\n") endforeach(_f) +execute_process( + COMMAND ${CMAKE_COMMAND} -E copy_if_different "${CMAKE_CURRENT_BINARY_DIR}/POTFILES.in.tmp" "${CMAKE_CURRENT_BINARY_DIR}/POTFILES.in" + ) + ADD_CUSTOM_COMMAND( OUTPUT "${CMAKE_CURRENT_BINARY_DIR}/${_lyxname}.pot" COMMAND ${CMAKE_COMMAND} -E copy "${CMAKE_CURRENT_BINARY_DIR}/${_lyxname}.fmt.pot" "${CMAKE_CURRENT_BINARY_DIR}/${_lyxname}.pot" COMMAND ${GETTEXT_XGETTEXT_EXECUTABLE} + --from-code=UTF-8 --default-domain=${_lyxname} --directory=${TOP_SRC_DIR} --add-comments=TRANSLATORS: --language=C++ --join-existing --keyword=_ --keyword=N_ --keyword=B_ --keyword=qt_ @@ -165,16 +174,31 @@ foreach(_pofile ${LYX_BASE_PO_FILES}) list(APPEND LYX_PO_FILES ${CMAKE_CURRENT_BINARY_DIR}/${_pofile}) endforeach(_pofile) +FIND_PROGRAM(LYX_GITVERSION git) set(LYX_UPDATED_GMO_FILES) foreach(_gmo_base ${INSTALLED_LANGUAGES}) set(_gmo ${_gmo_base}.gmo) - add_custom_command( - OUTPUT "${LYX_DEST_PO}/${_gmo}" - COMMAND ${CMAKE_COMMAND} -E copy_if_different "${CMAKE_CURRENT_BINARY_DIR}/${_gmo}" "${LYX_DEST_PO}/${_gmo}" - DEPENDS "${CMAKE_CURRENT_BINARY_DIR}/${_gmo}" + set(_tobeupdated "${CMAKE_CURRENT_BINARY_DIR}/${_gmo}.tobeupdated") + list(APPEND LYX_UPDATED_GMO_FILES "${_tobeupdated}") + if(LYX_GITVERSION) + add_custom_command( + OUTPUT "${_tobeupdated}" + COMMAND "${LYX_GITVERSION}" "status" "--porcelain" "${_gmo_base}.po" ">" "${_tobeupdated}" + COMMAND ${LYX_PYTHON_EXECUTABLE} "${TOP_CMAKE_PATH}/po/update-gmo.py" + "${_tobeupdated}" + "${CMAKE_CURRENT_BINARY_DIR}/${_gmo}" + "${LYX_DEST_PO}/${_gmo}" + WORKING_DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}" + DEPENDS "${CMAKE_CURRENT_BINARY_DIR}/${_gmo}" + ) + else() + add_custom_command( + OUTPUT "${_tobeupdated}" + COMMAND ${CMAKE_COMMAND} -E copy_if_different "${CMAKE_CURRENT_BINARY_DIR}/${_gmo}" "${LYX_DEST_PO}/${_gmo}" + COMMAND ${CMAKE_COMMAND} -E touch "${_tobeupdated}" + DEPENDS "${CMAKE_CURRENT_BINARY_DIR}/${_gmo}" ) - list(APPEND LYX_UPDATED_GMO_FILES "${LYX_DEST_PO}/${_gmo}") - ADD_CUSTOM_TARGET(update-${_gmo_base}-gmo DEPENDS "${LYX_DEST_PO}/${_gmo}") + endif() endforeach() set(LYX_UPDATED_PO_FILES) @@ -206,7 +230,8 @@ GETTEXT_CREATE_TRANSLATIONS(${CMAKE_CURRENT_BINARY_DIR}/${_lyxname}.pot ${_addAL # Create a new target to remerge po files # ALL omitted here, to prevent from automatic creation +ADD_CUSTOM_TARGET(update-gmo DEPENDS ${LYX_UPDATED_GMO_FILES}) ADD_CUSTOM_TARGET(update-po DEPENDS ${LYX_UPDATED_PO_FILES} ${LYX_UPDATED_GMO_FILES}) -set_target_properties(update-po PROPERTIES FOLDER "i18n") +set_target_properties(update-po update-gmo PROPERTIES FOLDER "i18n") add_dependencies(update-po translations)