aboutsummaryrefslogtreecommitdiffstats
path: root/scripts
diff options
context:
space:
mode:
authorFelix Fietkau <nbd@openwrt.org>2007-07-15 23:16:47 +0000
committerFelix Fietkau <nbd@openwrt.org>2007-07-15 23:16:47 +0000
commitec15f6a3bd901719a8f5c64f76a4c4e51f572b21 (patch)
treecd9df2633df98026758ab2cb30805f34021a4390 /scripts
parent90351f3587f0f64bac151f4701a6cd140650bd0b (diff)
downloadmaster-187ad058-ec15f6a3bd901719a8f5c64f76a4c4e51f572b21.tar.gz
master-187ad058-ec15f6a3bd901719a8f5c64f76a4c4e51f572b21.tar.bz2
master-187ad058-ec15f6a3bd901719a8f5c64f76a4c4e51f572b21.zip
fixes for recursive package scanning
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@7982 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'scripts')
-rwxr-xr-xscripts/metadata.pl14
1 files changed, 9 insertions, 5 deletions
diff --git a/scripts/metadata.pl b/scripts/metadata.pl
index dbd6ccef37..e8a7c1b4a8 100755
--- a/scripts/metadata.pl
+++ b/scripts/metadata.pl
@@ -72,12 +72,15 @@ sub parse_package_metadata() {
my $pkg;
my $makefile;
my $preconfig;
+ my $subdir;
my $src;
while (<>) {
chomp;
- /^Source-Makefile: \s*(.+\/([^\/]+)\/Makefile)\s*$/ and do {
+ /^Source-Makefile: \s*((.+\/)([^\/]+)\/Makefile)\s*$/ and do {
$makefile = $1;
- $src = $2;
+ $subdir = $2;
+ $src = $3;
+ $subdir =~ s/^package\///;
$srcpackage{$src} = [];
undef $pkg;
};
@@ -89,6 +92,7 @@ sub parse_package_metadata() {
$pkg->{default} = "m if ALL";
$pkg->{depends} = [];
$pkg->{builddepends} = [];
+ $pkg->{subdir} = $subdir;
$package{$1} = $pkg;
push @{$srcpackage{$src}}, $pkg;
};
@@ -503,7 +507,7 @@ sub gen_package_mk() {
$config = "\$(CONFIG_PACKAGE_$name)"
}
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";
}
@@ -519,7 +523,7 @@ sub gen_package_mk() {
next if defined $pkg_dep->{vdepends};
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})) {
$idx = $dep;
}
@@ -531,7 +535,7 @@ sub gen_package_mk() {
}
}
if ($depline) {
- $line .= "$pkg->{src}-compile: $depline\n";
+ $line .= $pkg->{subdir}."$pkg->{src}-compile: $depline\n";
}
}