Allow older branches to be built with Visual Studio 2008. This is a backport of commi...
authorAndrew Dunstan <[email protected]>
Tue, 4 Jan 2011 21:06:30 +0000 (16:06 -0500)
committerAndrew Dunstan <[email protected]>
Tue, 4 Jan 2011 21:06:30 +0000 (16:06 -0500)
src/tools/msvc/Project.pm
src/tools/msvc/Solution.pm

index 2e74d81ecd9cede4382a46c2d570c53a475d5970..6875692b57aa43454db577c875bd7465cc92fca0 100644 (file)
@@ -32,7 +32,8 @@ sub new
         defines         => ';',
         solution        => $solution,
         disablewarnings => '4018;4244;4273;4102;4090',
-        disablelinkerwarnings => ''
+        disablelinkerwarnings => '',
+        vcver           => $solution->{vcver}
     };
 
     bless $self;
@@ -459,7 +460,7 @@ sub WriteHeader
 
     print $f <<EOF;
 <?xml version="1.0" encoding="Windows-1252"?>
-<VisualStudioProject ProjectType="Visual C++" Version="8.00" Name="$self->{name}" ProjectGUID="$self->{guid}">
+<VisualStudioProject ProjectType="Visual C++" Version="$self->{vcver}" Name="$self->{name}" ProjectGUID="$self->{guid}">
  <Platforms><Platform Name="Win32"/></Platforms>
  <Configurations>
 EOF
index 232f242d9fa531cc8abf97f64be6eea5f44bfbb0..321035d5eeb79b6e1caa61c203ea4c98d5589c86 100644 (file)
@@ -20,6 +20,7 @@ sub new
         options  => $options,
         numver   => '',
         strver   => '',
+        vcver    => undef,
     };
     bless $self;
        # integer_datetimes is now the default
@@ -51,9 +52,30 @@ sub new
                unless $options->{wal_segsize}; # undef or 0 means default
        die "Bad wal_segsize $options->{wal_segsize}"
                unless grep {$_ == $options->{wal_segsize}} (1,2,4,8,16,32,64);
+
+    $self->DetermineToolVersions();
+
     return $self;
 }
 
+sub DetermineToolVersions
+{
+    my $self = shift;
+
+# Determine version of vcbuild command, to set proper verison of visual studio
+    open(P,"vcbuild /? |") || die "vcbuild command not found";
+    my $line = <P>;
+    close(P);
+    if ($line !~ /^Microsoft \(R\) Visual C\+\+ Project Builder - Command Line Version (\d+)\.00\.\d+/) {
+       die "Unable to determine vcbuild version from first line of output!";
+    }
+    if ($1 == 8) { $self->{vcver} = '8.00' }
+    elsif ($1 == 9) { $self->{vcver} = '9.00' }
+    else { die "Unsupported version of Visual Studio: $1" }
+    print "Detected Visual Studio version $self->{vcver}\n";
+}
+
+
 # Return 1 if $oldfile is newer than $newfile, or if $newfile doesn't exist.
 # Special case - if config.pl has changed, always return 1
 sub IsNewer