136 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Markdown
		
	
	
			
		
		
	
	
			136 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Markdown
		
	
	
| # Visual Studio Build Tools Container
 | |
| 
 | |
| This project builds a minimal (ish) Docker container for the Visual Studio build tools (MSVC).
 | |
| A second image is constructed for Windows XP Visual Studio build tools (v141_xp).
 | |
| Powershell scripts are included to try and recreate these build environments directly on a Windows 10 workstation.
 | |
| 
 | |
| # Requirements
 | |
| 
 | |
| A Windows 11 10.0.22621.1413+ workstation or VM with minimum 8 GB of memory is required.
 | |
| The more concurrent containers you have running, the more memory and CPU cores are required.
 | |
| 
 | |
| **Each container requires one core and approximately 4 GB of memory.**
 | |
| 
 | |
| 0. Download and install [Docker for Windows](https://download.docker.com/win/stable/Docker%20for%20Windows%20Installer.exe).
 | |
| 
 | |
|     - Select "Switch to Windows Containers" when prompted.
 | |
| 
 | |
| # Build Image
 | |
| 
 | |
| Prior to running a container the Docker image will need to be built.
 | |
| This step is automated but time consuming.
 | |
| It only needs to be built once.
 | |
| 
 | |
| 0. Open powershell and navigate to this project.
 | |
| 
 | |
| 0. Run docker compose with the configuration provided by this project in `docker-compose.yaml`
 | |
| 
 | |
|     ```bash
 | |
|     docker-compose build
 | |
|     ```
 | |
| 
 | |
| This will install both the Windows v142 and Windows XP v141_xp build chains into their respective containers.
 | |
| 
 | |
| Reference these containers later with the names:
 | |
| 
 | |
| - win_build:ltsc2022
 | |
| 
 | |
| - rust_build:ltsc2022
 | |
| 
 | |
| - winxp_build:ltsc2022
 | |
| 
 | |
| # Run Containers
 | |
| 
 | |
| It is recommend that a docker compose file is used to run these containers as paths on Windows can be a bit tricky.
 | |
| Make sure to use forward slashes in paths used within docker compose files.
 | |
| 
 | |
| Below is an example `docker-compose.yaml` file used to build a project configured with cmake.
 | |
| 
 | |
| ```yaml
 | |
| version: '3'
 | |
| 
 | |
| services:
 | |
|   win_build:
 | |
|     image: win_build:ltsc2022
 | |
|     volumes:
 | |
|       - .:C:/source/
 | |
| ```
 | |
| 
 | |
| - `volumes:` are mounted within the Docker container.
 | |
| 
 | |
|     - `C:/source/` is assumed to be the project being build with MSVC.
 | |
| 
 | |
| To build a Windows XP project use the `image: winxp_build:ltsc2022` container image.
 | |
| 
 | |
| # Build Your Windows Project
 | |
| 
 | |
| The above `docker-compose.yaml` file should be stored within your project and will reference the built Docker images by name, not by path.
 | |
| Once this file is created within your project run the following command to begin the build process.
 | |
| 
 | |
| ```bash
 | |
| docker-compose run win_build
 | |
| ```
 | |
| 
 | |
| This will drop you into the visual studio developer shell or console for winxp.
 | |
| 
 | |
| To modify the developer shell environments replace `entrypoint:` in your `docker-compose.yaml` with the desired environment variables or scripted build commands.
 | |
| 
 | |
| ```yaml
 | |
| version: '3'
 | |
| 
 | |
| services:
 | |
|   win_build:
 | |
|     image: win_build:ltsc2022
 | |
|     volumes:
 | |
|       - .:C:/source/
 | |
|     entrypoint: powershell -Command Import-Module C:\\msvc\\Common7\\Tools\\Microsoft.VisualStudio.DevShell.dll; Enter-VsDevShell -VsInstallPath C:\\msvc\\ -DevCmdArguments -arch=amd64
 | |
| ```
 | |
| 
 | |
| # Optional Workstation Scripts
 | |
| 
 | |
| We have done our best to provide powershell scripts that should reproduce these build environments on a Windows 10 workstation.
 | |
| They can be ran but should be evaluated as there is no error checking.
 | |
| 
 | |
| - [win_build_tools_install.ps1](win_build_tools_install.ps1)
 | |
| 
 | |
| - [winxp_build_tools_install.ps1](winxp_build_tools_install.ps1)
 | |
| 
 | |
| # Troubleshooting
 | |
| 
 | |
| ## `error C2471: cannot update program database`
 | |
| 
 | |
| MSBuild has trouble writing files to a mounted directory which occurs even if the out path is set in the project.
 | |
| It is recommended that you include a script in your project that copies the `C:\source` directory into the container prior to running the build commands.
 | |
| 
 | |
| ```powershell
 | |
| Copy-Item C:\source\ -Destination C:\build\ -Recurse -Force
 | |
| MSBuild C:\build\project.sln
 | |
| Copy-Item C:\build\bin -Destination C:\source\ -Recurse -Force
 | |
| Remove-Item -Recurse C:\build\
 | |
| ```
 | |
| 
 | |
| ## `docker-compose build not implimented`
 | |
| 
 | |
| https://docs.docker.com/compose/cli-command/#compose-v2-and-the-new-docker-compose-command
 | |
| 
 | |
| Docker Desktop includes an experimental version of docker-compose which may result in this error.
 | |
| Use the following command to disable.
 | |
| 
 | |
| ```
 | |
| docker-compose disable-v2
 | |
| ```
 | |
| 
 | |
| ## service immediately exits on `docker-compose up`
 | |
| 
 | |
| Reminder to run the container instead:
 | |
| ```
 | |
| docker-compose run win_build
 | |
| ```
 | |
| 
 | |
| ## `a Windows version 10.0.XXXXX-based image is incompatible with a 10.0.XXXXX host`
 | |
| 
 | |
| Microsoft paid a lot of money to check each container version.
 | |
| Two solutions:
 | |
| 
 | |
| 0. Update your workstation to Windows 11 10.0.22621.1413+
 | |
| 0. Replace the string `ltsc2022` with `ltsc2019` across the entire project and rebuild. |