]> git.vanrenterghem.biz Git - git.ikiwiki.info.git/blobdiff - po/Makefile
(no commit message)
[git.ikiwiki.info.git] / po / Makefile
index cef2ec87977baec52ebdf5c6c294428660d67b0e..bd218c6e19352b02b77e5a0cedb32040077062dd 100644 (file)
@@ -5,16 +5,29 @@ POTFILES=$(sort $(shell find ../IkiWiki -type f -name \*.pm)) \
 POFILES=$(wildcard *.po)
 MOFILES=$(POFILES:.po=.mo)
 
-all: ikiwiki.pot mo ../underlays/locale
+# Translated underlays can only be generated if po4a is available.
+TRANSLATED_UNDERLAYS=$(shell if perl -e 'use Locale::Po4a::Common' 2>/dev/null; then echo ../underlays/locale; fi)
+
+all: ikiwiki.pot mo $(TRANSLATED_UNDERLAYS)
 
 mo: $(MOFILES)
 
 install: all
+       # Normal mo files for program translation.
        for file in $(MOFILES); do \
                lang=`echo $$file | sed 's/\.mo//'`; \
                install -d $(DESTDIR)$(PREFIX)/share/locale/$$lang/LC_MESSAGES/; \
                install -m 0644 $$file $(DESTDIR)$(PREFIX)/share/locale/$$lang/LC_MESSAGES/ikiwiki.mo; \
        done
+       
+       # Underlay translation via po files that go in special per-language
+       # underlays.
+       for file in `find underlays -type f -name \*.po | sed -e 's|^underlays/||'`; do \
+               lang=`echo $$file | sed -e 's/.po$$//' -e 's/.*\\.//'`; \
+               dir=`dirname "$(DESTDIR)$(PREFIX)/share/ikiwiki/po/$$lang/$$file"`; \
+               install -d $$dir; \
+               install -m 0644 underlays/$$file $$dir; \
+       done
 
 ikiwiki.pot: $(POTFILES)
        @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 \
@@ -24,23 +37,26 @@ ikiwiki.pot: $(POTFILES)
 
 clean:
        rm -f $(MOFILES) messages messages.mo *_stamp
-       rm -rf html underlays/.ikiwiki ../underlays/locale
-       find underlays -name \*.mdwn | xargs rm -f
+       rm -rf html underlays/.ikiwiki $(TRANSLATED_UNDERLAYS)
+       find underlays -name \*.mdwn -or -name \*.pot | xargs rm -f
 
 %.mo: %.po
-       msgfmt -o $@ $<
+       @if ! msgfmt -o $@ $<; then echo "unable to run msgfmt"; fi
 
 %.po: ikiwiki.pot
        @echo -n "Merging ikiwiki.pot and $@"
-       @msgmerge $@ ikiwiki.pot -o $@.new 2>&1
-# Typically all that changes was a date or line number. I'd prefer not to
+# Typically all that changes is a date or line number. I'd prefer not to
 # commit such changes, so detect and ignore them.
-       @if [ "`diff $@ $@.new | grep '[<>]' | grep -v '[<>] #:' | wc -l`" -ne 2 ]; then \
-               mv -f $@.new $@; \
+       @if ! msgmerge $@ ikiwiki.pot -o $@.new 2>&1; then \
+               echo "unable to run msgmerge"; \
        else \
-               rm -f $@.new; \
+               if [ "`diff $@ $@.new | grep '[<>]' | grep -v '[<>] #:' | wc -l`" -ne 2 ]; then \
+                       mv -f $@.new $@; \
+               else \
+                       rm -f $@.new; \
+               fi; \
+               msgfmt --statistics $@ 2>&1; \
        fi
-       @msgfmt --statistics $@ 2>&1
 
 check:
        @for file in $(POFILES); do \
@@ -61,13 +77,19 @@ underlays_copy_stamp:
                cp -a ../$$file underlays/directives/ikiwiki/directive ||  \
                install -m 644 ../$$file underlays/directives/ikiwiki/directive; \
        done
+       install -d underlays/empty
        touch $@
 
-underlays: underlays_copy_stamp
-       install -d underlays/empty
-       ../ikiwiki.out -libdir .. -setup underlay.setup -refresh
+underlays: ../ikiwiki.out underlays_copy_stamp
+       ../ikiwiki.out --libdir .. --setup underlay.setup --refresh
+
+../ikiwiki.out: ../Makefile
+       $(MAKE) -C .. ikiwiki.out
+
+../Makefile: ../Makefile.PL
+       cd .. && ./Makefile.PL
 
-../underlays/locale: po2wiki_stamp
+$(TRANSLATED_UNDERLAYS): po2wiki_stamp
 po2wiki_stamp: po2wiki underlays_copy_stamp
        PERL5LIB=.. ./po2wiki underlay.setup
        touch $@