From: Felix Fietkau Date: Fri, 13 May 2016 14:31:58 +0000 (+0200) Subject: scripts/metadata.pl: add support for generating profile make code for the image builder X-Git-Url: http://git.openwrt.org/?p=openwrt%2Fstaging%2Fflorian.git;a=commitdiff_plain;h=0d10ada19c1a1bff98e2e9cc79ea1dca0fdcbe1c scripts/metadata.pl: add support for generating profile make code for the image builder Signed-off-by: Felix Fietkau --- 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 <{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 < [] } ]; + + $target->{sort} and @{$target->{profiles}} = sort { + $a->{priority} <=> $b->{priority} or + $a->{name} cmp $b->{name}; + } @{$target->{profiles}}; } return @target; }