From 105a602ecf14e4afe29f88e062496135bce41dc7 Mon Sep 17 00:00:00 2001 From: Felix Fietkau Date: Sun, 12 Nov 2006 05:06:56 +0000 Subject: implement target profiles in menuconfig SVN-Revision: 5512 --- scripts/gen_package_config.pl | 3 ++ scripts/gen_target_config.pl | 116 ++++++++++++++++++++++++++++++++++++++++-- 2 files changed, 116 insertions(+), 3 deletions(-) (limited to 'scripts') diff --git a/scripts/gen_package_config.pl b/scripts/gen_package_config.pl index 9c705af563..4ce117c06f 100755 --- a/scripts/gen_package_config.pl +++ b/scripts/gen_package_config.pl @@ -89,10 +89,13 @@ sub print_category($) { if ($c > 0) { $title .= ("." x $c). " ". $pkg->{title}; } + print "\tconfig DEFAULT_".$pkg->{name}."\n"; + print "\t\tbool\n\n"; print "\t"; $pkg->{menu} and print "menu"; print "config PACKAGE_".$pkg->{name}."\n"; print "\t\ttristate \"$title\"\n"; + print "\t\tdefault y if DEFAULT_".$pkg->{name}."\n"; foreach my $default (split /\s*,\s*/, $pkg->{default}) { print "\t\tdefault $default\n"; } diff --git a/scripts/gen_target_config.pl b/scripts/gen_target_config.pl index c0b83963b6..4d0d6b13ef 100755 --- a/scripts/gen_target_config.pl +++ b/scripts/gen_target_config.pl @@ -10,6 +10,8 @@ use strict; my @target; my $target; +my $profiles; +my $profile; sub features(@) { my $ret; @@ -30,8 +32,11 @@ sub features(@) { while (<>) { chomp; /^Target:\s*((.+)-(\d+\.\d+))\s*$/ and do { + my $conf = uc $3.'_'.$2; + $conf =~ tr/\.-/__/; $target = { id => $1, + conf => $conf, board => $2, kernel => $3 }; @@ -56,6 +61,22 @@ while (<>) { /^Linux-Version:\s*(.+)\s*$/ and $target->{version} = $1; /^Linux-Release:\s*(.+)\s*$/ and $target->{release} = $1; /^Linux-Kernel-Arch:\s*(.+)\s*$/ and $target->{karch} = $1; + /^Default-Packages:\s*(.+)\s*$/ and do { + my @pkgs = split /\s+/, $1; + $target->{defaultpkgs} = \@pkgs; + }; + /^Target-Profile:\s*(.+)\s*$/ and do { + $profiles = $target->{profiles} or $target->{profiles} = $profiles = []; + $profile = { + id => $1 + }; + push @$profiles, $profile; + }; + /^Target-Profile-Name:\s*(.+)\s*$/ and $profile->{name} = $1; + /^Target-Profile-Packages:\s*(.+)\s*$/ and do { + my @pkgs = split /\s+/, $1; + $profile->{pkgs} = \@pkgs; + }; } @target = sort { @@ -63,13 +84,18 @@ while (<>) { } @target; +print <{kernel}.'_'.$target->{board}; my $features = features(@{$target->{features}}); my $help = $target->{desc}; chomp $features; $features .= "\n"; - $conf =~ tr/\.-/__/; if ($help =~ /\w+/) { $help =~ s/^\s*/\t /mg; $help = "\thelp\n$help"; @@ -78,7 +104,7 @@ foreach $target (@target) { } print <{conf} bool "$target->{name}" select $target->{arch} $features$help @@ -86,3 +112,87 @@ $features$help EOF } +print <{profiles} or $profiles = [ + { + id => 'Default', + name => 'Default', + pkgs => [] + } + ]; + foreach my $profile (@$profiles) { + print <{conf}_$profile->{id} + bool "$profile->{name}" + depends LINUX_$target->{conf} +EOF + foreach my $pkg (@{$target->{defaultpkgs}}, @{$profile->{pkgs}}) { + print "\tselect DEFAULT_$pkg\n"; + } + print "\n"; + } +} + +print "endchoice\n"; -- cgit v1.2.3