Merged from the latest developing branch.
[MacVim.git] / src / po / Makefile
blobe6290caaa7c577e54ca4ffba62e586e4a6dc53ae
1 # Makefile for the Vim message translations.
3 # TODO make this configurable
4 # Note: ja.sjis, *.cp1250 and zh_CN.cp936 are only for MS-Windows, they are
5 # not installed on Unix
7 LANGUAGES = \
8 af \
9 ca \
10 cs \
11 de \
12 en_GB \
13 eo \
14 es \
15 fi \
16 fr \
17 ga \
18 it \
19 ja \
20 ko \
21 no \
22 pl \
23 pt_BR \
24 ru \
25 sk \
26 sv \
27 uk \
28 vi \
29 zh_CN \
30 zh_CN.UTF-8 \
31 zh_TW \
32 zh_TW.UTF-8
34 MOFILES = \
35 af.mo \
36 ca.mo \
37 cs.mo \
38 de.mo \
39 en_GB.mo \
40 eo.mo \
41 es.mo \
42 fi.mo \
43 fr.mo \
44 ga.mo \
45 it.mo \
46 ja.mo \
47 ko.mo \
48 no.mo \
49 pl.mo \
50 pt_BR.mo \
51 ru.mo \
52 sk.mo \
53 sv.mo \
54 uk.mo \
55 vi.mo \
56 zh_CN.UTF-8.mo \
57 zh_CN.mo \
58 zh_TW.UTF-8.mo \
59 zh_TW.mo
61 CONVERTED = \
62 cs.cp1250.mo \
63 ja.sjis.mo \
64 pl.cp1250.mo \
65 pl.UTF-8.mo \
66 ru.cp1251.mo \
67 sk.cp1250.mo \
68 uk.cp1251.mo \
69 zh_CN.cp936.mo
71 CHECKFILES = \
72 af.ck \
73 ca.ck \
74 cs.ck \
75 de.ck \
76 en_GB.ck \
77 eo.ck \
78 es.ck \
79 fi.ck \
80 fr.ck \
81 ga.ck \
82 it.ck \
83 ja.ck \
84 ko.ck \
85 no.ck \
86 pl.ck \
87 pt_BR.ck \
88 ru.ck \
89 sk.ck \
90 sv.ck \
91 uk.ck \
92 vi.ck \
93 zh_CN.UTF-8.ck \
94 zh_CN.ck \
95 zh_TW.UTF-8.ck \
96 zh_TW.ck \
97 cs.cp1250.ck \
98 ja.sjis.ck \
99 pl.cp1250.ck \
100 pl.UTF-8.ck \
101 ru.cp1251.ck \
102 sk.cp1250.ck \
103 uk.cp1251.ck \
104 zh_CN.cp936.ck
106 PACKAGE = vim
107 SHELL = /bin/sh
108 VIM = ../vim
110 # The OLD_PO_FILE_INPUT and OLD_PO_FILE_OUTPUT are for the new GNU gettext
111 # tools 0.10.37, which use a slightly different .po file format that is not
112 # compatible with Solaris (and old gettext implementations) unless these are
113 # set. gettext 0.10.36 will not work!
114 MSGFMT = OLD_PO_FILE_INPUT=yes msgfmt -v
115 XGETTEXT = OLD_PO_FILE_INPUT=yes OLD_PO_FILE_OUTPUT=yes xgettext
116 MSGMERGE = OLD_PO_FILE_INPUT=yes OLD_PO_FILE_OUTPUT=yes msgmerge
118 .SUFFIXES:
119 .SUFFIXES: .po .mo .pot .ck
120 .PHONY: all install uninstall prefixcheck converted check clean checkclean distclean update-po $(LANGUAGES)
122 .po.mo:
123 $(MSGFMT) -o $@ $<
125 .po.ck:
126 $(VIM) -u NONE -e -S check.vim -c "if error == 0 | q | endif" -c cq $<
127 touch $@
129 all: $(MOFILES)
131 check: $(CHECKFILES)
133 install: $(MOFILES)
134 @$(MAKE) prefixcheck
135 for lang in $(LANGUAGES); do \
136 dir=$(LOCALEDIR)/$$lang/; \
137 if test ! -x "$$dir"; then \
138 mkdir $$dir; chmod 755 $$dir; \
139 fi; \
140 dir=$(LOCALEDIR)/$$lang/LC_MESSAGES; \
141 if test ! -x "$$dir"; then \
142 mkdir $$dir; chmod 755 $$dir; \
143 fi; \
144 if test -r $$lang.mo; then \
145 $(INSTALL_DATA) $$lang.mo $$dir/$(PACKAGE).mo; \
146 chmod $(FILEMOD) $$dir/$(PACKAGE).mo; \
147 fi; \
148 done
150 uninstall:
151 @$(MAKE) prefixcheck
152 for cat in $(MOFILES); do \
153 cat=`basename $$cat`; \
154 lang=`echo $$cat | sed 's/\$(CATOBJEXT)$$//'`; \
155 rm -f $(LOCALEDIR)/$$lang/LC_MESSAGES/$(PACKAGE).mo; \
156 done
158 converted: $(CONVERTED)
160 # Convert ja.po to create ja.sjis.po. Requires doubling backslashes in the
161 # second byte. Don't depend on sjiscorr, it should only be compiled when
162 # ja.sjis.po is outdated.
163 ja.sjis.po: ja.po
164 @$(MAKE) sjiscorr
165 rm -f ja.sjis.po
166 iconv -f euc-jp -t cp932 ja.po | ./sjiscorr > ja.sjis.po
168 sjiscorr: sjiscorr.c
169 $(CC) -o sjiscorr sjiscorr.c
171 # Convert cs.po to create cs.cp1250.po.
172 cs.cp1250.po: cs.po
173 rm -f cs.cp1250.po
174 iconv -f iso-8859-2 -t cp1250 cs.po | \
175 sed -e 's/charset=ISO-8859-2/charset=cp1250/' -e 's/# Original translations/# Generated from cs.po, DO NOT EDIT/' > cs.cp1250.po
177 # Convert pl.po to create pl.cp1250.po.
178 pl.cp1250.po: pl.po
179 rm -f pl.cp1250.po
180 iconv -f iso-8859-2 -t cp1250 pl.po | \
181 sed -e 's/charset=ISO-8859-2/charset=cp1250/' -e 's/# Original translations/# Generated from pl.po, DO NOT EDIT/' > pl.cp1250.po
183 # Convert pl.po to create pl.UTF-8.po.
184 pl.UTF-8.po: pl.po
185 rm -f pl.UTF-8.po
186 iconv -f iso-8859-2 -t utf-8 pl.po | \
187 sed -e 's/charset=ISO-8859-2/charset=utf-8/' -e 's/# Original translations/# Generated from pl.po, DO NOT EDIT/' > pl.UTF-8.po
189 # Convert sk.po to create sk.cp1250.po.
190 sk.cp1250.po: sk.po
191 rm -f sk.cp1250.po
192 iconv -f iso-8859-2 -t cp1250 sk.po | \
193 sed -e 's/charset=ISO-8859-2/charset=cp1250/' -e 's/# Original translations/# Generated from sk.po, DO NOT EDIT/' > sk.cp1250.po
195 # Convert zh_CN.po to create zh_CN.cp936.po.
196 # set 'charset' to gbk to avoid that msfmt generates a warning
197 zh_CN.cp936.po: zh_CN.po
198 rm -f zh_CN.cp936.po
199 iconv -f gb2312 -t cp936 zh_CN.po | \
200 sed -e 's/charset=gb2312/charset=gbk/' -e 's/# Original translations/# Generated from zh_CN.po, DO NOT EDIT/' > zh_CN.cp936.po
202 # Convert ru.po to create ru.cp1251.po.
203 ru.cp1251.po: ru.po
204 rm -f ru.cp1251.po
205 iconv -f utf-8 -t cp1251 ru.po | \
206 sed -e 's/charset=utf-8/charset=cp1251/' -e 's/# Original translations/# Generated from ru.po, DO NOT EDIT/' > ru.cp1251.po
208 # Convert uk.po to create uk.cp1251.po.
209 uk.cp1251.po: uk.po
210 rm -f uk.cp1251.po
211 iconv -f utf-8 -t cp1251 uk.po | \
212 sed -e 's/charset=utf-8/charset=cp1251/' -e 's/# Original translations/# Generated from uk.po, DO NOT EDIT/' > uk.cp1251.po
214 prefixcheck:
215 @if test "x" = "x$(prefix)"; then \
216 echo "******************************************"; \
217 echo " please use make from the src directory "; \
218 echo "******************************************"; \
219 exit 1; \
222 clean: checkclean
223 rm -f core core.* *.old.po *.mo *.pot sjiscorr
225 distclean: clean
227 checkclean:
228 rm -f *.ck
231 # NOTE: If you get an error for gvimext.cpp not found, you need to unpack the
232 # extra archive.
234 $(PACKAGE).pot: ../*.c ../if_perl.xs ../GvimExt/gvimext.cpp ../globals.h
235 cd ..; $(XGETTEXT) --default-domain=$(PACKAGE) \
236 --add-comments --keyword=_ --keyword=N_ \
237 *.c if_perl.xs GvimExt/gvimext.cpp globals.h
238 mv -f ../$(PACKAGE).po $(PACKAGE).pot
240 update-po: $(LANGUAGES)
242 # Don't add a dependency here, we only want to update the .po files manually
243 $(LANGUAGES):
244 @$(MAKE) $(PACKAGE).pot
245 if test ! -f $@.po.orig; then cp $@.po $@.po.orig; fi
246 mv $@.po $@.po.old
247 if $(MSGMERGE) $@.po.old $(PACKAGE).pot -o $@.po; then \
248 rm -f $@.po.old; \
249 else \
250 echo "msgmerge for $@.po failed!"; mv $@.po.old $@.po; \