2018-08-28 05:35:58 +08:00
|
|
|
<Project xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
|
|
|
<Import Project="$(VCTargetsPath)\Microsoft.CppCommon.targets" />
|
|
|
|
|
|
|
|
<PropertyGroup>
|
|
|
|
<!-- Set the path to clang-cl executable based on the value of the project-
|
|
|
|
level setting. This has to be done in the .targets file since values
|
|
|
|
selected via the settings UI appear in the vcxproj (which is imported
|
|
|
|
before the targets file but after the props file) and we need the path
|
|
|
|
that the user may have overridden in the UI. -->
|
Update the Visual Studio Integration from user feedback.
This patch removes the MSBuild warnings about options that
clang-cl ignores. It also adds several additional fields to
the LLVM Configuration options page. The first is that it
adds support for LLD! To give the user flexibility though,
we don't want to force LLD to always-on, and if we're not
forcing LLD then we might as well not force clang-cl either.
So we add options that can enable or disable lld, clang-cl,
or any combination of the two. Whenever one is disabled,
it falls back to the Microsoft equivalent.
Additionally, for each of clang-cl and lld-link, we add a new
configuration setting that allows Additional Options to be
passed for that specific tool only. This is similar to the
C/C++ > Command Line > Additional Options entry box, but
it serves the use case where a user switches back and forth
between the toolsets in their vcxproj, but where cl.exe
won't accept some options that clang-cl will. In this case
you can pass those options in the clang-cl additional options
and whenever clang-cl is disabled (or the other toolset is
selected entirely), those options won't get passed at all.
llvm-svn: 340780
2018-08-28 05:53:36 +08:00
|
|
|
<CLToolExe Condition="$(UseClangCl)">$(ClangClExecutable)</CLToolExe>
|
|
|
|
<LinkToolExe Condition="$(UseLldLink)">$(LldLinkExecutable)</LinkToolExe>
|
2018-08-28 05:35:58 +08:00
|
|
|
</PropertyGroup>
|
|
|
|
|
|
|
|
<ItemGroup>
|
|
|
|
<PropertyPageSchema Include="$(VCTargetsPath)$(LangID)\llvm-general.xml">
|
|
|
|
<Context>Project</Context>
|
|
|
|
</PropertyPageSchema>
|
|
|
|
</ItemGroup>
|
|
|
|
|
Update the Visual Studio Integration from user feedback.
This patch removes the MSBuild warnings about options that
clang-cl ignores. It also adds several additional fields to
the LLVM Configuration options page. The first is that it
adds support for LLD! To give the user flexibility though,
we don't want to force LLD to always-on, and if we're not
forcing LLD then we might as well not force clang-cl either.
So we add options that can enable or disable lld, clang-cl,
or any combination of the two. Whenever one is disabled,
it falls back to the Microsoft equivalent.
Additionally, for each of clang-cl and lld-link, we add a new
configuration setting that allows Additional Options to be
passed for that specific tool only. This is similar to the
C/C++ > Command Line > Additional Options entry box, but
it serves the use case where a user switches back and forth
between the toolsets in their vcxproj, but where cl.exe
won't accept some options that clang-cl will. In this case
you can pass those options in the clang-cl additional options
and whenever clang-cl is disabled (or the other toolset is
selected entirely), those options won't get passed at all.
llvm-svn: 340780
2018-08-28 05:53:36 +08:00
|
|
|
<!-- Take any clang-specific options that the user wants to pass and stick them onto the
|
|
|
|
general purpose list of command line flags. -->
|
|
|
|
<ItemDefinitionGroup Condition="$(UseClangCl)">
|
|
|
|
<ClCompile>
|
|
|
|
<AdditionalOptions>-m$(PlatformArchitecture) $(ClangClAdditionalOptions) %(AdditionalOptions)</AdditionalOptions>
|
|
|
|
</ClCompile>
|
|
|
|
</ItemDefinitionGroup>
|
|
|
|
|
|
|
|
<ItemDefinitionGroup Condition="$(UseLldLink)">
|
|
|
|
<Link>
|
|
|
|
<AdditionalOptions>$(LldLinkAdditionalOptions) %(AdditionalOptions)</AdditionalOptions>
|
|
|
|
</Link>
|
|
|
|
</ItemDefinitionGroup>
|
|
|
|
|
2018-08-28 05:35:58 +08:00
|
|
|
<!-- We hook up a target to run every time ClCompile is about to run, the
|
|
|
|
purpose of which is to sanitize the command line before it gets passed to
|
|
|
|
the compiler. Some options we silently discard, other options we warn on
|
|
|
|
and then discard, and other options we generate a hard error.
|
|
|
|
|
|
|
|
We try to keep hard errors to a minimum and reserve it for cases where
|
|
|
|
the option implies fundamentally different assumptions about the way code
|
|
|
|
should be compiled. This code would probably generate an error anyway,
|
|
|
|
but at least this way we give the user a more useful message about what
|
|
|
|
the actual problem is, rather than relying on some obscure compilation
|
|
|
|
error.
|
|
|
|
|
|
|
|
For any options that clang-cl discards, we would prefer to not even pass
|
|
|
|
them in on the command line. So if a user starts with a cl projects and
|
|
|
|
changes the toolset to clang, they could have set options such as /Gm
|
|
|
|
(minimal rebuild), /sdl (Security Checks), etc. The ClCompile task would
|
|
|
|
then notice this and pass these through to clang-cl.exe. Clang would of
|
|
|
|
course ignore them, but in some cases (such as /Gm), they would generate
|
|
|
|
-Wunused-command-line-argument warnings, so it's better if we can just
|
|
|
|
strip them from the command line entirely. This also has the side
|
|
|
|
benefit of making command lines shorter which is always nice when trying
|
|
|
|
to look at the tool output.
|
|
|
|
-->
|
Update the Visual Studio Integration from user feedback.
This patch removes the MSBuild warnings about options that
clang-cl ignores. It also adds several additional fields to
the LLVM Configuration options page. The first is that it
adds support for LLD! To give the user flexibility though,
we don't want to force LLD to always-on, and if we're not
forcing LLD then we might as well not force clang-cl either.
So we add options that can enable or disable lld, clang-cl,
or any combination of the two. Whenever one is disabled,
it falls back to the Microsoft equivalent.
Additionally, for each of clang-cl and lld-link, we add a new
configuration setting that allows Additional Options to be
passed for that specific tool only. This is similar to the
C/C++ > Command Line > Additional Options entry box, but
it serves the use case where a user switches back and forth
between the toolsets in their vcxproj, but where cl.exe
won't accept some options that clang-cl will. In this case
you can pass those options in the clang-cl additional options
and whenever clang-cl is disabled (or the other toolset is
selected entirely), those options won't get passed at all.
llvm-svn: 340780
2018-08-28 05:53:36 +08:00
|
|
|
<Target Name="BeforeClCompile" BeforeTargets="ClCompile" Condition="$(UseClangCl)">
|
2018-08-28 05:35:58 +08:00
|
|
|
<!-- Error if they're trying to compile this file as managed code. -->
|
|
|
|
<Error Condition="('%(ClCompile.CompileAsManaged)' != 'false') AND ('%(ClCompile.CompileAsManaged)' != '')"
|
|
|
|
File="@(ClCompile)(0,0)"
|
|
|
|
Text="clang-cl does not support compiling managed code (/clr). This file cannot be compiled."/>
|
|
|
|
|
|
|
|
<!-- Error if WinRT is being used. -->
|
|
|
|
<Error Condition="('%(ClCompile.CompileAsWinRT)' == 'true') OR ('%(ClCompile.WinRTNoStdLib)' == 'true')"
|
|
|
|
File="@(ClCompile)(0,0)"
|
|
|
|
Text="clang-cl does not support Windows Runtime Language Extensions (/ZW, /ZW:nostdlib). This file cannot be compiled."/>
|
|
|
|
|
|
|
|
<!-- Error if OpenMP language extensions are enabled. -->
|
|
|
|
<Error Condition="'%(ClCompile.OpenMPSupport)' == 'true'"
|
|
|
|
File="@(ClCompile)(0,0)"
|
|
|
|
Text="clang-cl does not support OpenMP (/openmp). This file cannot be compiled."/>
|
|
|
|
|
|
|
|
<!-- Error if C++ Modules are enabled. Clang has its own notion of modules that are not compatible. -->
|
|
|
|
<Error Condition="'%(ClCompile.EnableModules)' == 'true'"
|
|
|
|
File="@(ClCompile)(0,0)"
|
|
|
|
Text="clang-cl does not support MSVC Modules (/experimental:module). This file cannot be compiled."/>
|
|
|
|
|
|
|
|
<ItemGroup>
|
|
|
|
<ClCompile>
|
|
|
|
<!-- Map /ZI and /Zi to /Z7. Clang internally does this, so if we were
|
|
|
|
to just pass the option through, clang would work. The problem is
|
|
|
|
that MSBuild would not. MSBuild detects /ZI and /Zi and then
|
|
|
|
assumes (rightly) that there will be a compiler-generated PDB (e.g.
|
|
|
|
vc141.pdb). Since clang-cl will not emit this, MSBuild will always
|
|
|
|
think that the compiler-generated PDB needs to be re-generated from
|
|
|
|
scratch and trigger a full build. The way to avoid this is to
|
|
|
|
always give MSBuild accurate information about how we plan to
|
|
|
|
generate debug info (which is to always using /Z7 semantics).
|
|
|
|
-->
|
|
|
|
<DebugInformationFormat Condition="'%(ClCompile.DebugInformationFormat)' == 'ProgramDatabase'">OldStyle</DebugInformationFormat>
|
|
|
|
<DebugInformationFormat Condition="'%(ClCompile.DebugInformationFormat)' == 'EditAndContinue'">OldStyle</DebugInformationFormat>
|
|
|
|
|
|
|
|
<!-- Unset any options that we either silently ignore or warn about due to compatibility.
|
|
|
|
Generally when an option is set to no value, that means "Don't pass an option to the
|
|
|
|
compiler at all."
|
|
|
|
-->
|
|
|
|
<WholeProgramOptimization/>
|
|
|
|
<EnableFiberSafeOptimizations/>
|
|
|
|
<IgnoreStandardIncludePath/>
|
|
|
|
<EnableParallelCodeGeneration/>
|
|
|
|
<ForceConformanceInForLoopScope/>
|
|
|
|
<TreatWChar_tAsBuiltInType/>
|
|
|
|
<SDLCheck/>
|
|
|
|
<GenerateXMLDocumentationFiles/>
|
|
|
|
<BrowseInformation/>
|
|
|
|
<EnablePREfast/>
|
|
|
|
<MinimalRebuild/>
|
|
|
|
<StringPooling/>
|
|
|
|
<ExpandAttributedSource/>
|
|
|
|
<EnforceTypeConversionRules/>
|
|
|
|
<ErrorReporting/>
|
|
|
|
<DisableLanguageExtensions/>
|
|
|
|
<ProgramDataBaseFileName/>
|
|
|
|
<DisableSpecificWarnings/>
|
|
|
|
<TreatSpecificWarningsAsErrors/>
|
|
|
|
<ForcedUsingFiles/>
|
|
|
|
<PREfastLog/>
|
|
|
|
<PREfastAdditionalOptions/>
|
|
|
|
<PREfastAdditionalPlugins/>
|
|
|
|
<MultiProcessorCompilation/>
|
|
|
|
<UseFullPaths/>
|
|
|
|
<RemoveUnreferencedCodeData/>
|
|
|
|
|
|
|
|
<!-- We can't just unset BasicRuntimeChecks, as that will pass /RTCu to the compiler.
|
|
|
|
We have to explicitly set it to 'Default' to avoid passing anything. -->
|
|
|
|
<BasicRuntimeChecks>Default</BasicRuntimeChecks>
|
|
|
|
</ClCompile>
|
|
|
|
</ItemGroup>
|
|
|
|
</Target>
|
|
|
|
|
|
|
|
</Project>
|