X-Git-Url: https://git.rohieb.name/openwrt.git/blobdiff_plain/02cdebbb91a33d8e24da1c94a9d93ac39be168a7..894eedd014eed1eb9790c93be7961ca93761da34:/scripts/gen_deps.pl diff --git a/scripts/gen_deps.pl b/scripts/gen_deps.pl index 0cdcc97a1..745d31c7d 100755 --- a/scripts/gen_deps.pl +++ b/scripts/gen_deps.pl @@ -13,6 +13,7 @@ my $src; my $makefile; my %conf; my %pkg; +my %prereq; my %dep; my %options; my $opt; @@ -33,6 +34,9 @@ while ($line = <>) { defined $pkg{$name} or $pkg{$name} = {}; $pkg{$name}->{src} = $src; }; + $line =~ /^Prereq-Check:/ and !defined $prereq{$src} and do { + $pkg{$name}->{prereq} = 1; + }; $line =~ /^(Build-)?Depends: \s*(.+)\s*$/ and do { $pkg{$name}->{depends} ||= []; foreach my $v (split /\s+/, $2) { @@ -46,11 +50,19 @@ while ($line = <>) { $line=""; foreach $name (sort {uc($a) cmp uc($b)} keys %pkg) { + my $config; + if ($options{SDK}) { - $conf{$pkg{$name}->{src}} or print "package-m += $pkg{$name}->{src}\n"; - $conf{$pkg{$name}->{src}} = 1; + $conf{$pkg{$name}->{src}} or do { + $config = 'm'; + $conf{$pkg{$name}->{src}} = 1; + }; } else { - print "package-\$(CONFIG_PACKAGE_$name) += $pkg{$name}->{src}\n"; + $config = "\$(CONFIG_PACKAGE_$name)" + } + if ($config) { + print "package-$config += $pkg{$name}->{src}\n"; + $pkg{$name}->{prereq} and print "prereq-$config += $pkg{$name}->{src}\n"; } my $hasdeps = 0; @@ -62,6 +74,7 @@ foreach $name (sort {uc($a) cmp uc($b)} keys %pkg) { } elsif (defined($pkg{$dep}) && !$options{SDK}) { $idx = $dep; } + undef $idx if $idx =~ /^(kernel)|(base-files)$/; if ($idx) { next if $dep{$pkg{$name}->{src}."->".$idx}; $depline .= " $idx\-compile";