Commit 35d19a9a authored by Noah Misch's avatar Noah Misch

MSVC: Process Makefile line continuations more like "make" does.

Unlike "make" itself, the MSVC build process recognized a continuation
even with whitespace after the backslash.  (Due to a typo, some code
sites accepted the letter "s" instead of whitespace).  Also, it would
consume any number of newlines following a single backslash.  This is
mere cleanup; those behaviors were unlikely to cause bugs.
parent 91f03ba5
...@@ -307,7 +307,7 @@ sub GenerateConversionScript ...@@ -307,7 +307,7 @@ sub GenerateConversionScript
print "Generating conversion proc script..."; print "Generating conversion proc script...";
my $mf = read_file('src/backend/utils/mb/conversion_procs/Makefile'); my $mf = read_file('src/backend/utils/mb/conversion_procs/Makefile');
$mf =~ s{\\\s*[\r\n]+}{}mg; $mf =~ s{\\\r?\n}{}g;
$mf =~ /^CONVERSIONS\s*=\s*(.*)$/m $mf =~ /^CONVERSIONS\s*=\s*(.*)$/m
|| die "Could not find CONVERSIONS line in conversions Makefile\n"; || die "Could not find CONVERSIONS line in conversions Makefile\n";
my @pieces = split /\s+/, $1; my @pieces = split /\s+/, $1;
...@@ -341,7 +341,7 @@ sub GenerateTimezoneFiles ...@@ -341,7 +341,7 @@ sub GenerateTimezoneFiles
my $target = shift; my $target = shift;
my $conf = shift; my $conf = shift;
my $mf = read_file("src/timezone/Makefile"); my $mf = read_file("src/timezone/Makefile");
$mf =~ s{\\\s*[\r\n]+}{}mg; $mf =~ s{\\\r?\n}{}g;
$mf =~ /^TZDATA\s*:?=\s*(.*)$/m $mf =~ /^TZDATA\s*:?=\s*(.*)$/m
|| die "Could not find TZDATA row in timezone makefile\n"; || die "Could not find TZDATA row in timezone makefile\n";
my @tzfiles = split /\s+/, $1; my @tzfiles = split /\s+/, $1;
...@@ -360,7 +360,7 @@ sub GenerateTsearchFiles ...@@ -360,7 +360,7 @@ sub GenerateTsearchFiles
my $F; my $F;
my $tmpl = read_file('src/backend/snowball/snowball.sql.in'); my $tmpl = read_file('src/backend/snowball/snowball.sql.in');
my $mf = read_file('src/backend/snowball/Makefile'); my $mf = read_file('src/backend/snowball/Makefile');
$mf =~ s{\\\s*[\r\n]+}{}mg; $mf =~ s{\\\r?\n}{}g;
$mf =~ /^LANGUAGES\s*=\s*(.*)$/m $mf =~ /^LANGUAGES\s*=\s*(.*)$/m
|| die "Could not find LANGUAGES line in snowball Makefile\n"; || die "Could not find LANGUAGES line in snowball Makefile\n";
my @pieces = split /\s+/, $1; my @pieces = split /\s+/, $1;
...@@ -415,7 +415,7 @@ sub CopyContribFiles ...@@ -415,7 +415,7 @@ sub CopyContribFiles
next if ($d eq "sepgsql"); next if ($d eq "sepgsql");
my $mf = read_file("contrib/$d/Makefile"); my $mf = read_file("contrib/$d/Makefile");
$mf =~ s{\\s*[\r\n]+}{}mg; $mf =~ s{\\\r?\n}{}g;
# Note: we currently don't support setting MODULEDIR in the makefile # Note: we currently don't support setting MODULEDIR in the makefile
my $moduledir = 'contrib'; my $moduledir = 'contrib';
...@@ -587,7 +587,7 @@ qq{xcopy /s /i /q /r /y src\\include\\$d\\*.h "$ctarget\\include\\server\\$d\\"} ...@@ -587,7 +587,7 @@ qq{xcopy /s /i /q /r /y src\\include\\$d\\*.h "$ctarget\\include\\server\\$d\\"}
closedir($D); closedir($D);
my $mf = read_file('src/interfaces/ecpg/include/Makefile'); my $mf = read_file('src/interfaces/ecpg/include/Makefile');
$mf =~ s{\\s*[\r\n]+}{}mg; $mf =~ s{\\\r?\n}{}g;
$mf =~ /^ecpg_headers\s*=\s*(.*)$/m $mf =~ /^ecpg_headers\s*=\s*(.*)$/m
|| croak "Could not find ecpg_headers line\n"; || croak "Could not find ecpg_headers line\n";
CopyFiles( CopyFiles(
......
...@@ -524,7 +524,7 @@ sub mkvcbuild ...@@ -524,7 +524,7 @@ sub mkvcbuild
$mf = $mf =
Project::read_file('src\backend\utils\mb\conversion_procs\Makefile'); Project::read_file('src\backend\utils\mb\conversion_procs\Makefile');
$mf =~ s{\\s*[\r\n]+}{}mg; $mf =~ s{\\\r?\n}{}g;
$mf =~ m{SUBDIRS\s*=\s*(.*)$}m $mf =~ m{SUBDIRS\s*=\s*(.*)$}m
|| die 'Could not match in conversion makefile' . "\n"; || die 'Could not match in conversion makefile' . "\n";
foreach my $sub (split /\s+/, $1) foreach my $sub (split /\s+/, $1)
...@@ -536,7 +536,7 @@ sub mkvcbuild ...@@ -536,7 +536,7 @@ sub mkvcbuild
} }
$mf = Project::read_file('src\bin\scripts\Makefile'); $mf = Project::read_file('src\bin\scripts\Makefile');
$mf =~ s{\\s*[\r\n]+}{}mg; $mf =~ s{\\\r?\n}{}g;
$mf =~ m{PROGRAMS\s*=\s*(.*)$}m $mf =~ m{PROGRAMS\s*=\s*(.*)$}m
|| die 'Could not match in bin\scripts\Makefile' . "\n"; || die 'Could not match in bin\scripts\Makefile' . "\n";
foreach my $prg (split /\s+/, $1) foreach my $prg (split /\s+/, $1)
...@@ -674,7 +674,7 @@ sub GenerateContribSqlFiles ...@@ -674,7 +674,7 @@ sub GenerateContribSqlFiles
{ {
my $n = shift; my $n = shift;
my $mf = shift; my $mf = shift;
$mf =~ s{\\\s*[\r\n]+}{}mg; $mf =~ s{\\\r?\n}{}g;
if ($mf =~ /^DATA_built\s*=\s*(.*)$/mg) if ($mf =~ /^DATA_built\s*=\s*(.*)$/mg)
{ {
my $l = $1; my $l = $1;
......
...@@ -193,7 +193,7 @@ sub AddDir ...@@ -193,7 +193,7 @@ sub AddDir
my $mf = <$MF>; my $mf = <$MF>;
close($MF); close($MF);
$mf =~ s{\\\s*[\r\n]+}{}mg; $mf =~ s{\\\r?\n}{}g;
if ($mf =~ m{^(?:SUB)?DIRS[^=]*=\s*(.*)$}mg) if ($mf =~ m{^(?:SUB)?DIRS[^=]*=\s*(.*)$}mg)
{ {
foreach my $subdir (split /\s+/, $1) foreach my $subdir (split /\s+/, $1)
......
...@@ -422,7 +422,7 @@ EOF ...@@ -422,7 +422,7 @@ EOF
} }
my $mf = Project::read_file('src\backend\catalog\Makefile'); my $mf = Project::read_file('src\backend\catalog\Makefile');
$mf =~ s{\\s*[\r\n]+}{}mg; $mf =~ s{\\\r?\n}{}g;
$mf =~ /^POSTGRES_BKI_SRCS\s*:?=[^,]+,(.*)\)$/gm $mf =~ /^POSTGRES_BKI_SRCS\s*:?=[^,]+,(.*)\)$/gm
|| croak "Could not find POSTGRES_BKI_SRCS in Makefile\n"; || croak "Could not find POSTGRES_BKI_SRCS in Makefile\n";
my @allbki = split /\s+/, $1; my @allbki = split /\s+/, $1;
......
...@@ -358,7 +358,7 @@ sub fetchTests ...@@ -358,7 +358,7 @@ sub fetchTests
close($handle); close($handle);
my $t = ""; my $t = "";
$m =~ s/\\[\r\n]*//gs; $m =~ s{\\\r?\n}{}g;
if ($m =~ /^REGRESS\s*=\s*(.*)$/gm) if ($m =~ /^REGRESS\s*=\s*(.*)$/gm)
{ {
$t = $1; $t = $1;
......
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