Merge branch 'bugs'
[ikiwiki] / po / Makefile
CommitLineData
912521ef 1# List here all source files with translatable strings.
2POTFILES=$(sort $(shell find ../IkiWiki -type f -name \*.pm)) \
3 ../ikiwiki.in ../IkiWiki.pm
4
5POFILES=$(wildcard *.po)
6MOFILES=$(POFILES:.po=.mo)
7
479f75ab
JH
8all: ikiwiki.pot mo
9
10mo: $(MOFILES)
912521ef 11
12install: all
13 for file in $(MOFILES); do \
14 lang=`echo $$file | sed 's/\.mo//'`; \
15 install -d $(DESTDIR)$(PREFIX)/share/locale/$$lang/LC_MESSAGES/; \
16 install -m 0644 $$file $(DESTDIR)$(PREFIX)/share/locale/$$lang/LC_MESSAGES/ikiwiki.mo; \
17 done
18
19ikiwiki.pot: $(POTFILES)
8b3a840a 20 @if perl -e '($$ver)=`xgettext -V | head -n 1`=~/.*\s+([0-9]+\.[0-9]+)/; die "gettext $$ver too old, not updating the pot file\n" if $$ver < 0.16'; then \
21 echo "Rebuilding the pot file"; \
22 xgettext $(POTFILES) -o ikiwiki.pot -Lperl --add-comments=translators; \
23 fi
912521ef 24
25clean:
d1636b63 26 rm -f $(MOFILES) messages messages.mo
912521ef 27
28%.mo: %.po
29 msgfmt -o $@ $<
30
479f75ab 31%.po:
912521ef 32 @echo -n "Merging ikiwiki.pot and $@"
3b5f0e6c 33 @msgmerge $@ ikiwiki.pot -o $@.new 2>&1
d0804acd 34# Typically all that changes was a date or line number. I'd prefer not to
35# commit such changes, so detect and ignore them.
36 @if [ "`diff $@ $@.new | grep '[<>]' | grep -v '[<>] #:' | wc -l`" -ne 2 ]; then \
912521ef 37 mv -f $@.new $@; \
38 else \
39 rm -f $@.new; \
40 fi
3b5f0e6c 41 @msgfmt --statistics $@ 2>&1
912521ef 42
43check:
44 @for file in $(POFILES); do \
45 lang=`echo $$file | sed 's/\.po//'`; \
46 printf "$$lang: "; \
47 msgfmt -o /dev/null -c -v --statistics $$lang.po;\
48 done