From 768df7e9e98c214c602edd3ee48bd1d72e2dc39c Mon Sep 17 00:00:00 2001 From: Michael Shigorin Date: Wed, 19 Jun 2013 19:57:30 +0400 Subject: [PATCH] main.mk: target refactoring The issue with the original hasty code that stuck around was that it bluntly ignored any ifdef/ifeq constructs due to an obvious reason of being essentially a grep, not a makefile interpreter. It's now fixed so that e.g. arch-specific targets won't pop up for no good reason. Thanks ldv@ for discussion and a reminder about the dump mode (make -p). --- main.mk | 19 +++++++++++-------- 1 file changed, 11 insertions(+), 8 deletions(-) diff --git a/main.mk b/main.mk index 5cc06fb1..844485be 100644 --- a/main.mk +++ b/main.mk @@ -40,14 +40,17 @@ $(shell mkdir -p $(IMAGEDIR)) IMAGEDIR := $(wildcard $(IMAGEDIR)) endif -# FIXME: this is buggy since *.mk can expose parts conditionally -# (e.g. test.mk does DEBUG-only bits) and these will fail -DISTRO_TARGETS := $(shell sed -n 's,^\(distro/[^:.]\+\):.*$$,\1,p' \ - lib/distro.mk $(wildcard conf.d/*.mk) | sort -u) -VE_TARGETS := $(shell sed -n 's,^\(ve/[^:.]\+\):.*$$,\1,p' \ - lib/ve.mk $(wildcard conf.d/*.mk) | sort -u) -VM_TARGETS := $(shell sed -n 's,^\(vm/[^:.]\+\):.*$$,\1,p' \ - lib/vm.mk $(wildcard conf.d/*.mk) | sort -u) +# conf.d/*.mk can expose parts conditionally (e.g. DEBUG-only bits) +targets = $(shell \ + for i in conf.d/*.mk; do \ + make IMAGE_CLASS=$(1) -s -r -p -f $$i 2>/dev/null; \ + done \ + | sed -rn 's,^($(1)/[^.:]+):.*,\1,p' \ + | sort -u) + +DISTRO_TARGETS := $(call targets,distro) +VE_TARGETS := $(call targets,ve) +VM_TARGETS := $(call targets,vm) DISTROS := $(call addsuffices,$(DISTRO_EXTS),$(DISTRO_TARGETS)) VES := $(call addsuffices,$(VE_EXTS),$(VE_TARGETS)) VMS := $(call addsuffices,$(VM_EXTS),$(VM_TARGETS))