diff options
author | Felix Fietkau <nbd@nbd.name> | 2016-05-13 16:31:58 +0200 |
---|---|---|
committer | Felix Fietkau <nbd@nbd.name> | 2016-05-13 16:32:36 +0200 |
commit | 0d10ada19c1a1bff98e2e9cc79ea1dca0fdcbe1c (patch) | |
tree | ed2026f974379a235152d530945878e90ad8987c | |
parent | 111285e742d075956a149dce5a817fad3de2c850 (diff) | |
download | upstream-0d10ada19c1a1bff98e2e9cc79ea1dca0fdcbe1c.tar.gz upstream-0d10ada19c1a1bff98e2e9cc79ea1dca0fdcbe1c.tar.bz2 upstream-0d10ada19c1a1bff98e2e9cc79ea1dca0fdcbe1c.zip |
scripts/metadata.pl: add support for generating profile make code for the image builder
Signed-off-by: Felix Fietkau <nbd@nbd.name>
-rwxr-xr-x | scripts/metadata.pl | 23 | ||||
-rw-r--r-- | scripts/metadata.pm | 5 |
2 files changed, 22 insertions, 6 deletions
diff --git a/scripts/metadata.pl b/scripts/metadata.pl index 260d06d712..c7582b42dc 100755 --- a/scripts/metadata.pl +++ b/scripts/metadata.pl @@ -282,12 +282,7 @@ EOF foreach my $target (@target) { my $profiles = $target->{profiles}; - $target->{sort} and @$profiles = sort { - $a->{priority} <=> $b->{priority} or - $a->{name} cmp $b->{name}; - } @$profiles; - - foreach my $profile (@$profiles) { + foreach my $profile (@{$target->{profiles}}) { print <<EOF; config TARGET_$target->{conf}_$profile->{id} bool "$profile->{name}" @@ -912,11 +907,26 @@ sub gen_version_filtered_list() { } } +sub gen_profile_mk() { + my $file = shift @ARGV; + my $target = shift @ARGV; + my @targets = parse_target_metadata($file); + foreach my $cur (@targets) { + next unless $cur->{id} eq $target; + print "PROFILE_NAMES = ".join(" ", map { $_->{id} } @{$cur->{profiles}})."\n"; + foreach my $profile (@{$cur->{profiles}}) { + print $profile->{id}.'_NAME:='.$profile->{name}."\n"; + print $profile->{id}.'_PACKAGES:='.join(' ', @{$profile->{packages}})."\n"; + } + } +} + sub parse_command() { GetOptions("ignore=s", \@ignore); my $cmd = shift @ARGV; for ($cmd) { /^target_config$/ and return gen_target_config(); + /^profile_mk$/ and return gen_profile_mk(); /^package_mk$/ and return gen_package_mk(); /^package_config$/ and return gen_package_config(); /^kconfig/ and return gen_kconfig_overrides(); @@ -929,6 +939,7 @@ sub parse_command() { print <<EOF Available Commands: $0 target_config [file] Target metadata in Kconfig format + $0 profile_mk [file] [target] Profile metadata in makefile format $0 package_mk [file] Package metadata in makefile format $0 package_config [file] Package metadata in Kconfig format $0 kconfig [file] [config] [patchver] Kernel config overrides diff --git a/scripts/metadata.pm b/scripts/metadata.pm index 5f28289037..e2a739533c 100644 --- a/scripts/metadata.pm +++ b/scripts/metadata.pm @@ -112,6 +112,11 @@ sub parse_target_metadata($) { packages => [] } ]; + + $target->{sort} and @{$target->{profiles}} = sort { + $a->{priority} <=> $b->{priority} or + $a->{name} cmp $b->{name}; + } @{$target->{profiles}}; } return @target; } |