msvc: Use different output directories depending on build type
This allows multiple versions (e.g. Debug/Release, x86/x64) of micropython.exe to co-exist instead and also solves potential problems where msbuild does not completely rebuild the output and/or pdb files when switching between builds, which in turn can cause linker errors in dependent projects. By default exe/map/... files go in windows/build/$(Configuration)$(Platform) After each build micropython.exe is still copied from the above directory to the windows directory though, as that is consistent with the other ports and the test runner by default uses that location as well. Also rename env.props -> path.props which is a clearer name, and add ample documentation in the affected build files. (also see discussion in #1538)
This commit is contained in:
parent
c1481bb0ab
commit
967ceba5b7
|
@ -1,13 +1,13 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||||
<ImportGroup Label="PropertySheets">
|
<ImportGroup Label="PropertySheets">
|
||||||
<Import Project="env.props" />
|
<Import Project="paths.props" Condition="'$(PyPathsIncluded)' != 'True'"/>
|
||||||
</ImportGroup>
|
</ImportGroup>
|
||||||
<PropertyGroup Label="UserMacros" />
|
<PropertyGroup Label="UserMacros" />
|
||||||
<PropertyGroup>
|
<PropertyGroup>
|
||||||
<OutDir>$(PyOutDir)</OutDir>
|
<OutDir>$(PyOutDir)</OutDir>
|
||||||
<IntDir>$(PyBuildDir)$(Configuration)$(Platform)\</IntDir>
|
<IntDir>$(PyIntDir)</IntDir>
|
||||||
<PyIncDirs>$(PyBaseDir);$(PyBaseDir)windows;$(PyBaseDir)windows\msvc;$(PyBuildDir)</PyIncDirs>
|
<PyFileCopyCookie>$(PyBuildDir)copycookie$(Configuration)$(Platform)</PyFileCopyCookie>
|
||||||
</PropertyGroup>
|
</PropertyGroup>
|
||||||
<ItemDefinitionGroup>
|
<ItemDefinitionGroup>
|
||||||
<ClCompile>
|
<ClCompile>
|
||||||
|
@ -22,5 +22,24 @@
|
||||||
<GenerateMapFile>true</GenerateMapFile>
|
<GenerateMapFile>true</GenerateMapFile>
|
||||||
</Link>
|
</Link>
|
||||||
</ItemDefinitionGroup>
|
</ItemDefinitionGroup>
|
||||||
<ItemGroup />
|
<ItemGroup>
|
||||||
|
<PyOutputFiles Include="$(TargetPath)">
|
||||||
|
<Destination>$(PyWinDir)%(FileName)%(Extension)</Destination>
|
||||||
|
</PyOutputFiles>
|
||||||
|
<PyCookieFiles Include="$(PyBuildDir)copycookie*" Exclude="$(PyFileCopyCookie)"/>
|
||||||
|
</ItemGroup>
|
||||||
|
|
||||||
|
<!-- Copy PyOutputFiles to their target destination.
|
||||||
|
To force this when switching between platforms/configurations which are already up-to-date (and as such,
|
||||||
|
for which a build wouldn't even start because all outputs are effectively newer than the inputs)
|
||||||
|
an empty file $(PyFileCopyCookie) is created serving as a record to indicate what was last copied,
|
||||||
|
and any previous records are deleted. So when switching between builds which are otherwise up-to-date
|
||||||
|
the tracker will notice a missing file and a build is started anyway (and it will just copy our files). -->
|
||||||
|
<Target Name="CopyFilesToWinDir" AfterTargets="Build"
|
||||||
|
Inputs="$(TargetPath)" Outputs="$(PyFileCopyCookie);@(PyOutputFiles->'%(Destination)')">
|
||||||
|
<Delete Files="@(PyCookieFiles)"/>
|
||||||
|
<Touch Files="$(PyFileCopyCookie)" AlwaysCreate="true"/>
|
||||||
|
<Copy SourceFiles="%(PyOutputFiles.Identity)" DestinationFiles="%(PyOutputFiles.Destination)"/>
|
||||||
|
<WriteLinesToFile File="$(TLogLocation)$(ProjectName).write.u.tlog" Lines="$(PyFileCopyCookie);@(PyOutputFiles->'%(Destination)')" Overwrite="True"/>
|
||||||
|
</Target>
|
||||||
</Project>
|
</Project>
|
||||||
|
|
|
@ -1,9 +0,0 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
|
||||||
<PropertyGroup>
|
|
||||||
<PyBaseDir>$([System.IO.Path]::GetFullPath(`$(MSBuildThisFileDirectory)..\..`))\</PyBaseDir>
|
|
||||||
<PyBuildDir Condition="'$(PyBuildDir)'==''">$(MSBuildThisFileDirectory)build\</PyBuildDir>
|
|
||||||
<PyOutDir Condition="'$(PyOutDir)'==''">$(PyBaseDir)windows\</PyOutDir>
|
|
||||||
<PyEnvIncluded>True</PyEnvIncluded>
|
|
||||||
</PropertyGroup>
|
|
||||||
</Project>
|
|
|
@ -1,7 +1,7 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003" DefaultTargets="GenerateHeaders">
|
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003" DefaultTargets="GenerateHeaders">
|
||||||
|
|
||||||
<Import Project="env.props" Condition="$(PyEnvIncluded)!=True"/>
|
<Import Project="paths.props" Condition="'$(PyPathsIncluded)' != 'True'"/>
|
||||||
|
|
||||||
<!--Generate qstrdefs.h and mpversion.h similar to what is done in py/py.mk-->
|
<!--Generate qstrdefs.h and mpversion.h similar to what is done in py/py.mk-->
|
||||||
<Target Name="GenerateHeaders" DependsOnTargets="MakeQstrData;MakeVersionHdr">
|
<Target Name="GenerateHeaders" DependsOnTargets="MakeQstrData;MakeVersionHdr">
|
||||||
|
|
|
@ -0,0 +1,45 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||||
|
<PropertyGroup>
|
||||||
|
<PyPathsIncluded>True</PyPathsIncluded>
|
||||||
|
|
||||||
|
<!-- The properties below specify the output directory structure.
|
||||||
|
This defaults to, for example for Configuration = Debug and Platform = x64:
|
||||||
|
|
||||||
|
micropython [PyBaseDir]
|
||||||
|
|- ...
|
||||||
|
|- windows [PyWinDir]
|
||||||
|
|- ...
|
||||||
|
|- micropython.exe
|
||||||
|
|- build [PyBuildDir]
|
||||||
|
|- Debugx64 [PyOutDir]
|
||||||
|
| |- ...
|
||||||
|
| |- micropython.exe
|
||||||
|
| |- micropython.map
|
||||||
|
| |- obj [PyIntDir]
|
||||||
|
|- genhdr
|
||||||
|
|
||||||
|
Note that the micropython executable will be copied from PyOutDir
|
||||||
|
to PyWinDir after each build. -->
|
||||||
|
|
||||||
|
<!-- Start from project root -->
|
||||||
|
<PyBaseDir>$([System.IO.Path]::GetFullPath(`$(MSBuildThisFileDirectory)..\..`))\</PyBaseDir>
|
||||||
|
<PyWinDir>$(PyBaseDir)windows\</PyWinDir>
|
||||||
|
<PyBuildDir Condition="'$(PyBuildDir)' == ''">$(PyWinDir)build\</PyBuildDir>
|
||||||
|
|
||||||
|
<!-- All include directories needed for uPy -->
|
||||||
|
<PyIncDirs>$(PyBaseDir);$(PyWinDir);$(PyBuildDir);$(PyWinDir)msvc</PyIncDirs>
|
||||||
|
|
||||||
|
<!-- Within PyBuildDir different subdirectories are used based on configuration and platform.
|
||||||
|
By default these are chosen based on the Configuration and Platform properties, but
|
||||||
|
this file might be imported by other projects (to figure out where the artifacts go
|
||||||
|
or what the include files are) and those projects might already contain conflicting
|
||||||
|
Configuration/Platform properties, so allow to override these -->
|
||||||
|
<PyPlatform Condition="'$(PyPlatform)' == ''">$(Platform)</PyPlatform>
|
||||||
|
<PyConfiguration Condition="'$(PyConfiguration)' == ''">$(Configuration)</PyConfiguration>
|
||||||
|
|
||||||
|
<!-- The final destination directories -->
|
||||||
|
<PyOutDir>$(PyBuildDir)$(PyConfiguration)$(PyPlatform)\</PyOutDir>
|
||||||
|
<PyIntDir>$(PyOutDir)obj\</PyIntDir>
|
||||||
|
</PropertyGroup>
|
||||||
|
</Project>
|
|
@ -1,6 +1,6 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<Project DefaultTargets="Build" ToolsVersion="12.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
<Project DefaultTargets="Build" ToolsVersion="12.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||||
<Import Project="env.props" Condition="$(PyEnvIncluded)!=True"/>
|
<Import Project="paths.props" Condition="'$(PyPathsIncluded)' != 'True'"/>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ClCompile Include="$(PyBaseDir)py\*.c" />
|
<ClCompile Include="$(PyBaseDir)py\*.c" />
|
||||||
<ClCompile Include="$(PyBaseDir)windows\*.c" />
|
<ClCompile Include="$(PyBaseDir)windows\*.c" />
|
||||||
|
|
Loading…
Reference in New Issue