[Libreoffice-commits] .: 2 commits - solenv/gbuild

Norbert Thiebaud nthiebaud at kemper.freedesktop.org
Fri Sep 30 11:45:04 PDT 2011


 solenv/gbuild/CustomTarget.mk    |    2 
 solenv/gbuild/ExternalLib.mk     |  104 +++++++++++++++++++++++++++++++++++++++
 solenv/gbuild/LinkTarget.mk      |    9 +++
 solenv/gbuild/TargetLocations.mk |    4 +
 solenv/gbuild/gbuild.mk          |    1 
 5 files changed, 119 insertions(+), 1 deletion(-)

New commits:
commit 8a2776971de1e460bc38d11223d530eed7878296
Author: Norbert Thiebaud <nthiebaud at gmail.com>
Date:   Sat Sep 17 13:46:08 2011 -0500

    preliminary work on a ExternalLib extension support for gbuild

diff --git a/solenv/gbuild/ExternalLib.mk b/solenv/gbuild/ExternalLib.mk
new file mode 100644
index 0000000..cee876f
--- /dev/null
+++ b/solenv/gbuild/ExternalLib.mk
@@ -0,0 +1,104 @@
+# -*- Mode: makefile-gmake; tab-width: 4; indent-tabs-mode: t -*-
+# -*- Mode: makefile-gmake; tab-width: 4; indent-tabs-mode: t -*-
+#
+# Version: MPL 1.1 / GPLv3+ / LGPLv3+
+#
+# The contents of this file are subject to the Mozilla Public License Version
+# 1.1 (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+# http://www.mozilla.org/MPL/
+#
+# Software distributed under the License is distributed on an "AS IS" basis,
+# WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
+# for the specific language governing rights and limitations under the
+# License.
+#
+# Major Contributor(s):
+# Copyright (C) 2011 Norbert Thiebaud <nthiebaud at gmail.com>
+#
+# All Rights Reserved.
+#
+# For minor contributions see the git repository.
+#
+# Alternatively, the contents of this file may be used under the terms of
+# either the GNU General Public License Version 3 or later (the "GPLv3+"), or
+# the GNU Lesser General Public License Version 3 or later (the "LGPLv3+"),
+# in which case the provisions of the GPLv3+ or the LGPLv3+ are applicable
+# instead of those above.
+
+gb_ExternalLib_REPOSITORYNAMES := $(gb_Helper_REPOSITORYNAMES)
+
+gb_ExternalLib_get_src_package = $(TARFILE_LOCATION)/$(1)
+
+define gb_ExternalLib_ExternalLib
+$(call gb_ExternalLib_get_target,$(1)): T_PATCHES:=
+$(call gb_ExternalLib_get_target,$(1)): T_POST_PATCHES:=
+$(call gb_ExternalLib_get_target,$(1)): T_CONF_ARGS:=
+$(call gb_ExternalLib_get_target,$(1)): T_BUILD_MODE:=$(2)
+$$(eval $$(call gb_Module_register_target,$(call gb_ExternalLib_get_target,$(1)),$(call gb_ExternalLib_get_clean_target,$(1))))
+
+ifeq ($(strip $(2)),autotools)
+$(call gb_ExternalLib_get_target,$(1)) :
+	$$(call gb_Output_announce,$*,$(true),MAK,3)
+	$$(call gb_ExternalLib__command_autotools,$(1));
+	touch $(call gb_ExternalLib_get_target,$(1));
+
+.PHONY: $(call gb_ExternalLib_get_clean_target,$(1))
+$(call gb_ExternalLib_get_clean_target,$(1)) :
+	$$(call gb_Output_announce,$(1),$(false),MAK,3)
+	$$(call gb_Helper_abbreviate_dirs,\
+	    if test -f $$(call gb_ExternalLib_get_builddir,$(1))/Makefile ; then cd $$(call gb_ExternalLib_get_builddir,$(1)) && make uninstall ; fi ; \
+	    rm -f $$(call gb_ExternalLib_get_target,$(1)) \
+		rm -rf $(call gb_ExternalLib_get_workdir,$(1)))
+
+else
+	$$(call gb_Output_error,$(2) is not a supported ExternalLib mode)
+endif
+
+endef
+
+define gb_ExternalLib_set_src_package
+$(call gb_ExternalLib_get_target,$(1)): $(call gb_ExternalLib_get_src_package,$(2))
+endef
+
+define gb_ExternalLib_add_patch
+$(call gb_ExternalLib_get_target,$(1)): T_PATCHES+=$(2)
+
+endef
+
+define gb_ExternalLib_add_patches
+$(foreach patch,$(2),$(call gb_ExternalLib_add_patch,$(1),$(patch)))
+endef
+
+define gb_ExternalLib_add_post_patch
+$(call gb_ExternalLib_get_target,$(1)): T_POST_PATCHES+=$(2)
+
+endef
+
+define gb_ExternalLib_add_post_patches
+$(foreach patch,$(2),$(call gb_ExternalLib_add_patch,$(1),$(patch)))
+endef
+
+define gb_ExternalLib_add_conf_arg
+$(call gb_ExternalLib_get_target,$(1)): T_CONF_ARGS+=$(2)
+endef
+
+define gb_ExternalLib_add_cxxflags
+$(call gb_ExternalLib_get_target,$(1)) : T_CXXFLAGS += $(2)
+endef
+
+define gb_ExternalLib_add_cflags
+$(call gb_ExternalLib_get_target,$(1)) : T_CFLAGS += $(2)
+endef
+
+
+define gb_ExternalLib__command_autotools
+	rm -fr $(call gb_ExternalLib_get_workdir,$(1)) && \
+	mkdir -p $(call gb_ExternalLib_get_builddir,$(1)) && \
+	tar -x -C $(call gb_ExternalLib_get_builddir,$(1)) --strip-component=1 -f $< && \
+	pushd $(call gb_ExternalLib_get_builddir,$(1)) && for p in $(T_PATCHES) ; do patch -p 1 < $(gb_REPOS)/$$p || exit 1; done && \
+	CC="$(gb_CC)" CXX="$(gb_CXX)" CFLAGS="$(T_CFLAGS)" CXXFLAGS="$(T_CXXFLAGS)" ./configure --prefix=$(OUTDIR) $(T_CONF_ARGS) && \
+	for p in $(T_POST_PATCHES) ; do patch -p 1 < $(gb_REPOS)/$p || exit 1; done
+	+MAKEFLAGS=$(filterout r,$(MAKEFLAGS)) $(MAKE) -C $(call gb_ExternalLib_get_builddir,$(1))
+	+$(MAKE) -C $(call gb_ExternalLib_get_builddir,$(1)) install
+endef
diff --git a/solenv/gbuild/LinkTarget.mk b/solenv/gbuild/LinkTarget.mk
index c74bed8..3b5356c 100644
--- a/solenv/gbuild/LinkTarget.mk
+++ b/solenv/gbuild/LinkTarget.mk
@@ -763,6 +763,15 @@ $$(foreach lib,$(2),$$(call gb_StaticLibrary_get_headers_target,$$(lib)))
 
 endef
 
