2014-02-01 09:21:01 +01:00
|
|
|
#
|
|
|
|
# POCO build script
|
|
|
|
#
|
|
|
|
# Usage:
|
|
|
|
# ------
|
2014-02-01 09:27:31 +01:00
|
|
|
# buildwin.ps1 [-poco_base dir]
|
2015-07-31 12:49:14 +02:00
|
|
|
# [-vs_version 140 | 120 | 110 | 100 | 90]
|
2014-02-01 09:21:01 +01:00
|
|
|
# [-action build | rebuild | clean]
|
|
|
|
# [-linkmode shared | static_mt | static_md | all]
|
|
|
|
# [-config release | debug | both]
|
2014-04-19 19:59:50 +02:00
|
|
|
# [-platform Win32 | x64 | WinCE | WEC2013]
|
2014-02-01 09:21:01 +01:00
|
|
|
# [-samples]
|
|
|
|
# [-tests]
|
|
|
|
# [-omit "Lib1X;LibY;LibZ;..."]
|
2014-02-01 09:27:31 +01:00
|
|
|
# [-tool msbuild | devenv | vcexpress | wdexpress]
|
2014-02-01 09:21:01 +01:00
|
|
|
# [-openssl_base dir]
|
|
|
|
# [-mysql_base dir]
|
|
|
|
|
|
|
|
[CmdletBinding()]
|
|
|
|
Param
|
|
|
|
(
|
|
|
|
[Parameter()]
|
|
|
|
[string] $poco_base,
|
|
|
|
|
|
|
|
[Parameter()]
|
2015-07-31 12:49:14 +02:00
|
|
|
[ValidateSet(90, 100, 110, 120, 140)]
|
2014-02-01 09:21:01 +01:00
|
|
|
[int] $vs_version,
|
|
|
|
|
|
|
|
[Parameter()]
|
|
|
|
[ValidateSet('build', 'rebuild', 'clean')]
|
|
|
|
[string] $action = 'build',
|
|
|
|
|
|
|
|
[Parameter()]
|
|
|
|
[ValidateSet('shared', 'static_mt', 'static_md', 'all')]
|
|
|
|
[string] $linkmode = 'shared',
|
|
|
|
|
|
|
|
[Parameter()]
|
|
|
|
[ValidateSet('release', 'debug', 'both')]
|
|
|
|
[string] $config = 'release',
|
|
|
|
|
|
|
|
[Parameter()]
|
2014-04-19 19:59:50 +02:00
|
|
|
[ValidateSet('Win32', 'x64', 'WinCE', 'WEC2013')]
|
2014-02-01 09:21:01 +01:00
|
|
|
[string] $platform = 'x64',
|
|
|
|
|
|
|
|
[switch] $tests = $false,
|
|
|
|
[switch] $samples = $false,
|
|
|
|
[string] $omit,
|
|
|
|
|
|
|
|
[Parameter()]
|
|
|
|
[ValidateSet('msbuild', 'devenv', 'vcexpress', 'wdexpress')]
|
|
|
|
[string] $tool = 'msbuild',
|
|
|
|
|
|
|
|
[Parameter()]
|
|
|
|
[string] $openssl_base,
|
|
|
|
|
|
|
|
[Parameter()]
|
|
|
|
[string] $mysql_base,
|
|
|
|
|
|
|
|
[switch] $help
|
|
|
|
)
|
|
|
|
|
2014-02-01 09:23:48 +01:00
|
|
|
|
2014-04-25 04:15:54 +02:00
|
|
|
function Add-Env-Var([string] $lib, [string] $var)
|
|
|
|
{
|
|
|
|
if ((${Env:$var} -eq $null) -or (-not ${Env:$var}.Contains(${Env:$lib_$var"})))
|
|
|
|
{
|
2014-04-26 06:22:54 +02:00
|
|
|
$libvar = "$lib" + "_" + "$var"
|
|
|
|
$envvar = [Environment]::GetEnvironmentVariable($libvar, "Process")
|
|
|
|
[Environment]::SetEnvironmentVariable($var, $envvar, "Process")
|
2014-04-25 04:15:54 +02:00
|
|
|
}
|
2014-04-26 06:22:54 +02:00
|
|
|
|
2014-04-25 04:15:54 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2014-02-01 09:21:01 +01:00
|
|
|
function Set-Environment
|
|
|
|
{
|
|
|
|
if ($poco_base -eq '') { $script:poco_base = Get-Location }
|
|
|
|
|
|
|
|
if ($vs_version -eq 0)
|
|
|
|
{
|
2015-07-31 12:49:14 +02:00
|
|
|
if ($Env:VS140COMNTOOLS -ne '') { $script:vs_version = 140 }
|
|
|
|
elseif ($Env:VS120COMNTOOLS -ne '') { $script:vs_version = 120 }
|
2014-02-01 09:21:01 +01:00
|
|
|
elseif ($Env:VS110COMNTOOLS -ne '') { $script:vs_version = 110 }
|
|
|
|
elseif ($Env:VS100COMNTOOLS -ne '') { $script:vs_version = 100 }
|
|
|
|
elseif ($Env:VS90COMNTOOLS -ne '') { $script:vs_version = 90 }
|
|
|
|
else
|
|
|
|
{
|
|
|
|
Write-Host 'Visual Studio not found, exiting.'
|
|
|
|
Exit
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-04-26 06:22:54 +02:00
|
|
|
if (-Not $Env:PATH.Contains("$Env:POCO_BASE\bin64;$Env:POCO_BASE\bin;"))
|
|
|
|
{ $Env:PATH = "$Env:POCO_BASE\bin64;$Env:POCO_BASE\bin;$Env:PATH" }
|
|
|
|
|
2014-04-25 04:15:54 +02:00
|
|
|
if ($openssl_base -eq '')
|
2014-02-01 09:21:01 +01:00
|
|
|
{
|
2014-04-25 04:15:54 +02:00
|
|
|
if ($platform -eq 'x64') { $script:openssl_base = 'C:\OpenSSL-Win64' }
|
|
|
|
else { $script:openssl_base = 'C:\OpenSSL-Win32' }
|
|
|
|
}
|
2014-04-26 06:22:54 +02:00
|
|
|
|
2014-04-25 04:15:54 +02:00
|
|
|
$Env:OPENSSL_DIR = "$openssl_base"
|
|
|
|
$Env:OPENSSL_INCLUDE = "$Env:OPENSSL_DIR\include"
|
|
|
|
$Env:OPENSSL_LIB = "$Env:OPENSSL_DIR\lib;$Env:OPENSSL_DIR\lib\VC"
|
2014-04-26 06:22:54 +02:00
|
|
|
Add-Env-Var "OPENSSL" "INCLUDE"
|
|
|
|
Add-Env-Var "OPENSSL" "LIB"
|
2014-02-01 09:21:01 +01:00
|
|
|
|
2014-04-25 04:15:54 +02:00
|
|
|
if ($mysql_base -ne '')
|
|
|
|
{
|
2014-02-01 09:21:01 +01:00
|
|
|
$Env:MYSQL_DIR = "$mysql_base"
|
|
|
|
$Env:MYSQL_INCLUDE = "$Env:MYSQL_DIR\include"
|
|
|
|
$Env:MYSQL_LIB = "$Env:MYSQL_DIR\lib"
|
2014-05-12 09:41:48 +02:00
|
|
|
Add-Env-Var "MYSQL" "INCLUDE"
|
|
|
|
Add-Env-Var "MYSQL" "LIB"
|
2014-04-25 04:15:54 +02:00
|
|
|
}
|
2014-02-01 09:21:01 +01:00
|
|
|
|
2014-04-25 04:15:54 +02:00
|
|
|
$vsct = "VS$($vs_version)COMNTOOLS"
|
|
|
|
$vsdir = (Get-Item Env:$vsct).Value
|
|
|
|
$Command = ''
|
|
|
|
if ($platform -eq 'x64')
|
|
|
|
{
|
|
|
|
$Command = "$($vsdir)..\..\VC\bin\x86_amd64\vcvarsx86_amd64.bat"
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
$Command = "$($vsdir)vsvars32.bat"
|
|
|
|
}
|
2014-02-01 09:21:01 +01:00
|
|
|
|
2014-04-25 04:15:54 +02:00
|
|
|
$tempFile = [IO.Path]::GetTempFileName()
|
|
|
|
cmd /c " `"$Command`" && set > `"$tempFile`" "
|
|
|
|
Get-Content $tempFile | Foreach-Object {
|
|
|
|
if($_ -match "^(.*?)=(.*)$")
|
|
|
|
{
|
|
|
|
Set-Content "Env:$($matches[1])" $matches[2]
|
|
|
|
}
|
2014-02-01 09:21:01 +01:00
|
|
|
}
|
2014-04-25 04:15:54 +02:00
|
|
|
Remove-Item $tempFile
|
2014-02-01 09:21:01 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function Process-Input
|
|
|
|
{
|
|
|
|
if ($help -eq $true)
|
|
|
|
{
|
|
|
|
Write-Host 'Usage:'
|
|
|
|
Write-Host '------'
|
2014-02-01 09:27:31 +01:00
|
|
|
Write-Host 'buildwin.ps1 [-poco_base dir]'
|
2015-07-31 12:49:14 +02:00
|
|
|
Write-Host ' [-vs_version 140 | 120 | 110 | 100 | 90]'
|
2014-02-01 09:21:01 +01:00
|
|
|
Write-Host ' [-action build | rebuild | clean]'
|
|
|
|
Write-Host ' [-linkmode shared | static_mt | static_md | all]'
|
|
|
|
Write-Host ' [-config release | debug | both]'
|
2014-04-19 19:59:50 +02:00
|
|
|
Write-Host ' [-platform Win32 | x64 | WinCE | WEC2013]'
|
2014-02-01 09:21:01 +01:00
|
|
|
Write-Host ' [-samples]'
|
|
|
|
Write-Host ' [-tests]'
|
|
|
|
Write-Host ' [-omit "Lib1X;LibY;LibZ;..."]'
|
2014-02-01 09:27:31 +01:00
|
|
|
Write-Host ' [-tool msbuild | devenv | vcexpress | wdexpress]'
|
2014-02-01 09:21:01 +01:00
|
|
|
Write-Host ' [-openssl_base dir]'
|
|
|
|
Write-Host ' [-mysql_base dir]'
|
|
|
|
|
|
|
|
Exit
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
Set-Environment
|
|
|
|
|
2014-04-25 04:15:54 +02:00
|
|
|
Write-Host "Build configuration:"
|
|
|
|
Write-Host "--------------------"
|
2014-02-01 09:21:01 +01:00
|
|
|
Write-Host "Poco Base: $poco_base"
|
|
|
|
Write-Host "Version: $vs_version"
|
|
|
|
Write-Host "Action: $action"
|
|
|
|
Write-Host "Link Mode: $linkmode"
|
|
|
|
Write-Host "Configuration: $config"
|
|
|
|
Write-Host "Platform: $platform"
|
|
|
|
Write-Host "Tests: $tests"
|
|
|
|
Write-Host "Samples: $samples"
|
|
|
|
Write-Host "Build Tool: $tool"
|
|
|
|
|
|
|
|
if ($omit -ne '')
|
|
|
|
{
|
|
|
|
Write-Host "Omit: $omit"
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($openssl_base -ne '')
|
|
|
|
{
|
|
|
|
Write-Host "OpenSSL: $openssl_base"
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($mysql_base -ne '')
|
|
|
|
{
|
|
|
|
Write-Host "MySQL: $mysql_base"
|
|
|
|
}
|
|
|
|
|
2014-04-25 04:15:54 +02:00
|
|
|
# NB: this won't work in PowerShell ISE
|
|
|
|
Write-Host "Press Ctrl-C to exit or any other key to continue ..."
|
|
|
|
$x = $host.UI.RawUI.ReadKey("NoEcho,IncludeKeyUp")
|
2014-02-01 09:21:01 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function Build-MSBuild([string] $vsProject)
|
|
|
|
{
|
|
|
|
Write-Host "Build-MSBuild ==> $vsProject"
|
|
|
|
if ($linkmode -eq 'all')
|
|
|
|
{
|
|
|
|
$linkModeArr = 'shared', 'static_mt', 'static_md'
|
|
|
|
|
|
|
|
foreach ($mode in $linkModeArr)
|
|
|
|
{
|
|
|
|
if ($config -eq 'both')
|
|
|
|
{
|
|
|
|
$configArr = 'release', 'debug'
|
|
|
|
foreach ($cfg in $configArr)
|
|
|
|
{
|
|
|
|
$projectConfig = "$cfg"
|
|
|
|
$projectConfig += "_$mode"
|
2014-04-25 04:15:54 +02:00
|
|
|
Invoke-Expression "msbuild $vsProject /t:$action /p:Configuration=$projectConfig /p:Platform=$platform /p:useenv=true"
|
2014-02-01 09:21:01 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else #config
|
|
|
|
{
|
|
|
|
$projectConfig = "$config"
|
|
|
|
$projectConfig += "_$mode"
|
2014-04-25 04:15:54 +02:00
|
|
|
Invoke-Expression "msbuild $vsProject /t:$action /p:Configuration=$projectConfig /p:Platform=$platform /p:useenv=true"
|
2014-02-01 09:21:01 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else #linkmode
|
|
|
|
{
|
|
|
|
if ($config -eq 'both')
|
|
|
|
{
|
|
|
|
$configArr = 'release', 'debug'
|
|
|
|
foreach ($cfg in $configArr)
|
|
|
|
{
|
|
|
|
$projectConfig = "$cfg"
|
2014-06-26 22:44:20 +02:00
|
|
|
$projectConfig += "_$linkmode"
|
2014-04-25 04:15:54 +02:00
|
|
|
Invoke-Expression "msbuild $vsProject /t:$action /p:Configuration=$projectConfig /p:Platform=$platform /p:useenv=true"
|
2014-02-01 09:21:01 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else #config
|
|
|
|
{
|
|
|
|
$projectConfig = "$config"
|
|
|
|
$projectConfig += "_$linkmode"
|
2014-04-25 04:15:54 +02:00
|
|
|
Invoke-Expression "msbuild $vsProject /t:$action /p:Configuration=$projectConfig /p:Platform=$platform /p:useenv=true"
|
2014-02-01 09:21:01 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function Build-Devenv([string] $vsProject)
|
|
|
|
{
|
|
|
|
if ($linkmode -eq 'all')
|
|
|
|
{
|
|
|
|
$linkModeArr = 'shared', 'static_mt', 'static_md'
|
|
|
|
|
|
|
|
foreach ($mode in $linkModeArr)
|
|
|
|
{
|
|
|
|
if ($config -eq 'both')
|
|
|
|
{
|
|
|
|
$configArr = 'release', 'debug'
|
|
|
|
foreach ($cfg in $configArr)
|
|
|
|
{
|
|
|
|
$projectConfig = "$cfg"
|
|
|
|
$projectConfig += "_$mode"
|
|
|
|
Invoke-Expression "devenv /useenv /$action $projectConfig $vsProject"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else #config
|
|
|
|
{
|
|
|
|
$projectConfig = "$config"
|
|
|
|
$projectConfig += "_$mode"
|
|
|
|
Invoke-Expression "devenv /useenv /$action $projectConfig $vsProject"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else #linkmode
|
|
|
|
{
|
|
|
|
if ($config -eq 'both')
|
|
|
|
{
|
|
|
|
$configArr = 'release', 'debug'
|
|
|
|
foreach ($cfg in $configArr)
|
|
|
|
{
|
|
|
|
$projectConfig = "$cfg"
|
2014-06-26 22:44:20 +02:00
|
|
|
$projectConfig += "_$linkmode"
|
2014-02-01 09:21:01 +01:00
|
|
|
Invoke-Expression "devenv /useenv /$action $projectConfig $vsProject"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else #config
|
|
|
|
{
|
|
|
|
$projectConfig = "$config"
|
|
|
|
$projectConfig += "_$linkmode"
|
|
|
|
Invoke-Expression "devenv /useenv /$action $projectConfig $vsProject"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$projectConfig = "$config"
|
|
|
|
$projectConfig += "_$linkmode"
|
|
|
|
Invoke-Expression "devenv /useenv /$action $projectConfig $vsProject"
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function Build-samples
|
|
|
|
{
|
|
|
|
process {
|
|
|
|
$sampleName = $_.BaseName.split("_")[0]
|
|
|
|
$sampleProjName = "$($poco_base)\$($componentDir)\samples\$($sampleName)\$($_)"
|
|
|
|
if ($tool -eq 'devenv') { Build-Devenv $sampleProjName }
|
|
|
|
elseif ($tool -eq 'msbuild') { Build-MSBuild $sampleProjName }
|
|
|
|
else{ Write-Host "Tool not supported: $tool" }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function Build
|
|
|
|
{
|
|
|
|
Process-Input
|
|
|
|
|
|
|
|
if ($vs_version -lt 100) { $extension = 'vcproj' }
|
|
|
|
else { $extension = 'vcxproj' }
|
|
|
|
|
|
|
|
$platformName = ''
|
|
|
|
if ($platform -eq 'x64') { $platformName = '_x64' }
|
|
|
|
elseif ($platform -eq 'WinCE') { $platformName = '_CE' }
|
|
|
|
|
|
|
|
Get-Content "$poco_base\components" | Foreach-Object {
|
|
|
|
|
|
|
|
$component = $_
|
|
|
|
$componentDir = $_.Replace("/", "\")
|
|
|
|
$componentArr = $_.split('/')
|
|
|
|
$componentName = $componentArr[$componentArr.Length - 1]
|
|
|
|
$suffix = "_vs$vs_version"
|
2014-04-19 04:32:30 +02:00
|
|
|
|
|
|
|
$omitArray = @()
|
|
|
|
$omit.Split(',;') | ForEach {
|
|
|
|
$omitArray += "$_"
|
|
|
|
}
|
2014-02-01 09:21:01 +01:00
|
|
|
|
|
|
|
if ($omitArray -NotContains $component)
|
|
|
|
{
|
|
|
|
$vsProject = "$poco_base\$componentDir\$componentName$($platformName)$($suffix).$($extension)"
|
2014-08-22 23:11:43 +02:00
|
|
|
|
|
|
|
if (!(Test-Path -Path $vsProject)) # when VS project name is not same as directory name
|
|
|
|
{
|
|
|
|
$vsProject = "$poco_base\$componentDir$($platformName)$($suffix).$($extension)"
|
|
|
|
if (!(Test-Path -Path $vsProject)) # not found
|
|
|
|
{
|
|
|
|
Write-Host "+------------------------------------------------------------------"
|
|
|
|
Write-Host "| VS project $vsProject not found, skipping."
|
|
|
|
Write-Host "+------------------------------------------------------------------"
|
|
|
|
Return # since Foreach-Object is a function, this is actually loop "continue"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-02-01 09:21:01 +01:00
|
|
|
Write-Host "+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"
|
|
|
|
Write-Host "| Building $vsProject"
|
|
|
|
Write-Host "+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"
|
|
|
|
|
2014-02-01 09:36:14 +01:00
|
|
|
if ($tool -eq 'devenv') { Build-Devenv $vsProject }
|
2014-02-01 09:21:01 +01:00
|
|
|
elseif ($tool -eq 'msbuild') { Build-MSBuild $vsProject }
|
2014-02-01 09:36:14 +01:00
|
|
|
elseif ($tool -ne '') { Write-Host "Build tool not supported: $tool" }
|
|
|
|
else
|
|
|
|
{
|
|
|
|
Write-Host "Build tool not specified. Exiting."
|
|
|
|
Exit
|
|
|
|
}
|
2014-02-01 09:21:01 +01:00
|
|
|
|
|
|
|
if ($tests)
|
|
|
|
{
|
|
|
|
$vsTestProject = "$poco_base\$componentDir\testsuite\TestSuite$($platformName)$($suffix).$($extension)"
|
|
|
|
Write-Host "+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"
|
|
|
|
Write-Host "| Building $vsTestProject"
|
|
|
|
Write-Host "+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++"
|
|
|
|
|
|
|
|
if ($tool -eq 'devenv') { Build-Devenv $vsTestProject }
|
|
|
|
elseif ($tool -eq 'msbuild') { Build-MSBuild $vsTestProject }
|
|
|
|
else{ Write-Host "Tool not supported: $tool" }
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($samples)
|
|
|
|
{
|
|
|
|
Get-Childitem "$poco_base\$($componentDir)" -Recurse |`
|
|
|
|
Where {$_.Extension -Match $extension -And $_.DirectoryName -Like "*samples*" -And $_.BaseName -Like "*$platformName$($suffix)" } `
|
|
|
|
| Build-samples "$_"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
Write-Host "-------------------------------"
|
|
|
|
Write-Host "# Skipping $componentDir"
|
|
|
|
Write-Host "-------------------------------"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Build
|