summaryrefslogtreecommitdiffstats
path: root/toolkit/locales/l10n.mk
diff options
context:
space:
mode:
Diffstat (limited to 'toolkit/locales/l10n.mk')
-rw-r--r--toolkit/locales/l10n.mk258
1 files changed, 258 insertions, 0 deletions
diff --git a/toolkit/locales/l10n.mk b/toolkit/locales/l10n.mk
new file mode 100644
index 0000000000..7ee13843b6
--- /dev/null
+++ b/toolkit/locales/l10n.mk
@@ -0,0 +1,258 @@
+# vim:set ts=8 sw=8 sts=8 noet:
+# This Source Code Form is subject to the terms of the Mozilla Public
+# License, v. 2.0. If a copy of the MPL was not distributed with this
+# file, You can obtain one at http://mozilla.org/MPL/2.0/.
+
+
+# Shared makefile that can be used to easily kick off l10n builds
+# of Mozilla applications.
+# This makefile should be included, and then assumes that the including
+# makefile defines the following targets:
+# l10n-%
+# This target should call into the various l10n targets that this
+# application depends on.
+# installer-%
+# This target should list all required targets, a typical rule would be
+# installers-%: clobber-% langpack-% repackage-zip-%
+# @echo "repackaging done"
+# to initially clobber the locale staging area, and then to build the
+# language pack and zip package.
+# Other targets like windows installers might be listed, too, and should
+# be defined in the including makefile.
+# The installer-% targets should not set AB_CD, so that the unpackaging
+# step finds the original package.
+# The including makefile should provide values for the variables
+# MOZ_APP_VERSION and MOZ_LANGPACK_EID.
+
+
+run_for_effects := $(shell if test ! -d $(DIST); then $(NSINSTALL) -D $(DIST); fi)
+
+# This makefile uses variable overrides from the l10n-% target to
+# build non-default locales to non-default dist/ locations. Be aware!
+
+LPROJ_ROOT = $(firstword $(subst -, ,$(AB_CD)))
+ifeq (cocoa,$(MOZ_WIDGET_TOOLKIT))
+ifeq (zh-TW,$(AB_CD))
+LPROJ_ROOT := $(subst -,_,$(AB_CD))
+endif
+endif
+
+# These are defaulted to be compatible with the files the wget-en-US target
+# pulls. You may override them if you provide your own files.
+ZIP_IN ?= $(ABS_DIST)/$(PACKAGE)
+WIN32_INSTALLER_IN ?= $(ABS_DIST)/$(PKG_INST_PATH)$(PKG_INST_BASENAME).exe
+
+# Allows overriding the final destination of the repackaged file
+ZIP_OUT ?= $(ABS_DIST)/$(PACKAGE)
+
+ACDEFINES += \
+ -DAB_CD=$(AB_CD) \
+ -DMOZ_LANGPACK_EID=$(MOZ_LANGPACK_EID) \
+ -DMOZ_APP_ID='$(MOZ_APP_ID)' \
+ -DMOZ_APP_VERSION=$(MOZ_APP_VERSION) \
+ -DMOZ_APP_MAXVERSION=$(MOZ_APP_MAXVERSION) \
+ -DLOCALE_SRCDIR=$(abspath $(LOCALE_SRCDIR)) \
+ -DPKG_BASENAME='$(PKG_BASENAME)' \
+ -DPKG_INST_BASENAME='$(PKG_INST_BASENAME)' \
+ $(NULL)
+
+# export some global defines for l10n repacks
+BASE_MERGE:=$(CURDIR)/merge-dir
+export REAL_LOCALE_MERGEDIR=$(BASE_MERGE)/$(AB_CD)
+# is an l10n repack step:
+export IS_LANGUAGE_REPACK
+# is a language pack:
+export IS_LANGPACK
+
+clobber-%: AB_CD=$*
+clobber-%:
+ $(RM) -rf $(DIST)/xpi-stage/locale-$*
+
+
+PACKAGER_NO_LIBS = 1
+
+ifeq (cocoa,$(MOZ_WIDGET_TOOLKIT))
+STAGEDIST = $(ABS_DIST)/l10n-stage/$(MOZ_PKG_DIR)/$(_APPNAME)/Contents/Resources
+else
+STAGEDIST = $(ABS_DIST)/l10n-stage/$(MOZ_PKG_DIR)
+endif
+UNPACKED_INSTALLER = $(ABS_DIST)/unpacked-installer
+
+include $(MOZILLA_DIR)/toolkit/mozapps/installer/packager.mk
+
+PACKAGE_BASE_DIR = $(ABS_DIST)/l10n-stage
+
+$(UNPACKED_INSTALLER): AB_CD:=en-US
+$(UNPACKED_INSTALLER): UNPACKAGE=$(call ESCAPE_WILDCARD,$(ZIP_IN))
+$(UNPACKED_INSTALLER): $(call ESCAPE_WILDCARD,$(ZIP_IN))
+# only mac needs to remove the parent of STAGEDIST...
+ifeq (cocoa,$(MOZ_WIDGET_TOOLKIT))
+ $(RM) -r -v $(UNPACKED_INSTALLER)
+else
+# ... and windows doesn't like removing STAGEDIST itself, remove all children
+ find $(UNPACKED_INSTALLER) -maxdepth 1 -print0 | xargs -0 $(RM) -r
+endif
+ $(NSINSTALL) -D $(UNPACKED_INSTALLER)
+ cd $(UNPACKED_INSTALLER) && \
+ $(INNER_UNMAKE_PACKAGE)
+
+
+unpack: $(UNPACKED_INSTALLER)
+ifeq ($(OS_ARCH), WINNT)
+ $(RM) -r -f $(ABS_DIST)/l10n-stage
+ $(NSINSTALL) -D $(ABS_DIST)/l10n-stage
+ $(call copy_dir, $(UNPACKED_INSTALLER), $(ABS_DIST)/l10n-stage)
+else
+ rsync -rav --delete $(UNPACKED_INSTALLER)/ $(ABS_DIST)/l10n-stage
+endif
+
+# The path to the object dir for the mozilla-central build system,
+# may be overridden if necessary.
+MOZDEPTH ?= $(DEPTH)
+
+repackage-zip: UNPACKAGE='$(ZIP_IN)'
+repackage-zip:
+ $(PYTHON3) $(MOZILLA_DIR)/toolkit/mozapps/installer/l10n-repack.py '$(STAGEDIST)' $(DIST)/xpi-stage/locale-$(AB_CD) \
+ $(MOZ_PKG_EXTRAL10N) \
+ $(if $(filter omni,$(MOZ_PACKAGER_FORMAT)),$(if $(NON_OMNIJAR_FILES),--non-resource $(NON_OMNIJAR_FILES)))
+
+ifeq (cocoa,$(MOZ_WIDGET_TOOLKIT))
+ifneq (en,$(LPROJ_ROOT))
+ mv '$(STAGEDIST)'/en.lproj '$(STAGEDIST)'/$(LPROJ_ROOT).lproj
+endif
+ifdef MOZ_CRASHREPORTER
+# On Mac OS X, the crashreporter.ini file needs to be moved from under the
+# application bundle's Resources directory where all other l10n files are
+# located to the crash reporter bundle's Resources directory.
+ mv '$(STAGEDIST)'/crashreporter.app/Contents/Resources/crashreporter.ini \
+ '$(STAGEDIST)'/../MacOS/crashreporter.app/Contents/Resources/crashreporter.ini
+ $(RM) -rf '$(STAGEDIST)'/crashreporter.app
+endif
+endif
+ifeq (WINNT,$(OS_ARCH))
+ $(MAKE) -C ../installer/windows CONFIG_DIR=l10ngen l10ngen/helper.exe
+ cp ../installer/windows/l10ngen/helper.exe $(STAGEDIST)/uninstall
+endif
+
+ $(NSINSTALL) -D $(DIST)/l10n-stage/$(PKG_PATH)
+ (cd $(DIST)/l10n-stage; \
+ $(MAKE_PACKAGE))
+ifdef MOZ_MAKE_COMPLETE_MAR
+ $(MAKE) -C $(MOZDEPTH)/tools/update-packaging full-update AB_CD=$(AB_CD) \
+ PACKAGE_BASE_DIR='$(ABS_DIST)/l10n-stage'
+endif
+# packaging done, undo l10n stuff
+ifneq (en,$(LPROJ_ROOT))
+ifeq (cocoa,$(MOZ_WIDGET_TOOLKIT))
+ mv '$(STAGEDIST)'/$(LPROJ_ROOT).lproj '$(STAGEDIST)'/en.lproj
+endif
+endif
+ $(NSINSTALL) -D $(DIST)/$(PKG_PATH)
+ mv -f '$(DIST)/l10n-stage/$(PACKAGE)' '$(ZIP_OUT)'
+ if test -f '$(DIST)/l10n-stage/$(PACKAGE).asc'; then mv -f '$(DIST)/l10n-stage/$(PACKAGE).asc' '$(ZIP_OUT).asc'; fi
+
+repackage-zip-%: unpack
+ @$(MAKE) repackage-zip AB_CD=$* ZIP_IN='$(ZIP_IN)'
+
+
+# Finding toolkit's defines.inc is hard for comm-central.
+# It needs to resolve mail's defines.inc relative to comm
+# for en-US, and toolkit's defines.inc relative to topsrcdir.
+# That's MOZILLA_DIR in their case, so fall back to that.
+# This is just needed for en-US, for repacks, all paths resolve
+# relative to the top-level REAL_LOCALE_MERGEDIR.
+LANGPACK_DEFINES = \
+ $(firstword \
+ $(wildcard $(call EXPAND_LOCALE_SRCDIR,toolkit/locales)/defines.inc) \
+ $(MOZILLA_DIR)/toolkit/locales/en-US/defines.inc \
+ ) \
+ $(LOCALE_SRCDIR)/defines.inc \
+$(NULL)
+
+# Dealing with app sub dirs: If DIST_SUBDIRS is defined it contains a
+# listing of app sub-dirs we should include in langpack xpis. If not,
+# check DIST_SUBDIR, and if that isn't present, just package the default
+# chrome directory and top-level localization for Fluent.
+PKG_ZIP_DIRS = chrome localization $(or $(DIST_SUBDIRS),$(DIST_SUBDIR))
+
+# Clone a l10n repository, either via hg or git
+# Make this a variable as it's embedded in a sh conditional
+ifeq ($(VCS_CHECKOUT_TYPE),hg)
+L10N_CO = $(HG) --cwd $(L10NBASEDIR) clone https://hg.mozilla.org/l10n-central/$(AB_CD)/
+else
+ifeq ($(VCS_CHECKOUT_TYPE),git)
+L10N_CO = $(GIT) -C $(L10NBASEDIR) clone hg://hg.mozilla.org/l10n-central/$(AB_CD)/
+else
+L10N_CO = $(error You need to use either hg or git)
+endif
+endif
+
+merge-%: IS_LANGUAGE_REPACK=1
+merge-%: AB_CD=$*
+merge-%:
+# For nightly builds, we automatically check out missing localizations
+# from l10n-central. We never automatically check out in automation:
+# automation builds check out revisions that have been signed-off by
+# l10n drivers prior to use.
+ifdef MOZ_AUTOMATION
+ if ! test -d $(L10NBASEDIR)/$(AB_CD) ; then \
+ echo 'Error: Automation requires l10n repositories to be checked out: $(L10NBASEDIR)/$(AB_CD)' ; \
+ exit 1 ; \
+ fi
+endif
+ifdef NIGHTLY_BUILD
+ if ! test -d $(L10NBASEDIR)/$(AB_CD) ; then \
+ echo 'Checking out $(L10NBASEDIR)/$(AB_CD)' ; \
+ $(NSINSTALL) -D $(L10NBASEDIR) ; \
+ $(L10N_CO) ; \
+ fi
+endif
+ $(RM) -rf $(REAL_LOCALE_MERGEDIR)
+ -$(PYTHON3) $(MOZILLA_DIR)/mach compare-locales --merge $(BASE_MERGE) $(srcdir)/l10n.toml $(L10NBASEDIR) $*
+# Hunspell dictionaries are interesting, as we don't ship the en-US
+# dictionary in repacks. Thus we can't use the merge logic from
+# compare-locales above, which would add en-US.dic and en-US.aff to
+# the merge directory.
+# Copy them to the merge dir, if exist. The repackaged app can still decide
+# on whether to package them or not in `l10n-%` and `chrome-%`.
+ if test -d $(L10NBASEDIR)/$(AB_CD)/extensions/spellcheck ; then \
+ $(NSINSTALL) -D $(REAL_LOCALE_MERGEDIR)/extensions/spellcheck/hunspell ; \
+ cp $(L10NBASEDIR)/$(AB_CD)/extensions/spellcheck/hunspell/*.* $(REAL_LOCALE_MERGEDIR)/extensions/spellcheck/hunspell ; \
+ fi
+
+langpack-%: IS_LANGUAGE_REPACK=1
+langpack-%: IS_LANGPACK=1
+langpack-%: AB_CD=$*
+langpack-%: clobber-%
+ @echo 'Making langpack $(LANGPACK_FILE)'
+ @$(MAKE) l10n-$(AB_CD)
+ @$(MAKE) package-langpack-$(AB_CD)
+
+package-langpack-%: LANGPACK_FILE=$(ABS_DIST)/$(PKG_LANGPACK_PATH)$(PKG_LANGPACK_BASENAME).xpi
+package-langpack-%: XPI_NAME=locale-$*
+package-langpack-%: AB_CD=$*
+package-langpack-%:
+ $(NSINSTALL) -D $(DIST)/$(PKG_LANGPACK_PATH)
+ $(call py_action,langpack_manifest,--locales $(AB_CD) --min-app-ver $(MOZ_APP_VERSION) --max-app-ver $(MOZ_APP_MAXVERSION) --app-name '$(MOZ_APP_DISPLAYNAME)' --l10n-basedir '$(L10NBASEDIR)' --defines $(LANGPACK_DEFINES) --langpack-eid '$(MOZ_LANGPACK_EID)' --input $(DIST)/xpi-stage/locale-$(AB_CD))
+ $(call py_action,zip,-C $(DIST)/xpi-stage/locale-$(AB_CD) -x **/*.manifest -x **/*.js -x **/*.ini $(LANGPACK_FILE) $(PKG_ZIP_DIRS) manifest.json)
+
+# This variable is to allow the wget-en-US target to know which ftp server to download from
+ifndef EN_US_BINARY_URL
+EN_US_BINARY_URL = $(error You must set EN_US_BINARY_URL)
+endif
+
+# Allow the overriding of PACKAGE format so we can get an EN_US build with a different
+# PACKAGE format than we are creating l10n packages with.
+EN_US_PACKAGE_NAME ?= $(PACKAGE)
+
+# This make target allows us to wget the latest en-US binary from a specified website
+# The make installers-% target needs the en-US binary in dist/
+# and for the windows repackages we need the .installer.exe in dist/sea
+wget-en-US:
+ifndef WGET
+ $(error Wget not installed)
+endif
+ $(NSINSTALL) -D $(ABS_DIST)/$(PKG_PATH)
+ (cd $(ABS_DIST)/$(PKG_PATH) && \
+ $(WGET) --no-cache -nv --no-iri -N -O $(PACKAGE) '$(EN_US_BINARY_URL)/$(EN_US_PACKAGE_NAME)')
+ @echo 'Downloaded $(EN_US_BINARY_URL)/$(EN_US_PACKAGE_NAME) to $(ABS_DIST)/$(PKG_PATH)/$(PACKAGE)'