i18n: check for gettext rather than just calling msgfmt
- *secretly* this is already done in the KF5 i18n modules, so the resizefs was already requiring FindGettext. - we don't actually use the gettext modules' CMake macros, so explain why in the module.
This commit is contained in:
parent
392b4d33a0
commit
6b6267e3a4
@ -12,6 +12,15 @@
|
|||||||
|
|
||||||
include( CMakeParseArguments )
|
include( CMakeParseArguments )
|
||||||
|
|
||||||
|
# The Gettext module is still old-fashioned, ALLCAPS variables
|
||||||
|
find_package( Gettext )
|
||||||
|
set_package_properties( GETTEXT PROPERTIES
|
||||||
|
DESCRIPTION "GNU gettext (translation) tools."
|
||||||
|
URL "https://www.gnu.org/software/gettext/"
|
||||||
|
PURPOSE "Gettext is used in the translation of Python modules."
|
||||||
|
TYPE REQUIRED
|
||||||
|
)
|
||||||
|
|
||||||
# Installs a directory containing language-code-labeled subdirectories with
|
# Installs a directory containing language-code-labeled subdirectories with
|
||||||
# gettext data into the appropriate system directory. Allows renaming the
|
# gettext data into the appropriate system directory. Allows renaming the
|
||||||
# .mo files during install to avoid namespace clashes.
|
# .mo files during install to avoid namespace clashes.
|
||||||
@ -44,8 +53,13 @@ function( install_calamares_gettext_translations )
|
|||||||
endif()
|
endif()
|
||||||
string( REGEX REPLACE ".mo$" ".po" TRANSLATION_SOURCE_FILENAME "${TRANSLATION_FILENAME}" )
|
string( REGEX REPLACE ".mo$" ".po" TRANSLATION_SOURCE_FILENAME "${TRANSLATION_FILENAME}" )
|
||||||
|
|
||||||
message(STATUS "Installing gettext translations for ${TRANSLATION_NAME}")
|
if ( GETTEXT_FOUND AND GETTEXT_MSGFMT_EXECUTABLE )
|
||||||
message(STATUS " Installing ${TRANSLATION_FILENAME} from ${TRANSLATION_SOURCE_DIR}")
|
message( STATUS "Installing gettext translations for ${TRANSLATION_NAME}")
|
||||||
|
message( STATUS " Installing ${TRANSLATION_FILENAME} from ${TRANSLATION_SOURCE_DIR}")
|
||||||
|
else()
|
||||||
|
message( WARNING "Gettext translations requested for ${TRANSLATION_NAME}, but gettext was not found." )
|
||||||
|
return()
|
||||||
|
endif()
|
||||||
|
|
||||||
set( TARGET_NAME calamares-gettext-translations-${NAME} )
|
set( TARGET_NAME calamares-gettext-translations-${NAME} )
|
||||||
if( NOT TARGET "${TARGET_NAME}" )
|
if( NOT TARGET "${TARGET_NAME}" )
|
||||||
@ -62,10 +76,18 @@ function( install_calamares_gettext_translations )
|
|||||||
if( lang STREQUAL "en" )
|
if( lang STREQUAL "en" )
|
||||||
message( STATUS " Skipping ${TRANSLATION_NAME} translations for en_US" )
|
message( STATUS " Skipping ${TRANSLATION_NAME} translations for en_US" )
|
||||||
else()
|
else()
|
||||||
|
# We **don't** use the gettext macro's here because the source
|
||||||
|
# structure doesn't match: we are calling this once per language
|
||||||
|
# for all of Calamares's languages, while the gettext module
|
||||||
|
# expects it to be called once, for a given language source-dir.
|
||||||
|
#
|
||||||
|
# Using any of the gettext macros just gets us multiple rules
|
||||||
|
# for python.gmo, and it wants to use msgmerge, besides, which
|
||||||
|
# doesn't fit our Transifex workflow.
|
||||||
make_directory( ${lang_mo_dir} )
|
make_directory( ${lang_mo_dir} )
|
||||||
add_custom_command(
|
add_custom_command(
|
||||||
OUTPUT ${lang_mo}
|
OUTPUT ${lang_mo}
|
||||||
COMMAND msgfmt
|
COMMAND ${GETTEXT_MSGFMT_EXECUTABLE}
|
||||||
ARGS -o ${lang_mo} ${lang_po}
|
ARGS -o ${lang_mo} ${lang_po}
|
||||||
MAIN_DEPENDENCY ${lang_po}
|
MAIN_DEPENDENCY ${lang_po}
|
||||||
)
|
)
|
||||||
|
Loading…
Reference in New Issue
Block a user