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.
This commit is contained in:
parent
91f03ba5cf
commit
35d19a9a37
@ -307,7 +307,7 @@ sub GenerateConversionScript
|
||||
|
||||
print "Generating conversion proc script...";
|
||||
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
|
||||
|| die "Could not find CONVERSIONS line in conversions Makefile\n";
|
||||
my @pieces = split /\s+/, $1;
|
||||
@ -341,7 +341,7 @@ sub GenerateTimezoneFiles
|
||||
my $target = shift;
|
||||
my $conf = shift;
|
||||
my $mf = read_file("src/timezone/Makefile");
|
||||
$mf =~ s{\\\s*[\r\n]+}{}mg;
|
||||
$mf =~ s{\\\r?\n}{}g;
|
||||
$mf =~ /^TZDATA\s*:?=\s*(.*)$/m
|
||||
|| die "Could not find TZDATA row in timezone makefile\n";
|
||||
my @tzfiles = split /\s+/, $1;
|
||||
@ -360,7 +360,7 @@ sub GenerateTsearchFiles
|
||||
my $F;
|
||||
my $tmpl = read_file('src/backend/snowball/snowball.sql.in');
|
||||
my $mf = read_file('src/backend/snowball/Makefile');
|
||||
$mf =~ s{\\\s*[\r\n]+}{}mg;
|
||||
$mf =~ s{\\\r?\n}{}g;
|
||||
$mf =~ /^LANGUAGES\s*=\s*(.*)$/m
|
||||
|| die "Could not find LANGUAGES line in snowball Makefile\n";
|
||||
my @pieces = split /\s+/, $1;
|
||||
@ -415,7 +415,7 @@ sub CopyContribFiles
|
||||
next if ($d eq "sepgsql");
|
||||
|
||||
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
|
||||
my $moduledir = 'contrib';
|
||||
@ -587,7 +587,7 @@ qq{xcopy /s /i /q /r /y src\\include\\$d\\*.h "$ctarget\\include\\server\\$d\\"}
|
||||
closedir($D);
|
||||
|
||||
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
|
||||
|| croak "Could not find ecpg_headers line\n";
|
||||
CopyFiles(
|
||||
|
@ -524,7 +524,7 @@ sub mkvcbuild
|
||||
|
||||
$mf =
|
||||
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
|
||||
|| die 'Could not match in conversion makefile' . "\n";
|
||||
foreach my $sub (split /\s+/, $1)
|
||||
@ -536,7 +536,7 @@ sub mkvcbuild
|
||||
}
|
||||
|
||||
$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
|
||||
|| die 'Could not match in bin\scripts\Makefile' . "\n";
|
||||
foreach my $prg (split /\s+/, $1)
|
||||
@ -674,7 +674,7 @@ sub GenerateContribSqlFiles
|
||||
{
|
||||
my $n = shift;
|
||||
my $mf = shift;
|
||||
$mf =~ s{\\\s*[\r\n]+}{}mg;
|
||||
$mf =~ s{\\\r?\n}{}g;
|
||||
if ($mf =~ /^DATA_built\s*=\s*(.*)$/mg)
|
||||
{
|
||||
my $l = $1;
|
||||
|
@ -193,7 +193,7 @@ sub AddDir
|
||||
my $mf = <$MF>;
|
||||
close($MF);
|
||||
|
||||
$mf =~ s{\\\s*[\r\n]+}{}mg;
|
||||
$mf =~ s{\\\r?\n}{}g;
|
||||
if ($mf =~ m{^(?:SUB)?DIRS[^=]*=\s*(.*)$}mg)
|
||||
{
|
||||
foreach my $subdir (split /\s+/, $1)
|
||||
|
@ -422,7 +422,7 @@ EOF
|
||||
}
|
||||
|
||||
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
|
||||
|| croak "Could not find POSTGRES_BKI_SRCS in Makefile\n";
|
||||
my @allbki = split /\s+/, $1;
|
||||
|
@ -358,7 +358,7 @@ sub fetchTests
|
||||
close($handle);
|
||||
my $t = "";
|
||||
|
||||
$m =~ s/\\[\r\n]*//gs;
|
||||
$m =~ s{\\\r?\n}{}g;
|
||||
if ($m =~ /^REGRESS\s*=\s*(.*)$/gm)
|
||||
{
|
||||
$t = $1;
|
||||
|
Loading…
x
Reference in New Issue
Block a user