summaryrefslogtreecommitdiffstats
path: root/src/po/Makefile
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-10 20:09:20 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-10 20:09:20 +0000
commit029f72b1a93430b24b88eb3a72c6114d9f149737 (patch)
tree765d5c2041967f9c6fef195fe343d9234a030e90 /src/po/Makefile
parentInitial commit. (diff)
downloadvim-029f72b1a93430b24b88eb3a72c6114d9f149737.tar.xz
vim-029f72b1a93430b24b88eb3a72c6114d9f149737.zip
Adding upstream version 2:9.1.0016.upstream/2%9.1.0016
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/po/Makefile')
-rw-r--r--src/po/Makefile299
1 files changed, 299 insertions, 0 deletions
diff --git a/src/po/Makefile b/src/po/Makefile
new file mode 100644
index 0000000..24f8104
--- /dev/null
+++ b/src/po/Makefile
@@ -0,0 +1,299 @@
+# Makefile for the Vim message translations.
+
+# Include stuff found by configure.
+include ../auto/config.mk
+
+# get LANGUAGES, MOFILES, MOCONVERTED and others
+include Make_all.mak
+
+# Note: ja.sjis, *.cp1250 and zh_CN.cp936 are only for MS-Windows, they are
+# not installed on Unix
+
+PACKAGE = vim
+SHELL = /bin/sh
+VIM = ../vim
+
+# MacOS sed is locale aware, set $LANG to avoid problems
+SED = LANG=C sed
+
+# The OLD_PO_FILE_INPUT and OLD_PO_FILE_OUTPUT are for the new GNU gettext
+# tools 0.10.37, which use a slightly different .po file format that is not
+# compatible with Solaris (and old gettext implementations) unless these are
+# set. gettext 0.10.36 will not work!
+MSGFMTCMD = OLD_PO_FILE_INPUT=yes $(MSGFMT) -v
+XGETTEXT = OLD_PO_FILE_INPUT=yes OLD_PO_FILE_OUTPUT=yes xgettext
+MSGMERGE = OLD_PO_FILE_INPUT=yes OLD_PO_FILE_OUTPUT=yes msgmerge
+
+.SUFFIXES:
+.SUFFIXES: .po .mo .pot .ck
+.PHONY: all install uninstall prefixcheck converted check clean checkclean distclean update-po $(LANGUAGES)
+
+.po.mo:
+ $(MSGFMTCMD) -o $@ $<
+
+.po.ck:
+ $(VIM) -u NONE --noplugins -e -s -X --cmd "set enc=utf-8" -S check.vim \
+ -c "if error == 0 | q | else | num 2 | cq | endif" $<
+ touch $@
+
+all: $(MOFILES) $(MOCONVERTED) $(MSGFMT_DESKTOP)
+
+check: $(CHECKFILES)
+
+# installing for real
+install: $(MOFILES) $(MOCONVERTED)
+ @$(MAKE) prefixcheck
+ for lang in $(LANGUAGES); do \
+ dir=$(LOCALEDIR)/$$lang/; \
+ if test ! -x "$$dir"; then \
+ mkdir $$dir; chmod 755 $$dir; \
+ fi; \
+ dir=$(LOCALEDIR)/$$lang/LC_MESSAGES; \
+ if test ! -x "$$dir"; then \
+ mkdir $$dir; chmod 755 $$dir; \
+ fi; \
+ if test -r $$lang.mo; then \
+ $(INSTALL_DATA) $$lang.mo $$dir/$(PACKAGE).mo; \
+ chmod $(FILEMOD) $$dir/$(PACKAGE).mo; \
+ fi; \
+ done
+
+uninstall:
+ @$(MAKE) prefixcheck
+ for cat in $(MOFILES) $(MOCONVERTED); do \
+ cat=`basename $$cat`; \
+ lang=`echo $$cat | $(SED) 's/\$(CATOBJEXT)$$//'`; \
+ rm -f $(LOCALEDIR)/$$lang/LC_MESSAGES/$(PACKAGE).mo; \
+ done
+
+# installing for local tryout into ../../runtime/lang
+tryoutinstall: $(MOFILES) $(MOCONVERTED)
+ @$(MAKE) prefixcheck
+ for lang in $(LANGUAGES); do \
+ dir=../../runtime/lang/$$lang/; \
+ if test ! -x "$$dir"; then \
+ mkdir $$dir; chmod 755 $$dir; \
+ fi; \
+ dir=../../runtime/lang/$$lang/LC_MESSAGES; \
+ if test ! -x "$$dir"; then \
+ mkdir $$dir; chmod 755 $$dir; \
+ fi; \
+ if test -r $$lang.mo; then \
+ cp $$lang.mo $$dir/$(PACKAGE).mo; \
+ chmod 644 $$dir/$(PACKAGE).mo; \
+ fi; \
+ done
+
+converted: $(MOCONVERTED)
+
+# nl.po was added later, if it does not exist use a file with just a # in it
+# (an empty file doesn't work with old msgfmt).
+nl.po:
+ @( echo \# > nl.po )
+
+# Norwegian/Bokmal: "nb" is an alias for "no".
+# Copying the file is not efficient, but I don't know of another way to make
+# this work.
+nb.po: no.po
+ cp no.po nb.po
+
+# Convert ja.po to create ja.sjis.po. Requires doubling backslashes in the
+# second byte. Don't depend on sjiscorr, it should only be compiled when
+# ja.sjis.po is outdated.
+ja.sjis.po: ja.po
+ @$(MAKE) sjiscorr
+ rm -f ja.sjis.po
+ iconv -f UTF-8 -t CP932 ja.po | ./sjiscorr > ja.sjis.po
+
+sjiscorr: sjiscorr.c
+ $(CC) -o sjiscorr sjiscorr.c
+
+ja.euc-jp.po: ja.po
+ iconv -f UTF-8 -t EUC-JP ja.po | \
+ $(SED) -e 's/charset=[uU][tT][fF]-8/charset=EUC-JP/' \
+ -e 's/# Original translations/# Generated from ja.po, DO NOT EDIT/' \
+ > ja.euc-jp.po
+
+# Convert cs.po to create cs.cp1250.po.
+cs.cp1250.po: cs.po
+ rm -f cs.cp1250.po
+ iconv -f ISO-8859-2 -t CP1250 cs.po | \
+ $(SED) -e 's/charset=[iI][sS][oO]-8859-2/charset=CP1250/' \
+ -e 's/# Original translations/# Generated from cs.po, DO NOT EDIT/' \
+ > cs.cp1250.po
+
+# Convert pl.po to create pl.cp1250.po.
+pl.cp1250.po: pl.po
+ rm -f pl.cp1250.po
+ iconv -f ISO-8859-2 -t CP1250 pl.po | \
+ $(SED) -e 's/charset=[iI][sS][oO]-8859-2/charset=CP1250/' \
+ -e 's/# Original translations/# Generated from pl.po, DO NOT EDIT/' \
+ > pl.cp1250.po
+
+# Convert pl.po to create pl.UTF-8.po.
+pl.UTF-8.po: pl.po
+ rm -f pl.UTF-8.po
+ iconv -f ISO-8859-2 -t UTF-8 pl.po | \
+ $(SED) -e 's/charset=[iI][sS][oO]-8859-2/charset=UTF-8/' \
+ -e 's/# Original translations/# Generated from pl.po, DO NOT EDIT/' \
+ > pl.UTF-8.po
+
+# Convert sk.po to create sk.cp1250.po.
+sk.cp1250.po: sk.po
+ rm -f sk.cp1250.po
+ iconv -f ISO-8859-2 -t CP1250 sk.po | \
+ $(SED) -e 's/charset=[iI][sS][oO]-8859-2/charset=CP1250/' \
+ -e 's/# Original translations/# Generated from sk.po, DO NOT EDIT/' \
+ > sk.cp1250.po
+
+# Convert zh_CN.UTF-8.po to create zh_CN.po.
+zh_CN.po: zh_CN.UTF-8.po
+ rm -f zh_CN.po
+ iconv -f UTF-8 -t GB2312 zh_CN.UTF-8.po | \
+ $(SED) -e 's/charset=[uU][tT][fF]-8/charset=GB2312/' \
+ -e 's/# Original translations/# Generated from zh_CN.UTF-8.po, DO NOT EDIT/' \
+ > zh_CN.po
+
+# Convert zh_CN.UTF-8.po to create zh_CN.cp936.po.
+# Set 'charset' to gbk to avoid that msfmt generates a warning.
+# This used to convert from zh_CN.po, but that results in a conversion error.
+zh_CN.cp936.po: zh_CN.UTF-8.po
+ rm -f zh_CN.cp936.po
+ iconv -f UTF-8 -t CP936 zh_CN.UTF-8.po | \
+ $(SED) -e 's/charset=[uU][tT][fF]-8/charset=GBK/' \
+ -e 's/# Original translations/# Generated from zh_CN.UTF-8.po, DO NOT EDIT/' \
+ > zh_CN.cp936.po
+
+# Convert zh_TW.UTF-8.po to create zh_TW.po
+zh_TW.po: zh_TW.UTF-8.po
+ rm -f zh_TW.po
+ iconv -f UTF-8 -t BIG5 zh_TW.UTF-8.po | \
+ $(SED) -e 's/charset=[uU][tT][fF]-8/charset=BIG5/' \
+ -e 's/# Original translations/# Generated from zh_TW.UTF-8.po, DO NOT EDIT/' \
+ > zh_TW.po
+
+
+# Convert zh_TW.UTF-8.po to create zh_TW.po with backslash characters
+# Requires doubling backslashes in the second byte. Don't depend on big5corr,
+# it should only be compiled when zh_TW.po is outdated.
+
+#
+# 06.11.23, added by Restorer
+# For more details, see:
+# https://github.com/vim/vim/pull/3261
+# https://github.com/vim/vim/pull/3476
+# https://github.com/vim/vim/pull/12153
+# (read all comments)
+#
+# I checked the workability on the list of backslash characters
+# specified in zh_TW.UTF-8.po. It works.
+# But it is better to have someone native speaker check it.
+#
+
+#zh_TW.po: zh_TW.UTF-8.po
+# @$(MAKE) big5corr
+# rm -f zh_TW.po
+# iconv -f UTF-8 -t BIG5 zh_TW.UTF-8.po | ./big5corr > zh_TW.po
+
+
+# 06.11.23, added by Restorer
+# see above in the zh_tw.po conversion section for backslashes.
+#big5corr: big5corr.c
+# $(CC) -o big5corr big5corr.c
+
+
+# Convert ko.UTF-8.po to create ko.po.
+ko.po: ko.UTF-8.po
+ rm -f ko.po
+ iconv -f UTF-8 -t EUC-KR ko.UTF-8.po | \
+ $(SED) -e 's/charset=[uU][tT][fF]-8/charset=EUC-KR/' \
+ -e 's/# Original translations/# Generated from ko.UTF-8.po, DO NOT EDIT/' \
+ > ko.po
+
+# Convert ru.po to create ru.cp1251.po.
+ru.cp1251.po: ru.po
+ rm -f ru.cp1251.po
+ iconv -f UTF-8 -t CP1251 ru.po | \
+ $(SED) -e 's/charset=[uU][tT][fF]-8/charset=CP1251/' \
+ -e 's/# Original translations/# Generated from ru.po, DO NOT EDIT/' \
+ > ru.cp1251.po
+
+# Convert uk.po to create uk.cp1251.po.
+uk.cp1251.po: uk.po
+ rm -f uk.cp1251.po
+ iconv -f UTF-8 -t CP1251 uk.po | \
+ $(SED) -e 's/charset=[uU][tT][fF]-8/charset=CP1251/' \
+ -e 's/# Original translations/# Generated from uk.po, DO NOT EDIT/' \
+ > uk.cp1251.po
+
+prefixcheck:
+ @if test "x" = "x$(prefix)"; then \
+ echo "******************************************"; \
+ echo " please use make from the src directory "; \
+ echo "******************************************"; \
+ exit 1; \
+ fi
+
+clean: checkclean
+ rm -f core core.* *.old.po *.mo *.pot sjiscorr
+ rm -f LINGUAS vim.desktop gvim.desktop tmp_*desktop
+# rm -f big5corr
+
+distclean: clean
+
+checkclean:
+ rm -f *.ck
+
+PO_INPUTLIST = \
+ ../*.c \
+ ../if_perl.xs \
+ ../GvimExt/gvimext.cpp \
+ ../errors.h \
+ ../globals.h \
+ ../if_py_both.h \
+ ../vim.h \
+ gvim.desktop.in \
+ vim.desktop.in
+
+$(PACKAGE).pot: $(PO_INPUTLIST) $(PO_VIM_INPUTLIST)
+ # Convert the Vim scripts to (what looks like) Javascript
+ $(VIM) -u NONE --not-a-term -S tojavascript.vim $(PACKAGE).pot $(PO_VIM_INPUTLIST)
+ # create vim.pot
+ $(XGETTEXT) --default-domain=$(PACKAGE) --add-comments \
+ $(XGETTEXT_KEYWORDS) $(PO_INPUTLIST) $(PO_VIM_JSLIST)
+ mv -f $(PACKAGE).po $(PACKAGE).pot
+ # Fix Vim scripts names, so that "gf" works
+ $(VIM) -u NONE --not-a-term -S fixfilenames.vim $(PACKAGE).pot $(PO_VIM_INPUTLIST)
+ # Delete the temporary files
+ rm *.js
+
+vim.desktop: vim.desktop.in $(POFILES)
+ echo $(LANGUAGES) | tr " " "\n" |$(SED) -e '/\./d' | sort > LINGUAS
+ $(MSGFMT) --desktop -d . --template vim.desktop.in -o tmp_vim.desktop
+ rm -f LINGUAS
+ if command -v desktop-file-validate; then desktop-file-validate tmp_vim.desktop; fi
+ mv tmp_vim.desktop vim.desktop
+
+# The dependency on vim.desktop is only to avoid the two targets are build at
+# the same time, which causes a race for the LINGUAS file.
+gvim.desktop: gvim.desktop.in $(POFILES) vim.desktop
+ echo $(LANGUAGES) | tr " " "\n" |$(SED) -e '/\./d' | sort > LINGUAS
+ $(MSGFMT) --desktop -d . --template gvim.desktop.in -o tmp_gvim.desktop
+ rm -f LINGUAS
+ if command -v desktop-file-validate; then desktop-file-validate tmp_gvim.desktop; fi
+ mv tmp_gvim.desktop gvim.desktop
+
+# When updating ja.sjis.po there are a bunch of errors and a crash.
+# The files that are converted to a different encoding clearly state "DO NOT EDIT".
+update-po: $(MOFILES:.mo=)
+
+# Don't add a dependency here, we only want to update the .po files manually
+$(LANGUAGES):
+ @$(MAKE) $(PACKAGE).pot
+ if test ! -f $@.po.orig; then cp $@.po $@.po.orig; fi
+ mv $@.po $@.po.old
+ if $(MSGMERGE) $@.po.old $(PACKAGE).pot -o $@.po; then \
+ rm -f $@.po.old; \
+ else \
+ echo "msgmerge for $@.po failed!"; mv $@.po.old $@.po; \
+ fi