summaryrefslogtreecommitdiff
path: root/include/scan.mk
blob: 3229523ea4ef36c0c1e28543ad6b433c6c4705ed (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
include $(TOPDIR)/include/verbose.mk

SCAN_TARGET ?= pkginfo
SCAN_NAME ?= package
SCAN_DIR ?= package
SCAN_DEPS ?= include/package.mk

ifeq ($(IS_TTY),1)
  define progress
	printf "\033[M\r$(1)" >&2;
  endef
else
  define progress
	:
  endef
endif

SCAN = $(patsubst $(SCAN_DIR)/%/Makefile,%,$(shell ls $(SCAN_DIR)/*/Makefile))
tmp/.$(SCAN_TARGET):
	@($(call progress,Collecting $(SCAN_NAME) info: merging...))
	for file in $(SCAN); do \
		cat tmp/info/.$(SCAN_TARGET)-$$file; \
	done > $@
	@($(call progress,Collecting $(SCAN_NAME) info: done))
	@echo

ifneq ($(SCAN_EXTRA),)
SCAN_STAMP=tmp/info/.scan-$(SCAN_TARGET)-$(shell ls $(SCAN_EXTRA) 2>/dev/null | (md5sum || md5) 2>/dev/null | cut -d' ' -f1)
$(SCAN_STAMP):
	rm -f tmp/info/.scan-$(SCAN_TARGET)-*
	touch $@
endif

# FIXME: generate this dynamically?
ifeq ($(SCAN_TARGET),pkginfo)
tmp/info/.pkginfo-kernel: $(shell ls package/kernel/modules/*.mk)
endif

define scanfiles
$(foreach FILE,$(SCAN),
  tmp/.$(SCAN_TARGET): tmp/info/.$(SCAN_TARGET)-$(FILE) FORCE
  tmp/info/.$(SCAN_TARGET)-$(FILE): $(SCAN_DEPS) $(SCAN_DIR)/$(FILE)/Makefile $(SCAN_STAMP)
	{ \
		$$(call progress,Collecting $(SCAN_NAME) info: $(SCAN_DIR)/$(FILE)) \
		echo Source-Makefile: $(SCAN_DIR)/$(FILE)/Makefile; \
		$(NO_TRACE_MAKE) --no-print-dir DUMP=1 -C $(SCAN_DIR)/$(FILE) 3>/dev/null || echo "ERROR: please fix $(SCAN_DIR)/$(FILE)/Makefile" >&2; \
		echo; \
	} > $$@
)

endef
$(eval $(call scanfiles))

FORCE:
.PHONY: FORCE