make sure tmp/info gets created
[openwrt.git] / target / sdk / files / Makefile
index ba488e3..184a1f9 100644 (file)
@@ -30,21 +30,41 @@ export TOPDIR
 DEVELOPER=1
 export DEVELOPER
 
 DEVELOPER=1
 export DEVELOPER
 
+SDK=1
+export SDK
+
+export IS_TTY=$(shell tty -s && echo 1 || echo 0)
+include $(TOPDIR)/include/verbose.mk
+
 all: world
 
 all: world
 
-.pkginfo: FORCE
-ifneq ($(shell ./scripts/timestamp.pl -p .pkginfo package Makefile),.pkginfo)
-       @echo Collecting package info...
-       @-for dir in package/*/; do \
-               echo Source-Makefile: $${dir}Makefile; \
-               $(MAKE) --no-print-dir DUMP=1 -C $$dir 2>&- || true; \
-       done > $@
-endif
+define stamp
+tmp/info/.stamp-$(1)-$(shell ls $(2)/*/Makefile $(5) | (md5sum || md5) 2>/dev/null | cut -d' ' -f1)
+endef
+
+STAMP=$(call stamp,pkginfo,package)
+
+$(STAMP):
+       @mkdir -p tmp/info
+       @rm -f tmp/info/.stamp-pkginfo*
+       @touch $@
+
+define filedep
+$(foreach FILE,$(shell ls package/*/Makefile),
+tmp/.pkginfo: $(FILE)
+$(FILE):
+       @true
+)
+endef
+
+$(eval $(filedep))
 
 
-pkginfo-clean: FORCE
-       -rm -f .pkginfo .config.in
+tmp/.pkginfo: $(STAMP)
+       @echo -n Collecting package info... 
+       @$(NO_TRACE_MAKE) -s -f include/scan.mk SCAN_TARGET="pkginfo" SCAN_DIR="package" SCAN_NAME="package" SCAN_DEPS=""
 
 
-package/%: .pkginfo FORCE
+package/%: FORCE
+       @$(NO_TRACE_MAKE) -s tmp/.pkginfo
        $(MAKE) -C package $(patsubst package/%,%,$@) SDK=1
 
 download: FORCE
        $(MAKE) -C package $(patsubst package/%,%,$@) SDK=1
 
 download: FORCE
This page took 0.02445 seconds and 4 git commands to generate.