summaryrefslogtreecommitdiff
path: root/unitize.mk
diff options
context:
space:
mode:
authorJörg Frings-Fürst <debian@jff-webhosting.net>2014-07-23 09:06:59 +0200
committerJörg Frings-Fürst <debian@jff-webhosting.net>2014-07-23 09:06:59 +0200
commit4ea2cc3bd4a7d9b1c54a9d33e6a1cf82e7c8c21d (patch)
treed2e54377d14d604356c86862a326f64ae64dadd6 /unitize.mk
Imported Upstream version 0.18.1upstream/0.18.1
Diffstat (limited to 'unitize.mk')
-rw-r--r--unitize.mk29
1 files changed, 29 insertions, 0 deletions
diff --git a/unitize.mk b/unitize.mk
new file mode 100644
index 0000000..6aaa7a0
--- /dev/null
+++ b/unitize.mk
@@ -0,0 +1,29 @@
+# unitize.mk
+#
+# Post-processes each unit's .mk file to properly add its requirements to the master Makefile.
+
+# append files to SRC_FILES (*don't* use +=, that's a recursive append)
+UNITIZED_SRC_FILES := $(UNITIZED_SRC_FILES) src/$(UNIT_DIR)/$(UNIT_NAME).vala $(foreach file,$(UNIT_FILES),src/$(UNIT_DIR)/$(file))
+
+# append unit namespace to master list
+UNIT_NAMESPACES := $(UNIT_NAMESPACES) $(UNIT_NAME)
+
+# append unit resources to master list
+UNIT_RESOURCES := $(UNIT_RESOURCES) $(foreach rc,$(UNIT_RC),src/$(UNIT_DIR)/$(rc))
+
+# create custom uses lists for this unit; note that the unit-unit is automatically included
+# (unless the unit is the unit-unit)
+ifneq ($(UNIT_NAME),Unit)
+$(UNIT_NAME)_USES := Unit $(UNIT_USES)
+else
+$(UNIT_NAME)_USES := $(UNIT_USES)
+endif
+$(UNIT_NAME)_USES_INITS := $(foreach uses,$($(UNIT_NAME)_USES),$(uses).init_entry();)
+$(UNIT_NAME)_USES_TERMINATORS := $(foreach uses,$($(UNIT_NAME)_USES),$(uses).terminate_entry();)
+
+# clear unit variables so they are not appended to by the next unit
+UNIT_NAME=
+UNIT_DIR=
+UNIT_FILES=
+UNIT_USES=
+UNIT_RC=