+define gb_LinkTarget_add_linked_static_external_libs
+
+$(call gb_LinkTarget_get_target,$(1)) : LINKED_STATIC_LIBS += $(2)
+
+$(call gb_LinkTarget_get_target,$(1)) : $$(foreach lib,$(2),$$(call gb_ExternalLibs_get_target,$$(lib)))
+$(call gb_LinkTarget_get_external_headers_target,$(1)) : $$(foreach lib,$(2),$$(call gb_ExternalLibs_get_target,$$(lib)))
+
+endef
+
 define gb_LinkTarget_add_cobject
 $(call gb_LinkTarget_get_target,$(1)) : COBJECTS += $(2)
 $(call gb_LinkTarget_get_clean_target,$(1)) : COBJECTS += $(2)
diff --git a/solenv/gbuild/TargetLocations.mk b/solenv/gbuild/TargetLocations.mk
index 2949a3a..7f067d2 100644
--- a/solenv/gbuild/TargetLocations.mk
+++ b/solenv/gbuild/TargetLocations.mk
@@ -79,6 +79,9 @@ gb_CxxObject_get_target = $(WORKDIR)/CxxObject/$(1).o
 gb_GenCxxObject_get_target = $(WORKDIR)/GenCxxObject/$(1).o
 gb_Executable_get_external_headers_target = $(WORKDIR)/ExternalHeaders/Executable/$(1)
 gb_Executable_get_headers_target = $(WORKDIR)/Headers/Executable/$(1)
+gb_ExternalLib_get_workdir = $(WORKDIR)/ExternalLib/$(1)
+gb_ExternalLib_get_builddir = $(WORKDIR)/ExternalLib/$(1)/build
+gb_ExternalLib_get_target = $(WORKDIR)/ExternalLib/$(1).done
 gb_Jar_get_target = $(WORKDIR)/Jar/$(1).jar
 gb_Jar_get_classsetname = Jar/$(1)
 gb_JavaClassSet_get_classdir = $(WORKDIR)/JavaClassSet/$(1)
@@ -167,6 +170,7 @@ $(eval $(call gb_Helper_make_clean_targets,\
 	SrsTemplateTarget \
 	CppunitTest \
 	CustomTarget \
+	ExternalLib \
 	UnoApiTarget \
 	WinResTarget \
 	YaccObject \
diff --git a/solenv/gbuild/gbuild.mk b/solenv/gbuild/gbuild.mk
index 393a257..6c387c2 100644
--- a/solenv/gbuild/gbuild.mk
+++ b/solenv/gbuild/gbuild.mk
@@ -299,6 +299,7 @@ include $(foreach class, \
 	SdiTarget \
 	Package \
 	CustomTarget \
+	ExternalLib \
 	PrecompiledHeaders \
 	Pyuno \
 	RdbTarget \
commit bba594a82088ce9631bbee1fd0fed2aedf3c2fa2
Author: Norbert Thiebaud <nthiebaud at gmail.com>
Date:   Sat Sep 17 13:44:29 2011 -0500

    fix an apparent cut-and-paste typo in CustomeTarget

diff --git a/solenv/gbuild/CustomTarget.mk b/solenv/gbuild/CustomTarget.mk
index a79ed8d..19279a4 100644
--- a/solenv/gbuild/CustomTarget.mk
+++ b/solenv/gbuild/CustomTarget.mk
@@ -55,7 +55,7 @@ endef
 define gb_CustomTarget_CustomTarget
 $(if $(filter $(2),$(gb_CustomTarget_REPOSITORYNAMES)),,\
  $(error CustomTarget: no or invalid repository given; known repositories: \
-  $(gb_JavaClassSet_REPOSITORYNAMES)))
+  $(gb_CustomTarget_REPOSITORYNAMES)))
 gb_CustomTarget_REPO_$(1) := $(2)
 $(call gb_CustomTarget_get_target,$(1)) : \
   $(call gb_CustomTarget__get_makefile,$($(2)),$(1))


More information about the Libreoffice-commits mailing list