# 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: # libs-% # This target should call into the various libs 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 libs-% 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/signing.mk 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) ifdef MOZ_MAKE_COMPLETE_MAR MAKE_COMPLETE_MAR = 1 ifeq ($(OS_ARCH), WINNT) ifneq ($(MOZ_PKG_FORMAT), SFX7Z) MAKE_COMPLETE_MAR = endif endif endif repackage-zip: UNPACKAGE='$(ZIP_IN)' repackage-zip: libs-$(AB_CD) # call a hook for apps to put their uninstall helper.exe into the package $(UNINSTALLER_PACKAGE_HOOK) # call a hook for apps to build the stub installer ifdef MOZ_STUB_INSTALLER $(STUB_HOOK) endif $(PYTHON) $(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 $(NSINSTALL) -D $(DIST)/l10n-stage/$(PKG_PATH) cd $(DIST)/l10n-stage; \ $(MAKE_PACKAGE) ifdef 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)' ifdef IS_LANGUAGE_REPACK MERGE_TK_FILE = $(firstword \ $(wildcard $(REAL_LOCALE_MERGEDIR)/$(subst /locales,,toolkit/locales)/$(1)) \ $(wildcard $(LOCALE_SRCDIR)/$(1)) \ $(call EXPAND_LOCALE_SRCDIR,toolkit/locales)/$(1) ) else MERGE_TK_FILE = $(call EXPAND_LOCALE_SRCDIR,toolkit/locales)/$(1) endif LANGPACK_DEFINES = $(call MERGE_TK_FILE,defines.inc) $(call MERGE_DIR,defines.inc) # 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. PKG_ZIP_DIRS = chrome $(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. ifdef NIGHTLY_BUILD @if ! test -d $(L10NBASEDIR)/$(AB_CD) ; then \ $(NSINSTALL) -D $(L10NBASEDIR) ; \ $(L10N_CO) ; \ fi endif $(RM) -rf $(REAL_LOCALE_MERGEDIR) -$(MOZILLA_DIR)/mach compare-locales --merge $(BASE_MERGE) $(srcdir)/l10n.toml $(L10NBASEDIR) $* langpack-%: LANGPACK_FILE=$(ABS_DIST)/$(PKG_LANGPACK_PATH)$(PKG_LANGPACK_BASENAME).xpi langpack-%: AB_CD=$* langpack-%: XPI_NAME=locale-$* langpack-%: IS_LANGUAGE_REPACK=1 langpack-%: IS_LANGPACK=1 langpack-%: libs-% @echo 'Making langpack $(LANGPACK_FILE)' $(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) --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 # In taskcluster the installer comes from another location ifndef EN_US_INSTALLER_BINARY_URL EN_US_INSTALLER_BINARY_URL = $(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) EN_US_PKG_INST_BASENAME ?= $(PKG_INST_BASENAME) # 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)' ifdef RETRIEVE_WINDOWS_INSTALLER ifeq ($(OS_ARCH), WINNT) $(NSINSTALL) -D $(ABS_DIST)/$(PKG_INST_PATH) (cd $(ABS_DIST)/$(PKG_INST_PATH) && \ $(WGET) --no-cache -nv --no-iri -N -O $(PKG_INST_BASENAME).exe '$(EN_US_INSTALLER_BINARY_URL)/$(PKG_PATH)$(EN_US_PKG_INST_BASENAME).exe') @echo 'Downloaded $(EN_US_INSTALLER_BINARY_URL)/$(PKG_PATH)$(EN_US_PKG_INST_BASENAME).exe to $(ABS_DIST)/$(PKG_INST_PATH)$(PKG_INST_BASENAME).exe' endif endif generate-snippet-%: $(PYTHON) $(MOZILLA_DIR)/tools/update-packaging/generatesnippet.py \ --mar-path=$(ABS_DIST)/update \ --application-ini-file=$(STAGEDIST)/application.ini \ --locale=$* \ --product=$(MOZ_PKG_APPNAME) \ --platform=$(MOZ_PKG_PLATFORM) \ --download-base-URL=$(DOWNLOAD_BASE_URL) \ --verbose