SOURCES: kernel-config-sort.pl (NEW) - script I am using to sort kernel con...
sparky
sparky at pld-linux.org
Sun Sep 28 02:37:42 CEST 2008
Author: sparky Date: Sun Sep 28 00:37:42 2008 GMT
Module: SOURCES Tag: HEAD
---- Log message:
- script I am using to sort kernel config files
---- Files affected:
SOURCES:
kernel-config-sort.pl (NONE -> 1.1) (NEW)
---- Diffs:
================================================================
Index: SOURCES/kernel-config-sort.pl
diff -u /dev/null SOURCES/kernel-config-sort.pl:1.1
--- /dev/null Sun Sep 28 02:37:43 2008
+++ SOURCES/kernel-config-sort.pl Sun Sep 28 02:37:37 2008
@@ -0,0 +1,220 @@
+#!/usr/bin/perl
+#
+# Script used to sort kernel-*.config files.
+# Usage:
+# ./kernel-config-sort.pl ../BUILD/linux-2.6.*/ kernel-multiarch.config
+#
+# ./kernel-config-sort.pl ../BUILD/linux-2.6.*/ -a x86 kernel-x86_84.config
+#
+use strict;
+use warnings;
+
+my $dir = ( shift @ARGV ) || ".";
+my $arch;
+if ( $ARGV[0] eq "-a" ) {
+ shift @ARGV;
+ $arch = shift @ARGV;
+}
+my $old_dir = $ENV{PWD};
+chdir $dir;
+
+my @Kconfig_list;
+my @Kconfig_arch;
+
+sub look_in
+{
+ my $parent = shift;
+ my @files = glob $parent."*";
+ foreach ( @files ) {
+ if ( -d ) {
+ if ( $_ eq "Documentation" or $_ eq "build-done" ) {
+ warn "Skipping $_\n";
+ next;
+ }
+ look_in( $_ . '/' );
+ next;
+ }
+ if ( m#^.*/Kconfig# ) {
+ if ( m#^arch/# ) {
+ push @Kconfig_arch, $_;
+ } else {
+ push @Kconfig_list, $_;
+ }
+ }
+ }
+}
+
+if ( $arch ) {
+ push @Kconfig_list, "arch/$arch/Kconfig";
+} else {
+ look_in("");
+ push @Kconfig_list, @Kconfig_arch;
+}
+
+my %byFile;
+my %byName;
+
+sub add_Kconfig
+{
+ my $file = shift;
+
+ my @maybe_add_source;
+ my @config_list;
+
+ unless ( -r $file ) {
+ warn "FILE $file does not exist\n";
+ return;
+ }
+
+ open my $f_in, '<', $file;
+ while ( <$f_in> ) {
+ if ( /^\s?(?:menu)?config\s+(.*?)`?\s*$/ ) {
+ if ( $byName{ $1 } ) {
+ warn "Warning: $file: $1 already defined in $byName{ $1 }\n";
+ next;
+ }
+ push @config_list, [ 'o', $1 ];
+ next;
+ }
+ if ( /^\s?comment\s+"(.*?)"\s*$/ ) {
+ push @config_list, [ 'c', $1 ];
+ next;
+ }
+ if ( /^\s*source\s+"(\S+?)"\s*$/ or /^\s*source\s+(\S+?)\s*$/) {
+ push @maybe_add_source, $1;
+ push @config_list, [ 's', $1 ];
+ next;
+ }
+ }
+ close $f_in;
+
+ $byFile{ $file } = \@config_list;
+
+ {
+ my %add;
+ @add{ @maybe_add_source } = ();
+ foreach ( @Kconfig_list ) {
+ delete $add{ $_ } if exists $add{ $_ };
+ }
+ if ( keys %add ) {
+ #warn "Adding more source files: " . ( join ", ", sort keys %add ) ."\n";
+ push @Kconfig_list, sort keys %add;
+ }
+ }
+}
+
+{
+ my $i;
+ for ( $i = 0; $i < scalar @Kconfig_list; $i++ ) {
+ my $file = $Kconfig_list[ $i ];
+ add_Kconfig( $file );
+ }
+}
+
+my $arch_specific;
+unless ( $arch ) {
+ my @arch_specific;
+
+ foreach my $f ( sort keys %byFile ) {
+ next unless $f =~ /^arch/;
+ foreach my $line ( @{ $byFile{ $f } } ) {
+ push @arch_specific, $line->[1]
+ if $line->[0] eq 'o';
+ }
+ delete $byFile{ $f };
+ }
+
+ my @as = map { [ 'o', $_ ] } sort @arch_specific;
+ $arch_specific = \@as;
+}
+
+chdir $old_dir;
+
+my $out_file = $ARGV[ $#ARGV ];
+
+my %setOptions;
+
+my $allowed_name = qr/[A-Za-z0-9_]+/;
+my $comment = "";
+while ( <> ) {
+ if ( /^#\*/ ) {
+ $comment .= $_;
+ next;
+ }
+ my $opt;
+ if ( /^# CONFIG_($allowed_name) is not set$/ ) {
+ $opt = $1;
+ }
+ if ( /^(?:CONFIG_)?($allowed_name)[=\s]/ ) {
+ $opt = $1;
+ }
+ unless ( $opt ) {
+ if ( /\S/ and !/^#-/ ) {
+ warn "Ignored line: $_";
+ }
+ next;
+ }
+
+ if ( exists $setOptions{ $opt } ) {
+ die "OPTION $opt REDEFINED";
+ }
+ chomp;
+ $setOptions{ $opt } = $comment . $_;
+ $comment = "";
+}
+
+sub file_out
+{
+ my $file = shift;
+ my $any_out = 0;
+ my @out;
+ push @out, "#-", "#- *** FILE: $file ***", "#-";
+ my $file_lines = $byFile{ $file };
+
+ foreach my $line ( @{$file_lines} ) {
+ my ($type, $data) = @$line;
+ if ( $type eq 'o' ) {
+ if ( exists $setOptions{ $data } ) {
+ push @out, $setOptions{ $data };
+ delete $setOptions{ $data };
+ $any_out = 1;
+ }
+ } elsif ( $type eq 'c' ) {
+ push @out, "#- $data";
+ } elsif ( $type eq 's' ) {
+ push @out, "#- file $data goes here";
+ }
+ }
+ if ( $any_out ) {
+ return "\n" . ( join "\n", @out ) . "\n";
+ }
+ return "";
+}
+
+*FILE_OUT = \*STDOUT;
+if ( $out_file ) {
+ open FILE_OUT, '>', $out_file;
+}
+unless ( $arch ) {
+ my @out;
+ foreach my $f ( sort keys %byFile ) {
+ push @out, file_out( $f );
+ }
+
+ my $as_name = "arch/* - ARCH SPECIFIC OPTIONS";
+ $byFile{ $as_name } = $arch_specific;
+ unshift @out, file_out( $as_name );
+
+ print FILE_OUT @out;
+} else {
+ foreach my $f ( sort keys %byFile ) {
+ print FILE_OUT file_out( $f );
+ }
+}
+
+if ( keys %setOptions ) {
+ print FILE_OUT "\n#-\n#- *** PROBABLY REMOVED OPTIONS ***\n#-\n";
+ foreach my $k ( sort keys %setOptions ) {
+ print FILE_OUT $setOptions{ $k } . "\n";
+ }
+}
================================================================
More information about the pld-cvs-commit
mailing list