fixes for recursive package scanning

SVN-Revision: 7982
This commit is contained in:
Felix Fietkau 2007-07-15 23:16:47 +00:00
parent bdc9419a20
commit 7b16475eb7
2 changed files with 17 additions and 11 deletions

View File

@ -20,11 +20,11 @@ endif
define PackageDir define PackageDir
tmp/.$(SCAN_TARGET): tmp/info/.$(SCAN_TARGET)-$(1) tmp/.$(SCAN_TARGET): tmp/info/.$(SCAN_TARGET)-$(1)
tmp/info/.$(SCAN_TARGET)-$(1): $(SCAN_DIR)/$(1)/Makefile $(SCAN_STAMP) $(foreach DEP,$(DEPS_$(SCAN_DIR)/$(1)/Makefile) $(SCAN_DEPS),$(wildcard $(if $(filter /%,$(DEP)),$(DEP),$(SCAN_DIR)/$(1)/$(DEP)))) tmp/info/.$(SCAN_TARGET)-$(1): $(SCAN_DIR)/$(2)/Makefile $(SCAN_STAMP) $(foreach DEP,$(DEPS_$(SCAN_DIR)/$(1)/Makefile) $(SCAN_DEPS),$(wildcard $(if $(filter /%,$(DEP)),$(DEP),$(SCAN_DIR)/$(1)/$(DEP))))
{ \ { \
$$(call progress,Collecting $(SCAN_NAME) info: $(SCAN_DIR)/$(1)) \ $$(call progress,Collecting $(SCAN_NAME) info: $(SCAN_DIR)/$(2)) \
echo Source-Makefile: $(SCAN_DIR)/$(1)/Makefile; \ echo Source-Makefile: $(SCAN_DIR)/$(2)/Makefile; \
$(NO_TRACE_MAKE) --no-print-dir DUMP=1 -C $(SCAN_DIR)/$(1) 2>/dev/null || echo "ERROR: please fix $(SCAN_DIR)/$(1)/Makefile" >&2; \ $(NO_TRACE_MAKE) --no-print-dir DUMP=1 -C $(SCAN_DIR)/$(2) 2>/dev/null || echo "ERROR: please fix $(SCAN_DIR)/$(2)/Makefile" >&2; \
echo; \ echo; \
} > $$@ || true } > $$@ || true
endef endef
@ -37,7 +37,9 @@ tmp/info/.files-$(SCAN_TARGET).mk: $(FILELIST)
( \ ( \
cat $< | awk '{print "$(SCAN_DIR)/" $$0 "/Makefile" }' | xargs grep -HE '^ *SCAN_DEPS *= *' | awk -F: '{ gsub(/^.*DEPS *= */, "", $$2); print "DEPS_" $$1 "=" $$2 }'; \ cat $< | awk '{print "$(SCAN_DIR)/" $$0 "/Makefile" }' | xargs grep -HE '^ *SCAN_DEPS *= *' | awk -F: '{ gsub(/^.*DEPS *= */, "", $$2); print "DEPS_" $$1 "=" $$2 }'; \
awk -v deps="$$DEPS" '{ \ awk -v deps="$$DEPS" '{ \
print "$$(eval $$(call PackageDir," $$0 "))"; \ info=$$0; \
gsub(/\//, "_", info); \
print "$$(eval $$(call PackageDir," info "," $$0 "))"; \
} ' < $<; \ } ' < $<; \
true; \ true; \
) > $@ ) > $@
@ -57,7 +59,7 @@ $(TARGET_STAMP):
tmp/.$(SCAN_TARGET): $(TARGET_STAMP) $(SCAN_STAMP) tmp/.$(SCAN_TARGET): $(TARGET_STAMP) $(SCAN_STAMP)
$(call progress,Collecting $(SCAN_NAME) info: merging...) $(call progress,Collecting $(SCAN_NAME) info: merging...)
cat $(FILELIST) | awk '{print "tmp/info/.$(SCAN_TARGET)-" $$0}' | xargs cat > $@ cat $(FILELIST) | awk '{gsub(/\//, "_", $$0);print "tmp/info/.$(SCAN_TARGET)-" $$0}' | xargs cat > $@
$(call progress,Collecting $(SCAN_NAME) info: done) $(call progress,Collecting $(SCAN_NAME) info: done)
echo echo

View File

@ -72,12 +72,15 @@ sub parse_package_metadata() {
my $pkg; my $pkg;
my $makefile; my $makefile;
my $preconfig; my $preconfig;
my $subdir;
my $src; my $src;
while (<>) { while (<>) {
chomp; chomp;
/^Source-Makefile: \s*(.+\/([^\/]+)\/Makefile)\s*$/ and do { /^Source-Makefile: \s*((.+\/)([^\/]+)\/Makefile)\s*$/ and do {
$makefile = $1; $makefile = $1;
$src = $2; $subdir = $2;
$src = $3;
$subdir =~ s/^package\///;
$srcpackage{$src} = []; $srcpackage{$src} = [];
undef $pkg; undef $pkg;
}; };
@ -89,6 +92,7 @@ sub parse_package_metadata() {
$pkg->{default} = "m if ALL"; $pkg->{default} = "m if ALL";
$pkg->{depends} = []; $pkg->{depends} = [];
$pkg->{builddepends} = []; $pkg->{builddepends} = [];
$pkg->{subdir} = $subdir;
$package{$1} = $pkg; $package{$1} = $pkg;
push @{$srcpackage{$src}}, $pkg; push @{$srcpackage{$src}}, $pkg;
}; };
@ -503,7 +507,7 @@ sub gen_package_mk() {
$config = "\$(CONFIG_PACKAGE_$name)" $config = "\$(CONFIG_PACKAGE_$name)"
} }
if ($config) { if ($config) {
print "package-$config += $pkg->{src}\n"; print "package-$config += $pkg->{subdir}$pkg->{src}\n";
$pkg->{prereq} and print "prereq-$config += $pkg->{src}\n"; $pkg->{prereq} and print "prereq-$config += $pkg->{src}\n";
} }
@ -519,7 +523,7 @@ sub gen_package_mk() {
next if defined $pkg_dep->{vdepends}; next if defined $pkg_dep->{vdepends};
if (defined $pkg_dep->{src}) { if (defined $pkg_dep->{src}) {
($pkg->{src} ne $pkg_dep->{src}) and $idx = $pkg_dep->{src}; ($pkg->{src} ne $pkg_dep->{src}) and $idx = $pkg_dep->{subdir}.$pkg_dep->{src};
} elsif (defined($pkg_dep) && !defined($ENV{SDK})) { } elsif (defined($pkg_dep) && !defined($ENV{SDK})) {
$idx = $dep; $idx = $dep;
} }
@ -531,7 +535,7 @@ sub gen_package_mk() {
} }
} }
if ($depline) { if ($depline) {
$line .= "$pkg->{src}-compile: $depline\n"; $line .= $pkg->{subdir}."$pkg->{src}-compile: $depline\n";
} }
} }