summaryrefslogtreecommitdiff
path: root/Makefile.in
diff options
context:
space:
mode:
authorMatúš Kukan <matus.kukan@gmail.com>2012-12-23 19:27:28 +0100
committerPeter Foley <pefoley2@verizon.net>2012-12-24 22:39:59 +0000
commit0e6212c81a837180db5b8ea29d0d2a529b4b1924 (patch)
treebdaf631d65e42559f5b6b5ec644f244b6517a71b /Makefile.in
parent4a3018e4eceb981aadbadbe3eadff4c17f018357 (diff)
merge Makefile and Makefile.top again
Using MAKE_RESTARTS as indicator whether to source environment. 'make foo -o bar' should work again. Change-Id: I6086b661559b39897f1d5378919541fb786bdf0e Reviewed-on: https://gerrit.libreoffice.org/1478 Reviewed-by: Peter Foley <pefoley2@verizon.net> Tested-by: Peter Foley <pefoley2@verizon.net>
Diffstat (limited to 'Makefile.in')
-rw-r--r--Makefile.in403
1 files changed, 394 insertions, 9 deletions
diff --git a/Makefile.in b/Makefile.in
index fd66058cb8ca..f1111ce795f3 100644
--- a/Makefile.in
+++ b/Makefile.in
@@ -7,20 +7,21 @@
# file, You can obtain one at http://mozilla.org/MPL/2.0/.
#
-# must not be empty so we can have a target for it
+.PHONY : all bootstrap build check clean clean-build clean-host dev-install distclean distro-pack-install docs download fetch findunusedcode get-submodules help id install install-strip install-tb subsequentcheck tags
+
ifeq ($(MAKECMDGOALS),)
MAKECMDGOALS:=all
endif
SHELL=/usr/bin/env bash
-export SRCDIR:=@SRC_ROOT@
-export BUILDDIR:=@BUILDDIR@
+SRCDIR := @SRC_ROOT@
+BUILDDIR := @BUILDDIR@
-.PHONY : $(filter-out $(BUILDDIR)/config_host.mk,$(MAKECMDGOALS))
+ifeq (,$(MAKE_RESTARTS))
-# recursively invoke Makefile.top, which includes config_host.mk
-$(filter-out help,$(firstword $(MAKECMDGOALS))) : $(BUILDDIR)/config_host.mk
- $(MAKE) -r -f $(SRCDIR)/Makefile.top $(MAKECMDGOALS)
+.PHONY : force-restart
+Makefile: $(BUILDDIR)/config_host.mk force-restart
+ @touch $@
# run configure in an environment not polluted by config_host.mk
$(BUILDDIR)/config_host.mk : \
@@ -34,9 +35,393 @@ $(BUILDDIR)/config_host.mk : \
$(BUILDDIR)/autogen.lastrun:
@true
+else # MAKE_RESTARTS
+
+all: build
+
+ifeq ($(gb_Side),)
+gb_Side:=host
+endif
+
+include $(BUILDDIR)/config_$(gb_Side).mk
+SRCDIR:=$(SRC_ROOT)
+
+ifeq ($(GMAKE_OPTIONS),)
+ifeq ($(verbose)$(VERBOSE),)
+export GMAKE_OPTIONS:=-rs
+else
+export GMAKE_OPTIONS:=-r
+endif
+endif
+
+# This list tells which modules are gbuild ones. It does *not* tell which modules to build. That is directed
+# by the module being mentioned in postprocess/prj/build.lst, etc, recursively.
+$(WORKDIR)/modules.mk: $(wildcard */Module_*.mk) $(wildcard */prj/dmake) $(BUILDDIR)/config_host.mk
+ mkdir -p $(dir $@)
+ echo -n "gbuild_modules:= tail_build \\" > $@
+ for m in */Module_*.mk; do echo $$m | sed -e 's/\/.*$$/ \\/'; done >> $@
+ echo >> $@
+ echo -n "dmake_modules:= " >> $@
+ for m in */prj/dmake; do echo $$m | sed -e 's/\/.*$$/ \\/'; done >> $@
+ echo >> $@
+
+-include $(WORKDIR)/modules.mk
+include $(SRCDIR)/solenv/gbuild/Output.mk
+$(if $(filter $(gbuild_modules),$(dmake_modules)),$(eval $(call gb_Output_warn,The following modules claim to be both dmake and gbuild: $(filter $(gbuild_modules),$(dmake_modules)))))
+
+export gb_TAILBUILDTARGET=all slowcheck
+
+define gbuild_module_rules
+.PHONY: $(1) $(1).all $(1).build $(1).check $(1).clean $(1).subsequentcheck $(1).deliver
+
+$(1): bootstrap fetch
+ cd $(1) && $(GNUMAKE) -j $(PARALLELISM) $(GMAKE_OPTIONS) gb_PARTIALBUILD=T
+
+$(1).all: bootstrap fetch
+ $$(if $$(filter $(1),$$(shell $(GNUMAKE) -r -f $(SRCDIR)/tail_build/Makefile showmodules)), \
+ cd $(SRC_ROOT)/tail_build && unset MAKEFLAGS && \
+ export gb_TAILBUILDTARGET="$(WORKDIR)/Module/$(1) $(WORKDIR)/Module/check/$(1) $(WORKDIR)/Module/slowcheck/$(1)" && \
+ , \
+ cd $(SRC_ROOT)/$(1) && unset MAKEFLAGS && \
+ ) \
+ $(SOLARENV)/bin/build.pl -P$(PARALLELISM) --all -- -P$(PARALLELISM)
+
+$(1).build $(1).check $(1).clean:
+ cd $(1) && $(GNUMAKE) -j $(PARALLELISM) $(GMAKE_OPTIONS) $$(patsubst $(1).%,%,$$@) gb_PARTIALBUILD=T
+
+$(1).subsequentcheck:
+ cd $(1) && $(GNUMAKE) -j $(CHECK_PARALLELISM) $(GMAKE_OPTIONS) subsequentcheck gb_PARTIALBUILD=T
+
+$(1).deliver:
+ @true
+
+endef
+
+define gbuild_modules_rules
+$(foreach m,$(1),$(call gbuild_module_rules,$(m)))
+endef
+
+define dmake_module_rules
+.PHONY: $(1) $(1).all $(1).deliver $(1).clean
+
+$(1): bootstrap fetch
+ cd $(SRC_ROOT)/$(1) && unset MAKEFLAGS && \
+ $(SOLARENV)/bin/build.pl -P$(PARALLELISM) -- -P$(PARALLELISM)
+
+$(1).all: bootstrap fetch
+ cd $(SRC_ROOT)/$(1) && unset MAKEFLAGS && \
+ $(SOLARENV)/bin/build.pl -P$(PARALLELISM) --all -- -P$(PARALLELISM)
+
+$(1).deliver: $(1)
+ cd $(SRC_ROOT)/$(1) && $(SOLARENV)/bin/deliver.pl
+
+$(1).clean:
+ cd $(SRC_ROOT)/$(1) && $(SOLARENV)/bin/deliver.pl -delete
+ rm -fr $(1)/$(INPATH)
+
+endef
+
+define dmake_modules_rules
+$(foreach m,$(1),$(call dmake_module_rules,$(m)))
+endef
+
+#
+# Partial Build
+#
+$(eval $(call gbuild_modules_rules,$(gbuild_modules)))
+
+$(eval $(call dmake_modules_rules,$(dmake_modules)))
+
+# run a JunitTest - relies on naming convention (module prefix)
+$(WORKDIR)/JunitTest/%/done :
+ cd $(firstword $(subst _, ,$*)) && $(GNUMAKE) $(GMAKE_OPTIONS) $@ gb_PARTIALBUILD=T
+
+# run a CppunitTest - relies on naming convention (module prefix)
+$(WORKDIR)/CppunitTest/%.test :
+ cd $(firstword $(subst _, ,$*)) && $(GNUMAKE) $(GMAKE_OPTIONS) $@ gb_PARTIALBUILD=T
+
+#
+# Help
+#
help:
@cat $(SRCDIR)/solenv/gbuild/gbuild.help.txt
- @true
-# vim: set noet sw=4 ts=4:
+#
+# Clean
+#
+clean: clean-host clean-build
+
+clean-host:
+ifeq ($(BUILD_DMAKE),YES)
+ if [ -f dmake/Makefile ] ; then $(GNUMAKE) -j $(PARALLELISM) -C dmake clean; fi
+endif
+ rm -fr $(DEVINSTALLDIR)
+ rm -fr $(OUTDIR)
+ rm -fr $(WORKDIR)
+ rm -fr $(SRCDIR)/*/$(INPATH)
+ rm -fr $(SRCDIR)/solenv/$(OUTPATH)
+ rm -fr install
+
+clean-build:
+ifeq ($(CROSS_COMPILING),YES)
+ rm -rf $(SOLARVER)/$(INPATH_FOR_BUILD) # not necessarily below SRCDIR
+ rm -rf $(SRCDIR)/*/$(INPATH_FOR_BUILD)
+endif
+
+include $(SRCDIR)/compilerplugins/Makefile.mk
+
+#
+# Distclean
+#
+distclean : clean compilerplugins-clean
+ifeq ($(BUILD_DMAKE),YES)
+ (if [ -f dmake/Makefile ] ; then $(GNUMAKE) -j $(PARALLELISM) -C dmake distclean; fi) && \
+ rm -f solenv/*/bin/dmake*
+endif
+ rm -fr \
+ $(BUILDDIR)/Makefile \
+ $(BUILDDIR)/aclocal.m4 \
+ $(BUILDDIR)/autom4te.cache \
+ $(BUILDDIR)/config.log \
+ $(BUILDDIR)/config.status \
+ $(BUILDDIR)/config/*.h \
+ $(BUILDDIR)/config_build.mk \
+ $(BUILDDIR)/config_host.mk \
+ $(BUILDDIR)/config_host.mk.last \
+ $(BUILDDIR)/config_host.mk.stamp \
+ $(BUILDDIR)/configure \
+ $(BUILDDIR)/warn
+ find $(SOLARENV)/gdb -name "*.pyc" -exec rm {} \;
+
+#
+# custom command
+#
+ifneq ( $(MAKECMDGOALS),cmd)
+cmd:
+ echo "custom cmd" && ( $(cmd) )
+
+endif
+ifneq ($(filter-out clean distclean,$(MAKECMDGOALS)),)
+#
+# Fetch
+#
+ifneq ($(DO_FETCH_TARBALLS),NO)
+include $(SRCDIR)/Makefile.fetch
+fetch: download
+fetch: get-submodules
+
+ifneq (,$(wildcard $(SRCDIR)/.git))
+get-submodules:
+ifneq ($(foreach i,$(GIT_NEEDED_SUBMODULES),$(i)/.git),$(wildcard $(foreach i,$(GIT_NEEDED_SUBMODULES),$(i)/.git)))
+ifeq (,$(GIT_LINK_SRC))
+ cd $(SRCDIR) && ./g -f clone
+else # space-saving clone from another local workdir
+ @echo "FIXME: GIT_LINK_SRC method is not yet implemented with submodules" 1>&2
+ true $(foreach i,$(GIT_NEEDED_SUBMODULES),\
+ && rm -r $(i) && cp -R $(GIT_LINK_SRC)/$(i) $(i))
+# bin/git-new-workdir $GIT_LINK_SRC/$i $i
+ git submodule update $(GIT_NEEDED_SUBMODULES)
+endif
+endif
+
+else # these sources are from a tarball, so get the other source tarballs
+gb_LO_VER := $(shell . $(SRCDIR)/sources.ver && echo $$lo_sources_ver)
+$(if $(gb_LO_VER),,$(error Error while retrieving $$lo_sources_ver from $(SRCDIR)/sources.ver))
+
+get-submodules: | download
+ifneq ($(foreach i,$(subst helpcontent2,help,$(GIT_NEEDED_SUBMODULES)),$(SRCDIR)/src/libreoffice-$(i)-$(gb_LO_VER)),$(wildcard $(foreach i,$(subst helpcontent2,help,$(GIT_NEEDED_SUBMODULES)),$(SRCDIR)/src/libreoffice-$(i)-$(gb_LO_VER))))
+ $(foreach i,$(subst helpcontent2,help,$(GIT_NEEDED_SUBMODULES)),\
+ $(call fetch_Download_item,http://download.documentfoundation.org/libreoffice/src/$(shell echo $(gb_LO_VER) | sed -e "s/\([0-9]*\.[0-9]*\.[0-9]*\).*/\1/"),libreoffice-$(i)-$(gb_LO_VER).tar.xz,no-check))
+ $(SRCDIR)/bin/unpack-sources $(SRCDIR) $(foreach i,$(subst helpcontent2,help,$(GIT_NEEDED_SUBMODULES)),\
+ $(TARFILE_LOCATION)/libreoffice-$(i)-$(gb_LO_VER).tar.xz)
+endif
+
+endif
+
+else
+fetch:
+ @echo "Automatic fetching of external tarballs is disabled."
+
+endif
+
+#
+# Bootstap
+#
+bootstrap: $(WORKDIR)/bootstrap compilerplugins
+
+$(WORKDIR)/bootstrap:
+ @cd $(SRCDIR) && ./bootstrap
+ @mkdir -p $(dir $@) && touch $@
+
+#
+# Build
+#
+build-postprocess: bootstrap fetch $(if $(filter $(INPATH),$(INPATH_FOR_BUILD)),,cross-toolset)
+ifeq ($(DISABLE_SCRIPTING),TRUE)
+# We must get the headers from vbahelper "delivered" because
+# as we don't link to any libs from there they won't otherwise be, or
+# something. And we still do include those headers always even if the
+# libs aren't built in the --disable-scripting case. (Ifdefs for
+# DISABLE_SCRIPTING will be added to the code later as necessary.)
+ $(GNUMAKE) vbahelper
+endif
+ifeq ($(DISABLE_DBCONNECTIVITY),TRUE)
+# Ditto for dbconnectivity in the --disable-database-connectivity case
+ cd connectivity && sed -e 's/^\(export [A-Z0-9_]*=\)\(.*\)$$/\1"\2"/' <../config_host.mk >conftmp.sh && . conftmp.sh && rm conftmp.sh && $(SOLARENV)/bin/deliver.pl
+endif
+ cd $(SRC_ROOT)/postprocess && unset MAKEFLAGS && \
+ $(SOLARENV)/bin/build.pl -P$(PARALLELISM) --all -- -P$(PARALLELISM) && \
+ $(GNUMAKE) -j $(PARALLELISM) $(GMAKE_OPTIONS)
+
+build: build-postprocess
+ifeq ($(OS_FOR_BUILD),WNT)
+ cd $(SRC_ROOT)/instsetoo_native && unset MAKEFLAGS && $(SOLARENV)/bin/build.pl
+else
+ cd $(SRC_ROOT)/instsetoo_native && unset MAKEFLAGS && \
+ $(SOLARENV)/bin/build.pl -P$(PARALLELISM) -- -P$(PARALLELISM)
+endif
+ifeq ($(OS),ANDROID)
+ cd android && $(GNUMAKE) -j $(PARALLELISM) $(GMAKE_OPTIONS)
+endif
+
+build-nocheck : export SKIP_TESTS := YES
+build-nocheck : build
+
+cross-toolset: bootstrap fetch
+ cd cross_toolset && $(GNUMAKE) -j $(PARALLELISM) $(GMAKE_OPTIONS)
+ifneq (,$(filter DESKTOP,$(BUILD_TYPE)))
+ifneq (WNT,$(OS))
+# We need to build nss for nsinstall... See NSINSTALL=... in nss/makefile.mk
+ $(GNUMAKE) gb_Side=build nss
+endif
+endif
+
+#
+# Install
+#
+
+install:
+ echo "Installing in $(INSTALLDIR)..." && \
+ ooinstall "$(INSTALLDIR)" && \
+ echo "" && \
+ echo "Installation finished, you can now execute:" && \
+ echo "$(INSTALLDIR)/program/soffice"
+
+install-strip:
+ echo "Installing and stripping binaries in $(INSTALLDIR)..." && \
+ ooinstall --strip "$(INSTALLDIR)" && \
+ echo "" && \
+ echo "Installation finished, you can now execute:" && \
+ echo "$(INSTALLDIR)/program/soffice"
+
+dev-install: build
+ @rm -rf $(DEVINSTALLDIR)
+ @mkdir $(DEVINSTALLDIR)
+ifeq ($(OS_FOR_BUILD),WNT)
+ cd $(SRC_ROOT)/instsetoo_native && unset MAKEFLAGS && $(SOLARENV)/bin/build.pl LIBO_DEV_INSTALL=TRUE
+ unzip -q -d "$(DEVINSTALLDIR)" "$(SRCDIR)/instsetoo_native/$(INPATH)/LibreOffice/archive/install/en-US/LibO*_install-arc_en-US.zip"
+ mv "$(DEVINSTALLDIR)"/LibO*_install-arc_en-US/* "$(DEVINSTALLDIR)"/opt
+else
+ifeq ($(DISABLE_LINKOO),TRUE)
+ @ooinstall $(DEVINSTALLDIR)/opt
+ @install-gdb-printers -L
+else
+ @ooinstall -l $(DEVINSTALLDIR)/opt
+endif
+endif
+ @rm -f $(SRCDIR)/install && ln -s $(DEVINSTALLDIR)/opt/ $(SRCDIR)/install
+
+dev-install-nocheck : export SKIP_TESTS := YES
+dev-install-nocheck : dev-install
+
+dev-update:
+ifeq ($(DISABLE_LINKOO),TRUE)
+ @linkoo --copy $(DEVINSTALLDIR)/opt $(SRCDIR)
+else
+ @linkoo $(DEVINSTALLDIR)/opt $(SRCDIR)
+endif
+
+install-tb:
+ @rm -rf $(DEVINSTALLDIR)
+ @mkdir $(DEVINSTALLDIR)
+ifeq ($(OS_FOR_BUILD),WNT)
+ cd $(SRC_ROOT)/instsetoo_native && unset MAKEFLAGS && $(SOLARENV)/bin/build.pl LIBO_DEV_INSTALL=TRUE
+ unzip -q -d "$(DEVINSTALLDIR)" "$(SRCDIR)/instsetoo_native/$(INPATH)/LibreOffice/archive/install/en-US/LibO*_install-arc_en-US.zip"
+ mv "$(DEVINSTALLDIR)"/LibO*_install-arc_en-US/* "$(DEVINSTALLDIR)"/opt
+else
+ @ooinstall $(DEVINSTALLDIR)/opt
+ @install-gdb-printers
+endif
+ @rm -f $(SRCDIR)/install && ln -s $(DEVINSTALLDIR)/opt/ $(SRCDIR)/install
+
+distro-pack-install: install
+ $(SRCDIR)/bin/distro-install-clean-up
+ $(SRCDIR)/bin/distro-install-desktop-integration
+ $(SRCDIR)/bin/distro-install-sdk
+ $(SRCDIR)/bin/distro-install-file-lists
+
+id:
+ @create-ids
+
+tags:
+ @create-tags
+
+docs:
+ @mkdocs.sh $(SRCDIR)/docs $(SOLARENV)/inc/doxygen.cfg
+
+findunusedcode:
+ @which callcatcher > /dev/null 2>&1 || \
+ (echo "callcatcher not installed" && false)
+ @sed -e s,$$INPATH,callcatcher,g config_host.mk | sed -e s,"export OOO_JUNIT_JAR=.*","export OOO_JUNIT_JAR=",g > $(SRCDIR)/config_host_callcatcher.mk
+ @echo unexport ARCH_FLAGS >> $(SRCDIR)/config_host_callcatcher.mk
+ @echo unexport CFLAGS >> $(SRCDIR)/config_host_callcatcher.mk
+ @echo unexport CXXFLAGS >> $(SRCDIR)/config_host_callcatcher.mk
+ @mkdir -p $(SRCDIR)/solenv/callcatcher/bin && \
+ ln -sf $(SRCDIR)/solenv/$(INPATH)/bin/dmake \
+ $(SRCDIR)/solenv/callcatcher/bin/dmake
+ @$(GNUMAKE) -f $(SOLARENV)/bin/callcatcher.Makefile findunusedcode
+ @grep ::.*\( unusedcode.all \
+ | grep -v ^Atom \
+ | grep -v ^atom:: \
+ | grep -v ^boost:: \
+ | grep -v ^CIcc \
+ | grep -v ^CLuceneError:: \
+ | grep -v ^cppu:: \
+ | grep -v ^Dde \
+ | grep -v ^graphite2:: \
+ | grep -v ^jvmaccess:: \
+ | grep -v ^libcdr:: \
+ | grep -v ^libcmis:: \
+ | grep -v ^libmspub:: \
+ | grep -v ^libvisio:: \
+ | grep -v ^libwpg:: \
+ | grep -v ^libwps_tools_win:: \
+ | grep -v ^lucene:: \
+ | grep -v ^Matrix3d:: \
+ | grep -v ^RelatedMultipart:: \
+ | grep -v ^salhelper:: \
+ | grep -v ^VSDInternalStream:: \
+ | grep -v ^WP1 \
+ | grep -v ^WP3 \
+ | grep -v ^WP42 \
+ | grep -v ^WP6 \
+ | grep -v ^WPG \
+ | grep -v ^WPS \
+ | grep -v WPX \
+ | grep -v ^WSObject \
+ > unusedcode.easy
+
+check: dev-install subsequentcheck
+
+subsequentcheck :| $(if $(filter-out subsequentcheck,$(MAKECMDGOALS)),dev-install)
+ $(GNUMAKE) -j $(CHECK_PARALLELISM) $(GMAKE_OPTIONS) -f $(SRC_ROOT)/Makefile.post $@
+
+unitcheck slowcheck debugrun:
+ $(GNUMAKE) -j $(PARALLELISM) $(GMAKE_OPTIONS) -f $(SRC_ROOT)/Makefile.post $@
+
+endif # not clean or distclean
+
+endif # MAKE_RESTARTS
+
+# vim: set noet sw=4 ts=4: