diff options
author | Felix Fietkau <nbd@openwrt.org> | 2007-09-08 19:55:42 +0000 |
---|---|---|
committer | Felix Fietkau <nbd@openwrt.org> | 2007-09-08 19:55:42 +0000 |
commit | a9d683ca912b2c4837b2e65909c09ca01babe3df (patch) | |
tree | 6cbca6e13dd0bb18c9d9f1d4baa9a0ea7801b959 /scripts/config.pl | |
parent | 4a2e4920b1d909ca254853b0dce46af3123e8f74 (diff) | |
download | upstream-a9d683ca912b2c4837b2e65909c09ca01babe3df.tar.gz upstream-a9d683ca912b2c4837b2e65909c09ca01babe3df.tar.bz2 upstream-a9d683ca912b2c4837b2e65909c09ca01babe3df.zip |
major target cleanup. it is now possible to have subtargets that can override many target settings, including arch - merge adm5120, adm5120eb. target profiles still need to be adapted for subtargets
SVN-Revision: 8694
Diffstat (limited to 'scripts/config.pl')
-rwxr-xr-x | scripts/config.pl | 148 |
1 files changed, 0 insertions, 148 deletions
diff --git a/scripts/config.pl b/scripts/config.pl deleted file mode 100755 index 53b8f11025..0000000000 --- a/scripts/config.pl +++ /dev/null @@ -1,148 +0,0 @@ -#!/usr/bin/env perl -# -# Copyright (C) 2006 Felix Fietkau <nbd@openwrt.org> -# -# This is free software, licensed under the GNU General Public License v2. -# See /LICENSE for more information. -# - -use warnings; -use strict; - -my @arg = @ARGV; - -sub load_config($) { - my $file = shift; - my %config; - - open FILE, "$file" or die "can't open file"; - while (<FILE>) { - chomp; - /^CONFIG_(.+?)=(.+)/ and do { - $config{$1} = $2; - next; - }; - /^# CONFIG_(.+?) is not set/ and do { - $config{$1} = "#undef"; - next; - }; - /^#/ and next; - /^(.+)$/ and print "WARNING: can't parse line: $1\n"; - } - return \%config; -} - - -sub config_and($$) { - my $cfg1 = shift; - my $cfg2 = shift; - my %config; - - foreach my $config (keys %$cfg1) { - my $val1 = $cfg1->{$config}; - my $val2 = $cfg2->{$config}; - $val2 and ($val1 eq $val2) and do { - $config{$config} = $val1; - }; - } - return \%config; -} - - -sub config_add($$$) { - my $cfg1 = shift; - my $cfg2 = shift; - my $mod_plus = shift; - my %config; - - for ($cfg1, $cfg2) { - my %cfg = %$_; - - foreach my $config (keys %cfg) { - next if $mod_plus and $config{$config} and $config{$config} eq "y"; - $config{$config} = $cfg{$config}; - } - } - return \%config; -} - -sub config_diff($$) { - my $cfg1 = shift; - my $cfg2 = shift; - my %config; - - foreach my $config (keys %$cfg2) { - if (!$cfg1->{$config} or $cfg1->{$config} ne $cfg2->{$config}) { - $config{$config} = $cfg2->{$config}; - } - } - return \%config -} - -sub config_sub($$) { - my $cfg1 = shift; - my $cfg2 = shift; - my %config = %{$cfg1}; - - foreach my $config (keys %$cfg2) { - delete $config{$config}; - } - return \%config; -} - -sub print_cfgline($$) { - my $name = shift; - my $val = shift; - if ($val eq '#undef') { - print "# CONFIG_$name is not set\n"; - } else { - print "CONFIG_$name=$val\n"; - } -} - - -sub dump_config($) { - my $cfg = shift; - die "argument error in dump_config" unless ($cfg); - my %config = %$cfg; - foreach my $config (sort keys %config) { - print_cfgline($config, $config{$config}); - } -} - -sub parse_expr($); - -sub parse_expr($) { - my $pos = shift; - my $arg = $arg[$$pos++]; - - die "Parse error" if (!$arg); - - if ($arg eq '&') { - my $arg1 = parse_expr($pos); - my $arg2 = parse_expr($pos); - return config_and($arg1, $arg2); - } elsif ($arg =~ /^\+/) { - my $arg1 = parse_expr($pos); - my $arg2 = parse_expr($pos); - return config_add($arg1, $arg2, 0); - } elsif ($arg =~ /^m\+/) { - my $arg1 = parse_expr($pos); - my $arg2 = parse_expr($pos); - return config_add($arg1, $arg2, 1); - } elsif ($arg eq '>') { - my $arg1 = parse_expr($pos); - my $arg2 = parse_expr($pos); - return config_diff($arg1, $arg2); - } elsif ($arg eq '-') { - my $arg1 = parse_expr($pos); - my $arg2 = parse_expr($pos); - return config_sub($arg1, $arg2); - } else { - return load_config($arg); - } -} - -my $pos = 0; -dump_config(parse_expr(\$pos)); -die "Parse error" if ($arg[$pos]); |