summaryrefslogtreecommitdiffstats
path: root/scripts
diff options
context:
space:
mode:
authorFelix Fietkau <nbd@openwrt.org>2007-04-04 16:13:54 +0000
committerFelix Fietkau <nbd@openwrt.org>2007-04-04 16:13:54 +0000
commitb21ed1d7e484b913f0f71807d7f5c1c070fe41d4 (patch)
tree810198ef30d0374cb09027b1948eaefd7e01d271 /scripts
parent523fe3cf87d70bc0de2379dad8b03cf62ab86e49 (diff)
downloadmaster-31e0f0ae-b21ed1d7e484b913f0f71807d7f5c1c070fe41d4.tar.gz
master-31e0f0ae-b21ed1d7e484b913f0f71807d7f5c1c070fe41d4.tar.bz2
master-31e0f0ae-b21ed1d7e484b913f0f71807d7f5c1c070fe41d4.zip
move gen_busybox_menuconfig.pl to package/busybox
SVN-Revision: 6865
Diffstat (limited to 'scripts')
-rwxr-xr-xscripts/gen_busybox_menuconfig.pl78
1 files changed, 0 insertions, 78 deletions
diff --git a/scripts/gen_busybox_menuconfig.pl b/scripts/gen_busybox_menuconfig.pl
deleted file mode 100755
index 0128bf78d7..0000000000
--- a/scripts/gen_busybox_menuconfig.pl
+++ /dev/null
@@ -1,78 +0,0 @@
-#!/usr/bin/perl
-#
-# Copyright (C) 2006 OpenWrt.org
-#
-# This is free software, licensed under the GNU General Public License v2.
-# See /LICENSE for more information.
-#
-
-use strict;
-my $PATH = $ARGV[0];
-($PATH and -d $PATH) or die 'invalid path';
-my $DEFCONFIG = $ARGV[1];
-($DEFCONFIG and -f $DEFCONFIG) or die 'invalid config file';
-
-my %config;
-
-open CONFIG, $DEFCONFIG or die 'cannot open config file';
-while (<CONFIG>) {
- /^CONFIG_([\w_]+)=([ym])/ and $config{$1} = $2;
- /^CONFIG_([\w_]+)=(\d+)/ and $config{$1} = $2;
- /^CONFIG_([\w_]+)=(".+")/ and $config{$1} = $2;
-}
-close CONFIG;
-
-open FIND, "find \"$PATH\" -name Config.in |";
-while (<FIND>) {
- chomp;
- my $input = $_;
- s/^$PATH\///g;
- s/sysdeps\/linux\///g;
- my $output = $_;
- print STDERR "$input => $output\n";
- $output =~ /^(.+)\/[^\/]+$/ and system("mkdir -p $1");
-
- open INPUT, $input;
- open OUTPUT, ">$output";
- my ($cur, $default_set, $line);
- while ($line = <INPUT>) {
- next if $line =~ /^\s*mainmenu/;
-
- # FIXME: make this dynamic
- $line =~ s/default FEATURE_BUFFERS_USE_MALLOC/default FEATURE_BUFFERS_GO_ON_STACK/;
- $line =~ s/default FEATURE_SH_IS_NONE/default FEATURE_SH_IS_ASH/;
-
- if ($line =~ /^\s*config\s*([\w_]+)/) {
- $cur = $1;
- undef $default_set;
- }
- if ($line =~ /^\s*(menu|choice|end|source)/) {
- undef $cur;
- undef $default_set;
- }
- $line =~ s/^(\s*source\s+)/$1package\/busybox\/config\//;
-
- $line =~ s/^(\s*(prompt "[^"]+" if|config|depends|depends on|select|default|default \w if)\s+\!?)([A-Z_])/$1BUSYBOX_CONFIG_$3/g;
- $line =~ s/(( \|\| | \&\& | \( )!?)([A-Z_])/$1BUSYBOX_CONFIG_$3/g;
- $line =~ s/(\( ?!?)([A-Z_]+ (\|\||&&))/$1BUSYBOX_CONFIG_$2/g;
-
- if ($cur) {
- ($cur eq 'LFS') and do {
- $line =~ s/^(\s*(bool|tristate|string))\s*".+"$/$1/;
- };
- if ($line =~ /^\s*default/) {
- my $c;
- $default_set = 1;
- $c = $config{$cur} or $c = 'n';
-
- $line =~ s/^(\s*default\s*)(\w+|"[^"]*")(.*)/$1$c$3/;
- }
- }
-
- print OUTPUT $line;
- }
- close OUTPUT;
- close INPUT;
-
-}
-close FIND;