[Libreoffice-commits] .: Makefile.in Makefile.top

Libreoffice Gerrit user logerrit at kemper.freedesktop.org
Mon Dec 24 14:40:19 PST 2012


 Makefile.in  |  403 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++--
 Makefile.top |  390 ---------------------------------------------------------
 2 files changed, 394 insertions(+), 399 deletions(-)

New commits:
commit 0e6212c81a837180db5b8ea29d0d2a529b4b1924
Author: Matúš Kukan <matus.kukan at gmail.com>
Date:   Sun Dec 23 19:27:28 2012 +0100

    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 at verizon.net>
    Tested-by: Peter Foley <pefoley2 at verizon.net>

diff --git a/Makefile.in b/Makefile.in
index fd66058..f1111ce 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:
diff --git a/Makefile.top b/Makefile.top
deleted file mode 100644
index ed0dda2..0000000
--- a/Makefile.top
+++ /dev/null
@@ -1,390 +0,0 @@
-# -*- Mode: makefile-gmake; tab-width: 4; indent-tabs-mode: t -*-
-
-.PHONY : all bootstrap build check clean clean-build clean-host dev-install distclean distro-pack-install docs download fetch findunusedcode get-submodules id install install-strip install-tb subsequentcheck tags
-
-ifeq ($(MAKECMDGOALS),)
-MAKECMDGOALS:=all
-endif
-
-all: build
-
-SHELL=/usr/bin/env bash
-
-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
-
-#
-# 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
-
-# vim: set noet sw=4 ts=4:


More information about the Libreoffice-commits mailing list