ResInsight/scripts/ceesol-sample-clang-build.ps1
2018-02-24 09:15:31 +01:00

232 lines
9.3 KiB
PowerShell

<#
.SYNOPSIS
Compiles or tidies up code from Visual Studio .vcxproj project files.
It sets up the scene required for clang-build.ps1 to do its job, and makes
command-line usage for projects and files quicker.
Before calling sample-clang-build.ps1 you need to set the current directory
to the root source directory.
.PARAMETER aVcxprojToCompile
Alias 'proj'. Array of project(s) to compile. If empty, all projects are compiled.
If the -literal switch is present, name is matched exactly. Otherwise, regex matching is used,
e.g. "msicomp" compiles all msicomp projects.
Can be passed as comma separated values.
.PARAMETER aVcxprojToIgnore
Alias 'proj-ignore'. Array of project(s) to ignore, from the matched ones.
If empty, all already matched projects are compiled.
If the -literal switch is present, name is matched exactly. Otherwise, regex matching is used,
e.g. "msicomp" compiles all msicomp projects.
Can be passed as comma separated values.
.PARAMETER aVcxprojConfigPlatform
Alias 'active-config'. The configuration-platform pair, separated by |,
to be used when processing project files.
E.g. 'Debug|Win32'.
If not specified, the first configuration-plaform found in the current project is used.
.PARAMETER aCppToCompile
Alias 'file'. What cpp(s) to compile from the found project(s). If empty, all CPPs are compiled.
If the -literal switch is present, name is matched exactly. Otherwise, regex matching is used,
e.g. "table" compiles all CPPs containing 'table'.
.PARAMETER aCppToIgnore
Alias 'file-ignore'. Array of file(s) to ignore, from the matched ones.
If empty, all already matched files are compiled.
If the -literal switch is present, name is matched exactly. Otherwise, regex matching is used,
e.g. "table" ignores all CPPs containing 'table'.
Can be passed as comma separated values.
.PARAMETER aContinueOnError
Alias 'continue'. Switch to continue project compilation even when errors occur.
.PARAMETER aClangCompileFlags
Alias 'clang-flags'. Flags given to clang++ when compiling project,
alongside project-specific defines.
.PARAMETER aDisableNameRegexMatching
Alias 'literal'. Switch to take project and cpp name filters literally, not by regex matching.
.PARAMETER aTidyFlags
Alias 'tidy'. If not empty clang-tidy will be called with given flags, instead of clang++.
The tidy operation is applied to whole translation units, meaning all directory headers
included in the CPP will be tidied up too. Changes will not be applied, only simulated.
If aTidyFixFlags is present, it takes precedence over this parameter.
.PARAMETER aTidyFixFlags
Alias 'tidy-fix'. If not empty clang-tidy will be called with given flags, instead of clang++.
The tidy operation is applied to whole translation units, meaning all directory headers
included in the CPP will be tidied up too. Changes will be applied to the file(s).
If present, this parameter takes precedence over aTidyFlags.
.PARAMETER aAfterTidyFixFormatStyle
Alias 'format-style'. Used in combination with 'tidy-fix'. If present, clang-tidy will
also format the fixed file(s), using the specified style.
Possible values: - not present, no formatting will be done
- 'file'
Literally 'file', not a placeholder.
Uses .clang-format file in the closest parent directory.
- 'llvm'
- 'google'
- 'webkit'
- 'mozilla'
.EXAMPLE
PS .\sample-clang-build.ps1 -dir -proj foo,bar -file meow -tidy "-*,modernize-*"
<Description of example>
Runs clang-tidy, using "-*,modernize-*", on all CPPs containing 'meow' in their name from
the projects containing 'foo' or 'bar' in their names.
Doesn't actually apply the clang-tidy module changes to CPPs.
It will only print the tidy module output.
.EXAMPLE
PS .\sample-clang-build.ps1 -dir -proj foo,bar -file meow -tidy-fix "-*,modernize-*"
<Description of example>
Runs clang-tidy, using "-*,modernize-*", on all CPPs containing 'meow' in their name from
the projects containing 'foo' or 'bar' in their names.
It will apply all tidy module changes to CPPs.
.EXAMPLE
PS .\sample-clang-build.ps1 -dir -proj foo -proj-ignore foobar
<Description of example>
Runs clang++ on all CPPs in foo... projects, except foobar
.OUTPUTS
Will output Clang warnings and errors to screen. The return code will be 0 for success, >0 for failure.
.NOTES
Author: Gabriel Diaconita
#>
param( [alias("proj")] [Parameter(Mandatory=$false)][string[]] $aVcxprojToCompile
, [alias("proj-ignore")] [Parameter(Mandatory=$false)][string[]] $aVcxprojToIgnore
, [alias("active-config")][Parameter(Mandatory=$false)][string] $aVcxprojConfigPlatform
, [alias("file")] [Parameter(Mandatory=$false)][string] $aCppToCompile
, [alias("file-ignore")] [Parameter(Mandatory=$false)][string[]] $aCppToIgnore
, [alias("continue")] [Parameter(Mandatory=$false)][switch] $aContinueOnError
, [alias("literal")] [Parameter(Mandatory=$false)][switch] $aDisableNameRegexMatching
, [alias("tidy")] [Parameter(Mandatory=$false)][string] $aTidyFlags
, [alias("tidy-fix")] [Parameter(Mandatory=$false)][string] $aTidyFixFlags
, [alias("format-style")] [Parameter(Mandatory=$false)][string] $aAfterTidyFixFormatStyle
)
# ------------------------------------------------------------------------------------------------
Set-Variable -name kClangCompileFlags -Option Constant `
-value @( "-Wall"
, "-fms-compatibility-version=19.10"
, "-Wmicrosoft"
, "-Wno-invalid-token-paste"
, "-Wno-unknown-pragmas"
, "-Wno-unused-variable"
, "-Wno-unused-value"
, "-Wno-undefined-var-template"
, "-Wno-microsoft-enum-value"
, "-Wno-inconsistent-missing-override"
, "-Wno-extra-tokens"
, "-Wno-c99-extensions"
, "-Wno-logical-op-parentheses"
, "-Wno-invalid-source-encoding"
)
Set-Variable -name kVisualStudioVersion -value "2017" -Option Constant
Set-Variable -name kVisualStudioSku -value "Professional" -Option Constant
Set-Variable -name localVarUseParallelCompile -value $True -Option Constant
Set-Variable -name localVarCppToIgnore -Option Constant `
-value @( "gtest"
, "moc_"
)
# ------------------------------------------------------------------------------------------------
Function Merge-Array([string[]] $aArray)
{
# we need to individually wrap items into quotes as values
# can contain PS control characters (e.g. - in -std=c++14)
$quotedArray = ($aArray | ForEach-Object { """$_"""})
return ($quotedArray -join ",")
}
[string] $scriptDirectory = (Split-Path -parent $PSCommandPath)
[string] $clangScript = "$scriptDirectory\clang-build.ps1"
[string[]] $scriptParams = @("-aSolutionsPath", "'$(Get-Location)'")
if (![string]::IsNullOrEmpty($aVcxprojToCompile))
{
$scriptParams += ("-aVcxprojToCompile", (Merge-Array $aVcxprojToCompile))
}
if (![string]::IsNullOrEmpty($aVcxprojToIgnore))
{
$scriptParams += ("-aVcxprojToIgnore", (Merge-Array $aVcxprojToIgnore))
}
if (![string]::IsNullOrEmpty($aVcxprojConfigPlatform))
{
$scriptParams += ("-aVcxprojConfigPlatform", (Merge-Array $aVcxprojConfigPlatform))
}
if (![string]::IsNullOrEmpty($aCppToCompile))
{
$scriptParams += ("-aCppToCompile", (Merge-Array $aCppToCompile))
}
if (![string]::IsNullOrEmpty($localVarCppToIgnore))
{
$scriptParams += ("-aCppToIgnore", (Merge-Array $localVarCppToIgnore))
}
$scriptParams += ("-aClangCompileFlags", (Merge-Array $kClangCompileFlags))
if (![string]::IsNullOrEmpty($aTidyFlags))
{
$scriptParams += ("-aTidyFlags", (Merge-Array (@($aTidyFlags))))
}
if (![string]::IsNullOrEmpty($aTidyFixFlags))
{
$scriptParams += ("-aTidyFixFlags", (Merge-Array (@($aTidyFixFlags))))
}
if (![string]::IsNullOrEmpty($aAfterTidyFixFormatStyle))
{
$scriptParams += ("-aAfterTidyFixFormatStyle", $aAfterTidyFixFormatStyle)
}
if ($localVarUseParallelCompile)
{
$scriptParams += ("-aUseParallelCompile")
}
if ($aContinueOnError)
{
$scriptParams += ("-aContinueOnError")
}
if ($True)
{
$scriptParams += ("-aTreatAdditionalIncludesAsSystemIncludes")
}
if ($aDisableNameRegexMatching)
{
$scriptParams += ("-aDisableNameRegexMatching")
}
$scriptParams += ("-aVisualStudioVersion", $kVisualStudioVersion)
$scriptParams += ("-aVisualStudioSku", $kVisualStudioSku)
$scriptParams += ("-aTidyHeaderFilter", ".*")
Invoke-Expression "&'$clangScript' $scriptParams"