aboutsummaryrefslogtreecommitdiff
path: root/cmake
diff options
context:
space:
mode:
authorJohn Szakmeister <john@szakmeister.net>2014-07-17 07:16:56 -0400
committerJohn Szakmeister <john@szakmeister.net>2014-07-17 07:17:35 -0400
commite057676a89fb692f2569d7e586ea26d323428de4 (patch)
tree24c8149b07972d06a987bab9807978fc26045c55 /cmake
parentc261b351ed40365a88d78f23c609a290ac0c8456 (diff)
parent92558ee3a4ad5572e0d848a098593381f7941ef5 (diff)
downloadrneovim-e057676a89fb692f2569d7e586ea26d323428de4.tar.gz
rneovim-e057676a89fb692f2569d7e586ea26d323428de4.tar.bz2
rneovim-e057676a89fb692f2569d7e586ea26d323428de4.zip
Merge #928 'Move po gen to cmake'
This includes the necessary fixes to sv.po to make the build work again.
Diffstat (limited to 'cmake')
-rw-r--r--cmake/ConvertPo.cmake21
-rw-r--r--cmake/RunMsgfmt.cmake9
-rw-r--r--cmake/RunMsgmerge.cmake11
-rw-r--r--cmake/RunXgettext.cmake14
4 files changed, 55 insertions, 0 deletions
diff --git a/cmake/ConvertPo.cmake b/cmake/ConvertPo.cmake
new file mode 100644
index 0000000000..2282b96f56
--- /dev/null
+++ b/cmake/ConvertPo.cmake
@@ -0,0 +1,21 @@
+string(TOUPPER ${INPUT_ENC} upperInputEnc)
+string(TOLOWER ${INPUT_ENC} lowerInputEnc)
+get_filename_component(inputName ${INPUT_FILE} NAME)
+execute_process(
+ COMMAND ${ICONV_PRG} -f ${INPUT_ENC} -t ${OUTPUT_ENC} ${INPUT_FILE}
+ OUTPUT_VARIABLE trans
+ ERROR_VARIABLE err
+ RESULT_VARIABLE res)
+if(NOT res EQUAL 0)
+ message(FATAL_ERROR "iconv failed to run correctly: ${err}")
+endif()
+
+string(REPLACE "charset=${lowerInputEnc}" "charset=${OUTPUT_CHARSET}"
+ trans "${trans}")
+string(REPLACE "charset=${upperInputEnc}" "charset=${OUTPUT_CHARSET}"
+ trans "${trans}")
+string(REPLACE "# Original translations"
+ "# Generated from ${inputName}, DO NOT EDIT"
+ trans "${trans}")
+
+file(WRITE ${OUTPUT_FILE} "${trans}")
diff --git a/cmake/RunMsgfmt.cmake b/cmake/RunMsgfmt.cmake
new file mode 100644
index 0000000000..51606338e0
--- /dev/null
+++ b/cmake/RunMsgfmt.cmake
@@ -0,0 +1,9 @@
+set(ENV{OLD_PO_FILE_INPUT} yes)
+
+execute_process(
+ COMMAND ${MSGFMT_PRG} -o ${MO_FILE} ${PO_FILE}
+ ERROR_VARIABLE err
+ RESULT_VARIABLE res)
+if(NOT res EQUAL 0)
+ message(FATAL_ERROR "msgfmt failed to run correctly: ${err}")
+endif()
diff --git a/cmake/RunMsgmerge.cmake b/cmake/RunMsgmerge.cmake
new file mode 100644
index 0000000000..69e5c7276d
--- /dev/null
+++ b/cmake/RunMsgmerge.cmake
@@ -0,0 +1,11 @@
+set(ENV{OLD_PO_FILE_INPUT} yes)
+set(ENV{OLD_PO_FILE_OUTPUT} yes)
+
+execute_process(
+ COMMAND ${MSGMERGE_PRG} -q --update --backup=none --sort-by-file
+ ${PO_FILE} ${POT_FILE}
+ ERROR_VARIABLE err
+ RESULT_VARIABLE res)
+if(NOT res EQUAL 0)
+ message(FATAL_ERROR "msgmerge failed to run correctly: ${err}")
+endif()
diff --git a/cmake/RunXgettext.cmake b/cmake/RunXgettext.cmake
new file mode 100644
index 0000000000..c9328b151d
--- /dev/null
+++ b/cmake/RunXgettext.cmake
@@ -0,0 +1,14 @@
+set(ENV{OLD_PO_FILE_INPUT} yes)
+set(ENV{OLD_PO_FILE_OUTPUT} yes)
+
+list(SORT SOURCES)
+
+execute_process(
+ COMMAND ${XGETTEXT_PRG} -o ${POT_FILE} --default-domain=nvim
+ --add-comments --keyword=_ --keyword=N_ -D ${SEARCH_DIR}
+ ${SOURCES}
+ ERROR_VARIABLE err
+ RESULT_VARIABLE res)
+if(NOT res EQUAL 0)
+ message(FATAL_ERROR "xgettext failed to run correctly: ${err}")
+endif()