X-Git-Url: http://git.vanrenterghem.biz/git.ikiwiki.info.git/blobdiff_plain/d1636b63239ba9ee59d97454ff6fddf6b386fae8..899c319191c8f82b03f7d67f3feeeae437423e2f:/po/Makefile?ds=sidebyside

diff --git a/po/Makefile b/po/Makefile
index a415854a2..013cdf268 100644
--- a/po/Makefile
+++ b/po/Makefile
@@ -5,7 +5,9 @@ POTFILES=$(sort $(shell find ../IkiWiki -type f -name \*.pm)) \
 POFILES=$(wildcard *.po)
 MOFILES=$(POFILES:.po=.mo)
 
-all: ikiwiki.pot $(MOFILES)
+all: ikiwiki.pot mo
+
+mo: $(MOFILES)
 
 install: all
 	for file in $(MOFILES); do \
@@ -15,8 +17,10 @@ install: all
 	done
 
 ikiwiki.pot: $(POTFILES)
-	@echo "Rebuilding the pot file"
-	xgettext $(POTFILES) -o ikiwiki.pot -Lperl --add-comments=translators
+	@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 \
+		echo "Rebuilding the pot file"; \
+		xgettext $(POTFILES) -o ikiwiki.pot -Lperl --add-comments=translators; \
+	fi
 
 clean:
 	rm -f $(MOFILES) messages messages.mo
@@ -24,12 +28,12 @@ clean:
 %.mo: %.po
 	msgfmt -o $@ $<
 
-%.po: ikiwiki.pot
+%.po:
 	@echo -n "Merging ikiwiki.pot and $@"
 	@msgmerge $@ ikiwiki.pot -o $@.new 2>&1
-# Typically all that changes was a date. I'd prefer not to commit such
-# changes, so detect and ignore them.
-	@if [ "`diff $@ $@.new | grep '[<>]' | wc -l`" -ne 2 ]; then \
+# Typically all that changes was 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 $@; \
 	else \
 		rm -f $@.new; \