fix submenu sorting
SVN-Revision: 5195
This commit is contained in:
parent
38fef4b4a8
commit
bd99a3e0cd
1 changed files with 32 additions and 23 deletions
|
@ -13,19 +13,7 @@ my $makefile;
|
||||||
my $pkg;
|
my $pkg;
|
||||||
my %package;
|
my %package;
|
||||||
my %category;
|
my %category;
|
||||||
my $cur_menu;
|
|
||||||
my $cur_menu_dep;
|
|
||||||
|
|
||||||
sub close_submenu {
|
|
||||||
if ($cur_menu) {
|
|
||||||
print "endmenu\n";
|
|
||||||
$cur_menu_dep and do {
|
|
||||||
print "endif\n";
|
|
||||||
$cur_menu_dep = undef;
|
|
||||||
};
|
|
||||||
undef $cur_menu;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
sub find_dep($$) {
|
sub find_dep($$) {
|
||||||
my $pkg = shift;
|
my $pkg = shift;
|
||||||
|
@ -45,6 +33,7 @@ sub depends($$) {
|
||||||
my $b = shift;
|
my $b = shift;
|
||||||
my $ret;
|
my $ret;
|
||||||
|
|
||||||
|
return 0 if ($a->{submenu} ne $b->{submenu});
|
||||||
if (find_dep($a, $b->{name}) == 1) {
|
if (find_dep($a, $b->{name}) == 1) {
|
||||||
$ret = 1;
|
$ret = 1;
|
||||||
} elsif (find_dep($b, $a->{name}) == 1) {
|
} elsif (find_dep($b, $a->{name}) == 1) {
|
||||||
|
@ -59,25 +48,42 @@ sub depends($$) {
|
||||||
|
|
||||||
sub print_category($) {
|
sub print_category($) {
|
||||||
my $cat = shift;
|
my $cat = shift;
|
||||||
|
my %menus;
|
||||||
|
my %menu_dep;
|
||||||
|
|
||||||
return unless $category{$cat};
|
return unless $category{$cat};
|
||||||
|
|
||||||
print "menu \"$cat\"\n\n";
|
print "menu \"$cat\"\n\n";
|
||||||
my %spkg = %{$category{$cat}};
|
my %spkg = %{$category{$cat}};
|
||||||
|
|
||||||
foreach my $spkg (sort {uc($a) cmp uc($b)} keys %spkg) {
|
foreach my $spkg (sort {uc($a) cmp uc($b)} keys %spkg) {
|
||||||
|
foreach my $pkg (@{$spkg{$spkg}}) {
|
||||||
|
my $menu = $pkg->{submenu};
|
||||||
|
if ($menu) {
|
||||||
|
$menu_dep{$menu} or $menu_dep{$menu} = $pkg->{submenudep};
|
||||||
|
} else {
|
||||||
|
$menu = 'undef';
|
||||||
|
}
|
||||||
|
$menus{$menu} or $menus{$menu} = [];
|
||||||
|
push @{$menus{$menu}}, $pkg;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
my @menus = sort {
|
||||||
|
($a eq 'undef' ? 1 : 0) or
|
||||||
|
($b eq 'undef' ? -1 : 0) or
|
||||||
|
($a cmp $b)
|
||||||
|
} keys %menus;
|
||||||
|
|
||||||
|
foreach my $menu (@menus) {
|
||||||
my @pkgs = sort {
|
my @pkgs = sort {
|
||||||
depends($a, $b) or
|
depends($a, $b) or
|
||||||
$a->{submenu}."->".$a->{name} cmp $b->{submenu}."->".$b->{name}
|
($a->{name} cmp $b->{name})
|
||||||
} @{$spkg{$spkg}};
|
} @{$menus{$menu}};
|
||||||
|
if ($menu ne 'undef') {
|
||||||
|
$menu_dep{$menu} and print "if $menu_dep{$menu}\n";
|
||||||
|
print "menu \"$menu\"\n";
|
||||||
|
}
|
||||||
foreach my $pkg (@pkgs) {
|
foreach my $pkg (@pkgs) {
|
||||||
if ($cur_menu ne $pkg->{submenu}) {
|
|
||||||
close_submenu();
|
|
||||||
if ($pkg->{submenu}) {
|
|
||||||
$cur_menu = $pkg->{submenu};
|
|
||||||
$cur_menu_dep = $pkg->{submenudep} and print "if $cur_menu_dep\n";
|
|
||||||
print "menu \"$cur_menu\"\n";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
my $title = $pkg->{name};
|
my $title = $pkg->{name};
|
||||||
my $c = (72 - length($pkg->{name}) - length($pkg->{title}));
|
my $c = (72 - length($pkg->{name}) - length($pkg->{title}));
|
||||||
if ($c > 0) {
|
if ($c > 0) {
|
||||||
|
@ -110,8 +116,11 @@ sub print_category($) {
|
||||||
|
|
||||||
$pkg->{config} and print $pkg->{config}."\n";
|
$pkg->{config} and print $pkg->{config}."\n";
|
||||||
}
|
}
|
||||||
|
if ($menu ne 'undef') {
|
||||||
|
print "endmenu\n";
|
||||||
|
$menu_dep{$menu} and print "endif\n";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
close_submenu();
|
|
||||||
print "endmenu\n\n";
|
print "endmenu\n\n";
|
||||||
|
|
||||||
undef $category{$cat};
|
undef $category{$cat};
|
||||||
|
|
Loading…
Reference in a new issue