# # Front-end based on GNU make, intended for a more friendly # integration of the build system with Linux/UNIX distributions, # as well as for those who still allergy using mach command. # # Place it as `mozilla/GNUmakefile' (instead of the existing stub), # and work under `mozilla/' dir. # # # For build, just use # # make # # (If you want to separate config stage, use "make configure" and then "make", # but normally it is done automatically). # # For install, use # # make install DESTDIR=where_you_want_to_install # # # Additionally, before install you can use: # # make locales # # to provide all the shipped locales (will appear in a form of langpack extensions). # If irc and/or calendar are built, their data will be included too. # (See below for more details about locales target). # # # For clarity, some comparison with the other build methods # (assume `-jN' is the option for parallel builds, ie. `-j4' for 4-cpu system): # # Build stage: # # client.mk: make -f client.mk build MOZ_MAKE_FLAGS=-jN # mach: ./mach build -jN # THIS: make -jN # # Install stage: # # client.mk: DESTDIR=where... make -f client.mk install # mach: DESTDIR=where... make -C $OBJDIR... install # THIS: make install DESTDIR=where... # ifeq (,$(wildcard .mozconfig)) $(error Cannot find .mozconfig file in the current directory) endif export MACH_USE_SYSTEM_PYTHON = 1 export MOZBUILD_STATE_PATH=$(CURDIR)/.mozbuild MACH_CMD = env MACH_USE_SYSTEM_PYTHON=1 MOZBUILD_STATE_PATH=$(CURDIR)/.mozbuild ./mach --log-no-times OBJDIR := $(shell $(MACH_CMD) environment --format=json | sed -n -e 's/.*"topobjdir": "//' -e 's/".*//p') OBJDIR_TARGETS = install distribution source-package package clobber .PHONY: all configure build clean distclean $(OBJDIR_TARGETS) all: build configure: $(OBJDIR)/Makefile $(OBJDIR)/Makefile: .mozconfig $(MACH_CMD) configure # Since the bug #1671424, a separate "mach configure" no longer creates $(OBJDIR)/CLOBBER stamp file # (as full "mach build" does), so do it manually as before. [ -f $(OBJDIR)/CLOBBER ] || touch -r $(OBJDIR)/.mozconfig.json $(OBJDIR)/CLOBBER build: $(OBJDIR)/Makefile $(MAKE) -C $(OBJDIR) $(OBJDIR_TARGETS): $(MAKE) -C $(OBJDIR) $@ clean: $(MACH_CMD) clobber distclean: clean rm -f configure js/src/configure rm -rf $(OBJDIR) # # LOCALES # # # The target `locales' creates all the needed langpacks. # # By default, all available locales will be used. You can change it # by overriding SHIPPED_LOCALES variable on the command line. # # Additionally, you can use `make locale-LANG' to create one (or several) # langpack separately. # # For example, to build `fr' and 'it' only, use: # # make locales SHIPPED_LOCALES="fr it" # # to create just `ru' langpack: # # make locale-ru # # Use `clear-locales' for clearing. # # # NOTE! NOTE! NOTE! # # Do NOT use parallel builds (-jN) for locale targets! # # It is better to use `-j1' explicitly (`make -j1 locales') to avoid issues. # .PHONY: locales clear-locales dictionaries clear-dictionaries drop_extra := $(if $(or $(filter Windows_NT,$(OS)),$(filter-out Darwin,$(shell uname))),ja-JP-mac,ja) SHIPPED_LOCALES := $(shell while read loc rest; do echo $$loc; done >$(PACKAGE_MANIFEST) clear-locales: sed -i '/langpack-.*@seamonkey.mozilla.org.xpi/ d' $(PACKAGE_MANIFEST) rm -f $(OBJDIR)/dist/bin/extensions/langpack-*@seamonkey.mozilla.org.xpi # # Dictionaries # # It is better to use system dictionaries, specifying directory path for them # by "spellchecker.dictionary_path" preference (or even use symlink when possible). # DICT_DEST := $(OBJDIR)/dist/bin/dictionaries dictionaries: $(SHIPPED_LOCALES:%=$(stage)-%) cp -f -d $(wildcard $(foreach loc,$(SHIPPED_LOCALES),$(stage)-$(loc)/dictionaries/$(loc).aff $(stage)-$(loc)/dictionaries/$(loc).dic)) $(DICT_DEST) clear-dictionaries: rm -f $(filter-out $(DICT_DEST)/en-US.%,$(wildcard $(DICT_DEST)/*.aff $(DICT_DEST)/*.dic))