summaryrefslogtreecommitdiff
path: root/solenv
diff options
context:
space:
mode:
authorMichael Stahl <mstahl@redhat.com>2013-10-31 00:58:46 +0100
committerMichael Stahl <mstahl@redhat.com>2013-10-31 10:42:25 +0100
commit60211134bc6aadd2c8bbcaf6fcda80971cb5fdd1 (patch)
treef8118a65be26ce50f9ea0ed6941b3df4cf3f3379 /solenv
parente0b50db09acef404f8dc0be74463bcaa1d488034 (diff)
gbuild: add ExtensionPackageSet class
Change-Id: I947207c78e28b416aebe2e33172043fd8cfa4f17
Diffstat (limited to 'solenv')
-rw-r--r--solenv/gbuild/ExtensionPackage.mk44
-rw-r--r--solenv/gbuild/TargetLocations.mk2
2 files changed, 43 insertions, 3 deletions
diff --git a/solenv/gbuild/ExtensionPackage.mk b/solenv/gbuild/ExtensionPackage.mk
index 34a9bd418fb3..73e1aa984c79 100644
--- a/solenv/gbuild/ExtensionPackage.mk
+++ b/solenv/gbuild/ExtensionPackage.mk
@@ -30,14 +30,21 @@ $(call gb_ExtensionPackage_get_target,%) :
&& zipinfo -1 $(ZIPFILE) | grep -v '/$$' \
| sed s+^+$(INSTROOT)/$(LIBO_SHARE_FOLDER)/extensions/$*/+ > $@)
-# call gb_ExtensionPackage_ExtensionPackage,package,oxt
-define gb_ExtensionPackage_ExtensionPackage
+# call gb_ExtensionPackage_ExtensionPackage_internal,package,oxt
+define gb_ExtensionPackage_ExtensionPackage_internal
+$(if $(2),,$(call gb_Output_error,need 2 parameters))
$(call gb_ExtensionPackage_get_target,$(1)) : ZIPFILE := $(2)
$(call gb_ExtensionPackage_get_target,$(1)) : $(2)
-$(2) :| $(call gb_ExtensionPackage_get_preparation_target,$(1))
$(call gb_ExtensionPackage_get_target,$(1)) :| \
$(INSTROOT)/$(LIBO_SHARE_FOLDER)/extensions/.dir
+endef
+
+# call gb_ExtensionPackage_ExtensionPackage,package,oxt
+define gb_ExtensionPackage_ExtensionPackage
+$(call gb_ExtensionPackage_ExtensionPackage_internal,$(1),$(2))
+$(2) :| $(call gb_ExtensionPackage_get_preparation_target,$(1))
+
$$(eval $$(call gb_Module_register_target,$(call gb_ExtensionPackage_get_target,$(1)),$(call gb_ExtensionPackage_get_clean_target,$(1))))
$(call gb_Helper_make_userfriendly_targets,$(1),ExtensionPackage)
@@ -50,4 +57,35 @@ $(call gb_ExtensionPackage_get_preparation_target,$(1)) : \
endef
+# ExtensionPackage class
+#
+# This is less boring than writing a dozen 1-line ExtensionPackage files.
+
+$(call gb_ExtensionPackageSet_get_clean_target,%) :
+ $(call gb_Output_announce,$*,$(false),OXS,3)
+ $(call gb_Helper_abbreviate_dirs,\
+ rm -rf $(call gb_ExtensionPackageSet_get_target,$*))
+
+$(call gb_ExtensionPackageSet_get_target,%) :
+ $(call gb_Output_announce,$*,$(true),OXS,3)
+ mkdir -p $(dir $@) && touch $@
+
+# call gb_ExtensionPackageSet_ExtensionPackageSet,set
+define gb_ExtensionPackageSet_ExtensionPackageSet
+$$(eval $$(call gb_Module_register_target,$(call gb_ExtensionPackageSet_get_target,$(1)),$(call gb_ExtensionPackageSet_get_clean_target,$(1))))
+$(call gb_Helper_make_userfriendly_targets,$(1),ExtensionPackageSet)
+
+endef
+
+# call gb_ExtensionPackageSet_add_extension,set,package,oxt-filename
+define gb_ExtensionPackageSet_add_extension
+$(call gb_ExtensionPackage_ExtensionPackage_internal,$(2),$(TARFILE_LOCATION)/$(3))
+
+$(call gb_ExtensionPackageSet_get_target,$(1)) : \
+ $(call gb_ExtensionPackage_get_target,$(2))
+$(call gb_ExtensionPackageSet_get_clean_target,$(1)) : \
+ $(call gb_ExtensionPackage_get_clean_target,$(2))
+
+endef
+
# vim: set noet sw=4 ts=4:
diff --git a/solenv/gbuild/TargetLocations.mk b/solenv/gbuild/TargetLocations.mk
index 8504e549685a..0218a39cadb6 100644
--- a/solenv/gbuild/TargetLocations.mk
+++ b/solenv/gbuild/TargetLocations.mk
@@ -86,6 +86,7 @@ gb_Extension_get_rootdir = $(WORKDIR)/Extension/$(1)/root
gb_Extension_get_workdir = $(WORKDIR)/Extension/$(1)
gb_ExtensionPackage_get_target = $(WORKDIR)/ExtensionPackage/$(1).filelist
gb_ExtensionPackage_get_preparation_target = $(WORKDIR)/ExtensionPackage/$(1).prepare
+gb_ExtensionPackageSet_get_target = $(WORKDIR)/ExtensionPackage/$(1).set
gb_ExternalPackage_get_target = $(WORKDIR)/ExternalPackage/$(1)
gb_ExternalProject_get_statedir = $(WORKDIR)/ExternalProject/$(1)
gb_ExternalProject_get_preparation_target = $(WORKDIR)/ExternalProject/$(1).prepare
@@ -258,6 +259,7 @@ $(eval $(call gb_Helper_make_clean_targets,\
ExternalPackage \
Extension \
ExtensionPackage \
+ ExtensionPackageSet \
Gallery \
GeneratedPackage \
HelpTarget \