Several fixes for MSVC build scripts, from Magnus.
This commit is contained in:
parent
aab964b311
commit
83078e9912
|
@ -81,7 +81,7 @@ sub AddReference {
|
|||
|
||||
while (my $ref = shift) {
|
||||
push @{$self->{references}},$ref;
|
||||
$self->AddLibrary("debug\\" . $ref->{name} . "\\" . $ref->{name} . ".lib") if ($ref->{type} eq "exe");
|
||||
$self->AddLibrary("__CFGNAME__\\" . $ref->{name} . "\\" . $ref->{name} . ".lib");
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -113,8 +113,8 @@ sub FullExportDLL {
|
|||
my ($self, $libname) = @_;
|
||||
|
||||
$self->{builddef} = 1;
|
||||
$self->{def} = ".\\debug\\$self->{name}\\$self->{name}.def";
|
||||
$self->{implib} = "debug\\$self->{name}\\$libname";
|
||||
$self->{def} = ".\\__CFGNAME__\\$self->{name}\\$self->{name}.def";
|
||||
$self->{implib} = "__CFGNAME__\\$self->{name}\\$libname";
|
||||
}
|
||||
|
||||
sub UseDef {
|
||||
|
@ -286,19 +286,19 @@ EOF
|
|||
my $of = $f;
|
||||
$of =~ s/\.y$/.c/;
|
||||
$of =~ s{^src\\pl\\plpgsql\\src\\gram.c$}{src\\pl\\plpgsql\\src\\pl_gram.c};
|
||||
print F '><FileConfiguration Name="Debug|Win32"><Tool Name="VCCustomBuildTool" Description="Running bison on ' . $f . '" CommandLine="vcbuild\pgbison.bat ' . $f . '" AdditionalDependencies="" Outputs="' . $of . '" /></FileConfiguration></File>' . "\n";
|
||||
print F '>' . GenerateCustomTool('Running bison on ' . $f, 'src\tools\msvc\pgbison.bat ' . $f, $of) . '</File>' . "\n";
|
||||
}
|
||||
elsif ($f =~ /\.l$/) {
|
||||
my $of = $f;
|
||||
$of =~ s/\.l$/.c/;
|
||||
$of =~ s{^src\\pl\\plpgsql\\src\\scan.c$}{src\\pl\\plpgsql\\src\\pl_scan.c};
|
||||
print F "><FileConfiguration Name=\"Debug|Win32\"><Tool Name=\"VCCustomBuildTool\" Description=\"Running flex on $f\" CommandLine=\"vcbuild\\pgflex.bat $f\" AdditionalDependencies=\"\" Outputs=\"$of\" /></FileConfiguration></File>\n";
|
||||
print F '>' . GenerateCustomTool('Running flex on ' . $f, 'src\tools\msvc\pgflex.bat ' . $f,$of) . '</File>' . "\n";
|
||||
}
|
||||
elsif (defined($uniquefiles{$file})) {
|
||||
# File already exists, so fake a new name
|
||||
my $obj = $dir;
|
||||
$obj =~ s/\\/_/g;
|
||||
print F "><FileConfiguration Name=\"Debug|Win32\"><Tool Name=\"VCCLCompilerTool\" ObjectFile=\".\\debug\\$self->{name}\\$obj" . "_$file.obj\" /></FileConfiguration></File>\n";
|
||||
print F "><FileConfiguration Name=\"Debug|Win32\"><Tool Name=\"VCCLCompilerTool\" ObjectFile=\".\\debug\\$self->{name}\\$obj" . "_$file.obj\" /></FileConfiguration><FileConfiguration Name=\"Release|Win32\"><Tool Name=\"VCCLCompilerTool\" ObjectFile=\".\\release\\$self->{name}\\$obj" . "_$file.obj\" /></FileConfiguration></File>\n";
|
||||
}
|
||||
else {
|
||||
$uniquefiles{$file} = 1;
|
||||
|
@ -313,6 +313,15 @@ EOF
|
|||
close(F);
|
||||
}
|
||||
|
||||
sub GenerateCustomTool {
|
||||
my ($desc, $tool, $output, $cfg) = @_;
|
||||
if (!defined($cfg)) {
|
||||
return GenerateCustomTool($desc, $tool, $output, 'Debug') .
|
||||
GenerateCustomTool($desc, $tool, $output, 'Release');
|
||||
}
|
||||
return "<FileConfiguration Name=\"$cfg|Win32\"><Tool Name=\"VCCustomBuildTool\" Description=\"$desc\" CommandLine=\"$tool\" AdditionalDependencies=\"\" Outputs=\"$output\" /></FileConfiguration>";
|
||||
}
|
||||
|
||||
sub WriteReferences {
|
||||
my ($self, $f) = @_;
|
||||
print $f " <References>\n";
|
||||
|
@ -325,48 +334,65 @@ sub WriteReferences {
|
|||
sub WriteHeader {
|
||||
my ($self, $f) = @_;
|
||||
|
||||
my $cfgtype = ($self->{type} eq "exe")?1:($self->{type} eq "dll"?2:4);
|
||||
|
||||
print $f <<EOF;
|
||||
<?xml version="1.0" encoding="Windows-1252"?>
|
||||
<VisualStudioProject ProjectType="Visual C++" Version="8.00" Name="$self->{name}" ProjectGUID="$self->{guid}">
|
||||
<Platforms><Platform Name="Win32"/></Platforms>
|
||||
<Configurations>
|
||||
<Configuration Name="Debug|Win32" OutputDirectory=".\\Debug\\$self->{name}" IntermediateDirectory=".\\Debug\\$self->{name}"
|
||||
ConfigurationType="$cfgtype" UseOfMFC="0" ATLMinimizesCRunTimeLibraryUsage="FALSE" CharacterSet="2">
|
||||
<Tool Name="VCCLCompilerTool" Optimization="0"
|
||||
EOF
|
||||
$self->WriteConfiguration($f, 'Debug', { defs=>'_DEBUG;DEBUG=1;', wholeopt=>0 , opt=>0, strpool=>'false', runtime=>3 });
|
||||
$self->WriteConfiguration($f, 'Release', { defs=>'', wholeopt=>0, opt=>3, strpool=>'true', runtime=>2 });
|
||||
print $f <<EOF;
|
||||
</Configurations>
|
||||
EOF
|
||||
}
|
||||
|
||||
sub WriteConfiguration
|
||||
{
|
||||
my ($self, $f, $cfgname, $p) = @_;
|
||||
my $cfgtype = ($self->{type} eq "exe")?1:($self->{type} eq "dll"?2:4);
|
||||
my $libs = $self->{libraries};
|
||||
$libs =~ s/__CFGNAME__/$cfgname/g;
|
||||
print $f <<EOF;
|
||||
<Configuration Name="$cfgname|Win32" OutputDirectory=".\\$cfgname\\$self->{name}" IntermediateDirectory=".\\$cfgname\\$self->{name}"
|
||||
ConfigurationType="$cfgtype" UseOfMFC="0" ATLMinimizesCRunTimeLibraryUsage="FALSE" CharacterSet="2" WholeProgramOptimization="$p->{wholeopt}">
|
||||
<Tool Name="VCCLCompilerTool" Optimization="$p->{opt}"
|
||||
AdditionalIncludeDirectories="src/include;src/include/port/win32;src/include/port/win32_msvc;$self->{solution}->{options}->{pthread};$self->{includes}"
|
||||
PreprocessorDefinitions="WIN32;_DEBUG;_WINDOWS;__WINDOWS__;DEBUG=1;__WIN32__;EXEC_BACKEND;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE$self->{defines}"
|
||||
RuntimeLibrary="3" DisableSpecificWarnings="$self->{disablewarnings}"
|
||||
PreprocessorDefinitions="WIN32;_WINDOWS;__WINDOWS__;__WIN32__;EXEC_BACKEND;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE$self->{defines}$p->{defs}"
|
||||
StringPooling="$p->{strpool}"
|
||||
RuntimeLibrary="$p->{runtime}" DisableSpecificWarnings="$self->{disablewarnings}"
|
||||
EOF
|
||||
print $f <<EOF;
|
||||
AssemblerOutput="0" AssemblerListingLocation=".\\debug\\$self->{name}\\" ObjectFile=".\\debug\\$self->{name}\\"
|
||||
ProgramDataBaseFileName=".\\debug\\$self->{name}\\" BrowseInformation="0"
|
||||
AssemblerOutput="0" AssemblerListingLocation=".\\$cfgname\\$self->{name}\\" ObjectFile=".\\$cfgname\\$self->{name}\\"
|
||||
ProgramDataBaseFileName=".\\$cfgname\\$self->{name}\\" BrowseInformation="0"
|
||||
WarningLevel="3" SuppressStartupBanner="TRUE" DebugInformationFormat="3" CompileAs="0"/>
|
||||
<Tool Name="VCLinkerTool" OutputFile=".\\debug\\$self->{name}\\$self->{name}.$self->{type}"
|
||||
AdditionalDependencies="$self->{libraries}"
|
||||
<Tool Name="VCLinkerTool" OutputFile=".\\$cfgname\\$self->{name}\\$self->{name}.$self->{type}"
|
||||
AdditionalDependencies="$libs"
|
||||
LinkIncremental="0" SuppressStartupBanner="TRUE" AdditionalLibraryDirectories="" IgnoreDefaultLibraryNames="libc"
|
||||
StackReserveSize="4194304" DisableSpecificWarnings="$self->{disablewarnings}"
|
||||
GenerateDebugInformation="TRUE" ProgramDatabaseFile=".\\debug\\$self->{name}\\$self->{name}.pdb"
|
||||
GenerateMapFile="FALSE" MapFileName=".\\debug\\$self->{name}\\$self->{name}.map"
|
||||
GenerateDebugInformation="TRUE" ProgramDatabaseFile=".\\$cfgname\\$self->{name}\\$self->{name}.pdb"
|
||||
GenerateMapFile="FALSE" MapFileName=".\\$cfgname\\$self->{name}\\$self->{name}.map"
|
||||
SubSystem="1" TargetMachine="1"
|
||||
EOF
|
||||
if ($self->{implib}) {
|
||||
print $f "\t\tImportLibrary=\"$self->{implib}\"\n";
|
||||
my $l = $self->{implib};
|
||||
$l =~ s/__CFGNAME__/$cfgname/g;
|
||||
print $f "\t\tImportLibrary=\"$l\"\n";
|
||||
}
|
||||
if ($self->{def}) {
|
||||
print $f "\t\tModuleDefinitionFile=\"$self->{def}\"\n";
|
||||
my $d = $self->{def};
|
||||
$d =~ s/__CFGNAME__/$cfgname/g;
|
||||
print $f "\t\tModuleDefinitionFile=\"$d\"\n";
|
||||
}
|
||||
|
||||
print $f "\t/>\n";
|
||||
print $f "\t<Tool Name=\"VCLibrarianTool\" OutputFile=\".\\Debug\\$self->{name}\\$self->{name}.lib\" IgnoreDefaultLibraryNames=\"libc\" />\n";
|
||||
print $f "\t<Tool Name=\"VCLibrarianTool\" OutputFile=\".\\$cfgname\\$self->{name}\\$self->{name}.lib\" IgnoreDefaultLibraryNames=\"libc\" />\n";
|
||||
print $f "\t<Tool Name=\"VCResourceCompilerTool\" AdditionalIncludeDirectories=\"src\\include\" />\n";
|
||||
if ($self->{builddef}) {
|
||||
print $f "\t<Tool Name=\"VCPreLinkEventTool\" Description=\"Generate DEF file\" CommandLine=\"perl vcbuild\\gendef.pl debug\\$self->{name}\" />\n";
|
||||
print $f "\t<Tool Name=\"VCPreLinkEventTool\" Description=\"Generate DEF file\" CommandLine=\"perl src\\tools\\msvc\\gendef.pl $cfgname\\$self->{name}\" />\n";
|
||||
}
|
||||
print $f <<EOF;
|
||||
</Configuration>
|
||||
</Configurations>
|
||||
EOF
|
||||
}
|
||||
|
||||
|
|
|
@ -21,8 +21,8 @@ sub new {
|
|||
# Special case - if config.pl has changed, always return 1
|
||||
sub IsNewer {
|
||||
my ($newfile, $oldfile) = @_;
|
||||
if ($oldfile ne 'vcbuild\config.pl') {
|
||||
return 1 if IsNewer($newfile, 'vcbuild\config.pl');
|
||||
if ($oldfile ne 'src\tools\msvc\config.pl') {
|
||||
return 1 if IsNewer($newfile, 'src\tools\msvc\config.pl');
|
||||
}
|
||||
return 1 if (!(-e $newfile));
|
||||
my @nstat = stat($newfile);
|
||||
|
@ -177,6 +177,17 @@ sub GenerateFiles {
|
|||
chdir('..\..\..');
|
||||
}
|
||||
|
||||
if (IsNewer('src\interfaces\ecpg\include\ecpg_config.h', 'src\interfaces\ecpg\include\ecpg_config.h.in')) {
|
||||
print "Generating ecpg_config.h...\n";
|
||||
open(O,'>','src\interfaces\ecpg\include\ecpg_config.h') || confess "Could not open ecpg_config.h";
|
||||
print O <<EOF;
|
||||
#if (_MSC_VER > 1200)
|
||||
#define HAVE_LONG_LONG_INT_64
|
||||
#endif
|
||||
EOF
|
||||
close(O);
|
||||
}
|
||||
|
||||
unless (-f "src\\port\\pg_config_paths.h") {
|
||||
print "Generating pg_config_paths.h...\n";
|
||||
open(O,'>', 'src\port\pg_config_paths.h') || confess "Could not open pg_config_paths.h";
|
||||
|
@ -271,6 +282,7 @@ EOF
|
|||
print SLN <<EOF;
|
||||
$proj->{guid}.Debug|Win32.ActiveCfg = Debug|Win32
|
||||
$proj->{guid}.Debug|Win32.Build.0 = Debug|Win32
|
||||
$proj->{guid}.Release|Win32.ActiveCfg = Release|Win32
|
||||
$proj->{guid}.Release|Win32.Build.0 = Release|Win32
|
||||
EOF
|
||||
}
|
||||
|
|
|
@ -1,12 +1,18 @@
|
|||
@echo off
|
||||
SET STARTDIR=%CD%
|
||||
|
||||
perl mkvcbuild.pl
|
||||
if errorlevel 1 goto :eof
|
||||
|
||||
if exist ..\vcbuild if exist ..\src cd ..
|
||||
|
||||
if "%1" == "" msbuild pgsql.sln
|
||||
if not "%1" == "" vcbuild %1.vcproj
|
||||
|
||||
cd %STARTDIR%
|
||||
@echo off
|
||||
SET STARTDIR=%CD%
|
||||
|
||||
perl mkvcbuild.pl
|
||||
if errorlevel 1 goto :eof
|
||||
|
||||
if exist ..\msvc if exist ..\..\..\src cd ..\..\..
|
||||
SET CONFIG=
|
||||
if "%1" == "" set CONFIG=Debug
|
||||
if "%CONFIG%" == "" if "%1" == "DEBUG" set CONFIG=Debug
|
||||
if "%CONFIG%" == "" if "%1" == "RELEASE" set CONFIG=Release
|
||||
if not "%CONFIG%" == "" shift
|
||||
if "%CONFIG%" == "" set CONFIG=Debug
|
||||
|
||||
if "%1" == "" msbuild pgsql.sln /p:Configuration=%CONFIG%
|
||||
if not "%1" == "" vcbuild %1.vcproj %CONFIG%
|
||||
|
||||
cd %STARTDIR%
|
||||
|
|
|
@ -5,12 +5,12 @@ use warnings;
|
|||
use Project;
|
||||
use Solution;
|
||||
|
||||
chdir('..') if (-d '..\vcbuild' && -d '..\src');
|
||||
die 'Must run from root directory or vcbuild directory' unless (-d 'vcbuild' && -d 'src');
|
||||
die 'Could not find config.pl' unless (-f 'vcbuild/config.pl');
|
||||
chdir('..\..\..') if (-d '..\msvc' && -d '..\..\..\src');
|
||||
die 'Must run from root or msvc directory' unless (-d 'src\tools\msvc' && -d 'src');
|
||||
die 'Could not find config.pl' unless (-f 'src/tools/msvc/config.pl');
|
||||
|
||||
our $config;
|
||||
require 'vcbuild/config.pl';
|
||||
require 'src/tools/msvc/config.pl';
|
||||
|
||||
my $solution = new Solution($config);
|
||||
|
||||
|
@ -79,6 +79,7 @@ my $libpq = $solution->AddProject('libpq','dll','interfaces','src\interfaces\lib
|
|||
$libpq->AddDefine('FRONTEND');
|
||||
$libpq->AddIncludeDir('src\port');
|
||||
$libpq->AddLibrary('wsock32.lib');
|
||||
$libpq->AddLibrary('wldap32.lib') if ($solution->{options}->{ldap});
|
||||
$libpq->UseDef('src\interfaces\libpq\libpqdll.def');
|
||||
$libpq->ReplaceFile('src\interfaces\libpq\libpqrc.c','src\interfaces\libpq\libpq.rc');
|
||||
|
||||
|
@ -188,8 +189,6 @@ foreach my $prg (split /\s+/,$1) {
|
|||
$proj->AddIncludeDir('src\bin\psql');
|
||||
$proj->AddReference($libpq,$libpgport);
|
||||
$proj->AddResourceFile('src\bin\scripts','PostgreSQL Utility');
|
||||
$proj->AddLibrary('debug\libpgport\libpgport.lib');
|
||||
$proj->AddLibrary('debug\libpq\libpq.lib');
|
||||
}
|
||||
$/ = $t;
|
||||
|
||||
|
@ -224,11 +223,9 @@ sub AddSimpleFrontend {
|
|||
$p->AddDir('src\bin\\' . $n);
|
||||
$p->AddDefine('FRONTEND');
|
||||
$p->AddReference($libpgport);
|
||||
$p->AddLibrary('debug\libpgport\libpgport.lib');
|
||||
if ($uselibpq) {
|
||||
$p->AddIncludeDir('src\interfaces\libpq');
|
||||
$p->AddReference($libpq);
|
||||
$p->AddLibrary('debug\libpq\libpq.lib');
|
||||
}
|
||||
return $p;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue