Commit d060d963 authored by Steven Rostedt's avatar Steven Rostedt Committed by Steven Rostedt

kconfig/streamline-config.pl: Simplify backslash line concatination

Simplify the way lines ending with backslashes (continuation) in Makefiles
is parsed. This is needed to implement a necessary fix.
Tested-by: default avatarThomas Lange <thomas-lange2@gmx.de>
Cc: stable@vger.kernel.org
Signed-off-by: default avatarSteven Rostedt <rostedt@goodmis.org>
parent 805a6af8
...@@ -253,17 +253,22 @@ if ($kconfig) { ...@@ -253,17 +253,22 @@ if ($kconfig) {
# Read all Makefiles to map the configs to the objects # Read all Makefiles to map the configs to the objects
foreach my $makefile (@makefiles) { foreach my $makefile (@makefiles) {
my $cont = 0; my $line = "";
open(MIN,$makefile) || die "Can't open $makefile"; open(MIN,$makefile) || die "Can't open $makefile";
while (<MIN>) { while (<MIN>) {
my $objs; # if this line ends with a backslash, continue
chomp;
# is this a line after a line with a backslash? if (/^(.*)\\$/) {
if ($cont && /(\S.*)$/) { $line .= $1;
$objs = $1; next;
} }
$cont = 0;
$line .= $_;
$_ = $line;
$line = "";
my $objs;
# collect objects after obj-$(CONFIG_FOO_BAR) # collect objects after obj-$(CONFIG_FOO_BAR)
if (/obj-\$\((CONFIG_[^\)]*)\)\s*[+:]?=\s*(.*)/) { if (/obj-\$\((CONFIG_[^\)]*)\)\s*[+:]?=\s*(.*)/) {
...@@ -271,12 +276,6 @@ foreach my $makefile (@makefiles) { ...@@ -271,12 +276,6 @@ foreach my $makefile (@makefiles) {
$objs = $2; $objs = $2;
} }
if (defined($objs)) { if (defined($objs)) {
# test if the line ends with a backslash
if ($objs =~ m,(.*)\\$,) {
$objs = $1;
$cont = 1;
}
foreach my $obj (split /\s+/,$objs) { foreach my $obj (split /\s+/,$objs) {
$obj =~ s/-/_/g; $obj =~ s/-/_/g;
if ($obj =~ /(.*)\.o$/) { if ($obj =~ /(.*)\.o$/) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment