mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-25 13:17:41 +03:00 
			
		
		
		
	Allow MSVC to build with Tcl 8.6.
Commiteaba54c20cadded support for Tcl 8.6 for configure-supported platforms after verifying that pltcl works without further changes, but the MSVC tooling wasn't updated accordingly. Update MSVC to match, restructuring the code to avoid duplicating the logic for every Tcl version supported. Backpatch to all live branches, likeeaba54c20c. In 9.4 and previous, change the patch to use backslashes rather than forward, as in the rest of the file. Reported by Paresh More, who also tested the patch I provided. Discussion: https://postgr.es/m/CAAgiCNGVw3ssBtSi3ZNstrz5k00ax=UV+_ZEHUeW_LMSGL2sew@mail.gmail.com
This commit is contained in:
		| @@ -249,20 +249,24 @@ sub mkvcbuild | |||||||
|  |  | ||||||
| 	if ($solution->{options}->{tcl}) | 	if ($solution->{options}->{tcl}) | ||||||
| 	{ | 	{ | ||||||
|  | 		my $found = 0; | ||||||
| 		my $pltcl = | 		my $pltcl = | ||||||
| 		  $solution->AddProject('pltcl', 'dll', 'PLs', 'src\pl\tcl'); | 		  $solution->AddProject('pltcl', 'dll', 'PLs', 'src\pl\tcl'); | ||||||
| 		$pltcl->AddIncludeDir($solution->{options}->{tcl} . '\include'); | 		$pltcl->AddIncludeDir($solution->{options}->{tcl} . '\include'); | ||||||
| 		$pltcl->AddReference($postgres); | 		$pltcl->AddReference($postgres); | ||||||
| 		if (-e $solution->{options}->{tcl} . '\lib\tcl85.lib') |  | ||||||
|  | 		for my $tclver (qw(86t 85 84)) | ||||||
| 		{ | 		{ | ||||||
| 			$pltcl->AddLibrary( | 			my $tcllib = $solution->{options}->{tcl} . "\\lib\\tcl$tclver.lib"; | ||||||
| 				$solution->{options}->{tcl} . '\lib\tcl85.lib'); | 			if (-e $tcllib) | ||||||
| 		} | 			{ | ||||||
| 		else | 				$pltcl->AddLibrary($tcllib); | ||||||
| 		{ | 				$found = 1; | ||||||
| 			$pltcl->AddLibrary( | 				last; | ||||||
| 				$solution->{options}->{tcl} . '\lib\tcl84.lib'); | 			} | ||||||
| 		} | 		} | ||||||
|  | 		die "Unable to find $solution->{options}->{tcl}\\lib\\tcl<version>.lib" | ||||||
|  | 			unless $found; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	$libpq = $solution->AddProject('libpq', 'dll', 'interfaces', | 	$libpq = $solution->AddProject('libpq', 'dll', 'interfaces', | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user