1
0
mirror of https://git.familie-radermacher.ch/linux/ptouch-print.git synced 2025-08-14 07:53:26 +00:00

better gettext support (thanks to Michael Schulz)

This commit is contained in:
Dominic Radermacher 2025-08-03 09:42:30 +02:00
parent 1f450d9124
commit efa48162a8
5 changed files with 89 additions and 8 deletions

View File

@ -37,7 +37,6 @@ target_link_libraries(${PROJECT_NAME} PRIVATE
target_sources(${PROJECT_NAME} PRIVATE
include/ptouch.h
include/gettext.h
src/libptouch.c
src/ptouch-print.c
)
@ -66,6 +65,8 @@ add_custom_target(git-version ALL
${CMAKE_COMMAND} -P ${CMAKE_CURRENT_SOURCE_DIR}/cmake/gitversion.cmake
)
include(${CMAKE_CURRENT_SOURCE_DIR}/cmake/gettext.cmake)
install(TARGETS ${PROJECT_NAME} DESTINATION bin)
install(FILES ${CMAKE_CURRENT_SOURCE_DIR}/ptouch-print.1 DESTINATION ${CMAKE_INSTALL_MANDIR}/man1)

76
cmake/gettext.cmake Normal file
View File

@ -0,0 +1,76 @@
# Utilize gettext multilingual internationalization services
if(Gettext_FOUND)
add_custom_target(
pot-update
ALL
DEPENDS ${CMAKE_SOURCE_DIR}/po/ptouch.pot
)
add_dependencies(pot-update git-version)
# generate pot files using xgettext
if(GETTEXT_XGETTEXT_EXECUTABLE)
file(GLOB_RECURSE C_FILES RELATIVE ${CMAKE_SOURCE_DIR} ${CMAKE_SOURCE_DIR}/src/*.c)
file(STRINGS ${CMAKE_BINARY_DIR}/version.h VERSION_LINE REGEX "VERSION")
string(REGEX MATCH "\".*\"$" PVERSION ${VERSION_LINE})
add_custom_command(
TARGET pot-update
PRE_BUILD
COMMAND ${GETTEXT_XGETTEXT_EXECUTABLE}
--keyword=_
--keyword=N_
--force-po
--package-name=${PROJECT_NAME}
--package-version=${PVERSION}
--copyright-holder="Dominic Radermacher <dominic@familie-radermacher.ch>"
--msgid-bugs-address="dominic@familie-radermacher.ch"
--output ${CMAKE_SOURCE_DIR}/po/ptouch.pot
${C_FILES}
WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}
)
else()
message(DEBUG "Variable GETTEXT_XGETTEXT_EXECUTABLE not set")
endif()
# read available languages from LINGUAS file while ignoring comments
file(STRINGS po/LINGUAS LINGUAS REGEX "^[^#]")
# merge po files
if(GETTEXT_MSGMERGE_EXECUTABLE)
add_custom_target(
po-merge
ALL
DEPENDS ${CMAKE_SOURCE_DIR}/po/ptouch.pot
)
add_dependencies(po-merge pot-update)
foreach(LINGUA IN LISTS LINGUAS)
add_custom_command(
TARGET po-merge
PRE_BUILD
COMMAND ${GETTEXT_MSGMERGE_EXECUTABLE}
--update
--quiet
${CMAKE_SOURCE_DIR}/po/${LINGUA}.po
${CMAKE_SOURCE_DIR}/po/ptouch.pot
)
endforeach()
endif()
# compile po files
foreach(LINGUA IN LISTS LINGUAS)
gettext_process_po_files(
${LINGUA}
ALL
PO_FILES ${CMAKE_SOURCE_DIR}/po/${LINGUA}.po
)
endforeach()
# install mo files
foreach(LINGUA IN LISTS LINGUAS)
install(
FILES "${CMAKE_CURRENT_BINARY_DIR}/${LINGUA}.gmo"
DESTINATION "${CMAKE_INSTALL_LOCALEDIR}/${LINGUA}/LC_MESSAGES"
RENAME "${PROJECT_NAME}.mo"
)
endforeach()
endif()

View File

@ -56,7 +56,8 @@ msgstr ""
#: src/libptouch.c:158
#, c-format
msgid "No P-Touch printer found on USB (remember to put switch to position E)\n"
msgid ""
"No P-Touch printer found on USB (remember to put switch to position E)\n"
msgstr "Kein P-Ptouch Drucker am USB gefunden (Schalter muss auf E stehen)\n"
#: src/libptouch.c:178
@ -66,7 +67,6 @@ msgstr ""
#: src/libptouch.c:182
#, fuzzy, c-format
#| msgid "read error: got %i instead of 32 bytes\n"
msgid "write error: could send only %i of %ld bytes\n"
msgstr "Lesefehler: %i anstatt 32 bytes empfangen\n"
@ -152,7 +152,6 @@ msgstr ""
#: src/ptouch-print.c:133
#, fuzzy, c-format
#| msgid "ptouch_send() failed\n"
msgid "ptouch_sendraster() failed\n"
msgstr "ptouch_send() fehlgeschlagen\n"

View File

@ -55,8 +55,10 @@ msgstr "interface claim error: %s\n"
#: src/libptouch.c:158
#, c-format
msgid "No P-Touch printer found on USB (remember to put switch to position E)\n"
msgstr "No P-Touch printer found on USB (remember to put switch to position E)\n"
msgid ""
"No P-Touch printer found on USB (remember to put switch to position E)\n"
msgstr ""
"No P-Touch printer found on USB (remember to put switch to position E)\n"
#: src/libptouch.c:178
#, c-format
@ -65,7 +67,6 @@ msgstr "write error: %s\n"
#: src/libptouch.c:182
#, fuzzy, c-format
#| msgid "write error: could send only %i of %i bytes\n"
msgid "write error: could send only %i of %ld bytes\n"
msgstr "write error: could send only %i of %i bytes\n"

View File

@ -535,7 +535,11 @@ int main(int argc, char *argv[])
ptouch_dev ptdev = NULL;
setlocale(LC_ALL, "");
bindtextdomain("ptouch-print", "/usr/share/locale/");
const char *textdomain_dir = getenv("TEXTDOMAINDIR");
if (!textdomain_dir) {
textdomain_dir = "/usr/share/locale/";
}
bindtextdomain("ptouch-print", textdomain_dir);
textdomain("ptouch-print");
int i = parse_args(argc, argv);
if (i != argc) {