diff options
author | Arch Librarian <arch@canonical.com> | 2004-09-20 16:59:32 +0000 |
---|---|---|
committer | Arch Librarian <arch@canonical.com> | 2004-09-20 16:59:32 +0000 |
commit | 89409d33dc8d3156d089f4f90a02b39a04a9d952 (patch) | |
tree | 61ecafa787f65986611097f2ad796b8806d8fcd9 /po/makefile | |
parent | a8c2695ba741509159fdf5477d036c3b87507724 (diff) | |
download | apt-89409d33dc8d3156d089f4f90a02b39a04a9d952.tar.gz |
First cut of i18n stuff
Author: jgg
Date: 2002-10-16 05:22:35 GMT
First cut of i18n stuff
Diffstat (limited to 'po/makefile')
-rw-r--r-- | po/makefile | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/po/makefile b/po/makefile new file mode 100644 index 000000000..5abbb8118 --- /dev/null +++ b/po/makefile @@ -0,0 +1,70 @@ +# -*- make -*- + +# This will compile the gettext message catalogues. + +# The other make files drop file lists in build/po/domains/DOMAIN/* which +# is then picked up by this make file to define all the domains and all the +# source files that compose each domain. It then produces the POT files +# and then filters the PO files through the per-domain POT file to create +# the input to msgformat, which is then dumped into a locale directory. + +BASE=.. +SUBDIR=po + +# Bring in the default rules +include ../buildlib/defaults.mak + +DOMAINS = $(notdir $(wildcard $(PO_DOMAINS)/*)) +POTFILES := $(addsuffix .pot,$(addprefix $(PO)/,$(DOMAINS))) + +# Construct a list of all mo files for all domains under $(PO_DOMAINS) +MOFILES := $(patsubst %.gmo,%.mo,$(CATALOGS)) +MOFILES := $(foreach D,$(DOMAINS),$(addprefix $(PO_DOMAINS)/$(D)/,$(MOFILES))) +LANG_POFILES := $(patsubst %.mo,%.po,$(MOFILES)) +LINGUAS := $(patsubst %.gmo,%,$(CATALOGS)) + +GETDOMAIN = $(filter $(DOMAINS),$(subst /, ,$(1))) +# Generate the list of files from the bits the other make files dropped +# and produce the .pot file. +$(POTFILES) : $(PO)/%.pot : + echo Generating POT file $@ + echo $@ : $(wildcard $(PO)/domains/$*/*.*list) $(addprefix $(BASE)/,$(shell cat $(wildcard $(PO)/domains/$*/*.srclist))) > $@.d +# From sh source + cat $(PO)/domains/$*/*.shlist 2> /dev/null | (cd $(BASE) && xargs -n1 bash --dump-po-strings) > $(PO)/domains/$*/sh.pot +# From C/C++ source + cat $(PO)/domains/$*/*.srclist > $(PO)/POTFILES_$*.in + $(XGETTEXT) --default-domain=$* --directory=$(BASE) \ + --add-comments --foreign --keyword=_ --keyword=N_ \ + --files-from=$(PO)/POTFILES_$*.in -o $(PO)/domains/$*/c.pot + rm -f $(PO)/POTFILES_$*.in + $(MSGCOMM) --more-than=0 $(PO)/domains/$*/c.pot $(PO)/domains/$*/sh.pot --output=$@ + +$(PO)/$(PACKAGE)-all.pot: $(POTFILES) + $(MSGCOMM) --more-than=0 $(POTFILES) --output=$@ + +# Filter the complete translation with the domain specific file to produce +# only the subtext needed for this domain +# We cannot express the dependencies required for this directly with a pattern +# rule, so we use the .d hack. +$(LANG_POFILES) : %.po : + echo Generating $@ + echo $@ : $(notdir $@) $(PO)/$(call GETDOMAIN,$*).pot > $(PO)/$(call GETDOMAIN,$*)_$(notdir $@).d + $(MSGMERGE) $(notdir $@) $(PO)/$(call GETDOMAIN,$*).pot -o $@ + +$(MOFILES) : %.mo : %.po + echo Generating $(LOCALE)/$(notdir $*)/LC_MESSAGES/$(call GETDOMAIN,$*).mo + $(GMSGFMT) --statistics -o $@ $< + mkdir -p $(LOCALE)/$(notdir $*)/LC_MESSAGES/ + cp $@ $(LOCALE)/$(notdir $*)/LC_MESSAGES/$(call GETDOMAIN,$*).mo + +binary: $(POTFILES) $(PO)/$(PACKAGE)-all.pot $(MOFILES) + +clean: clean/local +clean/local: + rm -f $(MOFILES) $(LANG_POFILES) $(PO)/*.d + +# Include the dependencies that are available +The_DFiles = $(wildcard $(PO)/*.d) +ifneq ($(words $(The_DFiles)),0) +include $(The_DFiles) +endif |