Skip to content

Latest commit

 

History

History
488 lines (349 loc) · 15.3 KB

config_windows.md

File metadata and controls

488 lines (349 loc) · 15.3 KB

Building Open RV on Windows

Summary

  1. Microsoft Visual Studio
  2. Setup default MSVC compiler
  3. Install Python 3
    1. Copy python.exe and rename it to python3.exe
  4. Install CMake
  5. Install Qt
  6. Install Strawberry Perl
  7. Install MSYS2
    1. Install required MSYS2 pacman packages (from an MSYS2-MinGW64 shell)
  8. Setup environment variables
  9. Build Open RV
You should be cloning the repository later in the steps, but if you must clone it beforehand, clone it into the root 
of a drive (e.g. ````c:````). See [Get Open RV source code](build_windows_openrv2).

(mvs)=

1. Microsoft Visual Studio

Open RV will not compile with Microsoft Visual Studio 2022 version 17.11.X with the default compiler because of issues 
between PySide2 and that version of the compiler.
\
\
You can still install 17.11.X, but you will need to install MSVC v143 version 14.40 to compile Open RV itself and 
MSVC v143 14.39.X to compile Boost.

Any variant of Microsoft Visual Studio 2022 will work with Open RV (e.g. Enterprise, Professional or Community). You can select the version on the Visual Studio website.

Installation

**Quick guide**:
- You must select **Desktop Development with C++**
- In the individual components section, you must install **MSVC v143 14.40.X** for Open RV and **MSVC v143 14.39.X** to compile Boost.
:show_controls:
:show_indicators:
:show_captions_below:
:show_shadows:
:data-bs-interval: false

```{figure} ../images/windows/msvc/msvc1.png

Step 1 - Select Desktop Development with C++

Select the Desktop Development with C++ component

```

```{figure} ../images/windows/msvc/msvc2.png

Step 1 - Individual components

Click on the Individual components tab, and search for ````msvc````. Select the following components:
MSVC v143 - VS 2022 C++ x64/x86 build tools (v14.39-17.9) and MSVC v143 - VS 2022 C++ x64/x86 build tools (v14.40-17.10).

```

(setup_default_msvc_compiler)=

2. Setup default MSVC compiler

If Microsoft Visual Studio 2022 was installed for the first time (using the steps above), MSVC v143 v14.40 should be the default compiler, although varying setup may affect this.

To ensure compatibility with Open RV, we need to make sure that MSVC v143 v14.40 is the default compiler.

Here are the possible methods to set the default compiler:

Method 1: Check default props file

The first solution is to modify the Microsoft.VCToolsVersion.v143.default.props under C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Auxiliary\Build. The path will vary depending on whether the variant is Enterprise, Profressional or Community.

Make sure that the VCToolsVersion is set to 14.40.33807. The file should look similar to this:

<?xml version = "1.0" encoding="utf-8"?> 
<Project ToolsVersion = "4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003"> 
  <Import Project="$([System.IO.Path]::GetFullPath($(MSBuildThisFileDirectory)Microsoft.VCRedistVersion.v143.default.props))"/> 
  <PropertyGroup> 
    <VCToolsVersion Condition = "'$(VCToolsVersion)' == ''" >14.40.33807</VCToolsVersion> 
  </PropertyGroup>      
</Project>     

If the version is different, change it to 14.40.33807 in the file.

(install_python)=

3. Install Python 3

3.1 VFX Reference Platform 2023

You must install Python 3.10 using the official Python installer. The latest version with an installer is 3.10.11. On the Python 3.10 page, scroll down and download the correct version for your Windows. Typically, the correct version will be Windows installer (64-bit).

3.2 VFX Reference Platform 2023

Same as VFX 2023 but download and install the latest Python 3.11 with binaries.

3.3 Installation

The carousel below shows how to install Python. The images refer to Python 3.11.X, but the only difference is the path. (C:\Python310 instead of C:\Python311)

:show_controls:
:show_indicators:
:show_captions_below:
:show_shadows:
:data-bs-interval: false

```{figure} ../images/windows/python/python1.png

Step 1 - Customize installation

Click on the Customize installation button to customize the installation location.

```

```{figure} ../images/windows/python/python2.png

Step 2 - Advanced Options

It is recommended to choose an installation location with a shorter path length (as shown in the image above).

```

```{figure} ../images/windows/python/python3.png

Step 3 - Setup was successful

Click on Disable path length limit
```

Take note of the installation path for Python 3, as it will be required in a subsequent step.\
The **recommended** path is `C:\Python310` for VFX 2023 and `C:\Python311` for VFX 2024.

(copy_python3)=

3.1 Copy python.exe and rename it to python3.exe

Copy the Python executable as python3.exe to ensure compatibility with Open RV, which requires the python3 command. This also aligns with Linux and macOS conventions, where both python and python3 are valid commands.

(install_cmake)=

4. Install CMake

Minimum **recommended** version for CMake is **3.27.X**.

Download the lastest version of CMake from the official CMake website. Typically, the correct version will be Windows x64 Installer. Follow the installation wizard prompts to complete the setup. There are no special considerations or unique configuration options required.

Take note of the installation path for CMake, as it will be required in a subsequent step.\
The default path is `C:\Program Files\CMake`.

(install_windows_qt)=

5. Install Qt


When obtaining Qt from a third-party source, ensure it includes **OpenSSL** support and check for the following essential modules that may not be included by default: **QtWebEngine**, **QtWebSockets**, **QtMultimedia**, and **QtDeclarative**.
\
\
For example, Qt from MSYS2 is missing QtWebEngine.

Download the latest version of Qt 5.15.x from the official Qt website using the online installer. It is recommended to install Qt in a location with a short path length. (e.g. C:\Qt)

Additionally, ensure you have jom, which is included with Qt Creator, available through the Qt online installer. If you prefer not to install Qt Creator, you can download jom separately from the official Qt repository and copy the executable and supporting files to the Tools/QtCreator/bin/jom directory within your Qt installation.

:show_controls:
:show_indicators:
:show_captions_below:
:show_shadows:
:data-bs-interval: false

```{figure} ../images/windows/qt/qt1.png

Step 1 - After log in

Open the setup, log in with your credentials, and proceed through the prompts until you reach this step.

```

```{figure} ../images/windows/qt/qt2.png

Step 2 - Enable archive packages

Select the 'Archives' checkbox on the right-hand side to enable and display the archive packages.

```

```{figure} ../images/windows/qt/qt3.png

Step 3 - Filter and load archive packages

Click the Filter button to load the archive packages and view available options.

```

```{figure} ../images/windows/qt/qt4.png

Step 4 - Check Qt 5.15.2

Once the archive packages are loaded, scroll down to Qt 5.15.2, select the checkbox, and click the small arrow icon beside it to expand the options.

```

```{figure} ../images/windows/qt/qt5.png

Step 5 - Uncheck optional packages and install Qt 5.15.2

Uncheck all optional packages (as shown in the image above) and click the 'Next' button to proceed.

```
Take note of the installation path for Qt 5.15.2, as it will be required in a subsequent step.\
Based on the recommendation above, the path would be `C:\Qt`.

(install_strawberry_perl)=

6. Install Strawberry Perl

Download and install the 64-bit version of Strawberry Perl

Take note of the installation path for Strawberry Perl, as it will be required in a subsequent step.\
The default path is `C:\Strawberry`.

(install_msys2)=

7. Install MSYS2


The Windows' WSL2 feature conflict with MSYS2. For simplicity, it is highly recommended to **disable** Windows' WSL or WSL2 feature entirely.\
\
Additional information can be found on the [MSYS2 github](https://github.com/msys2/setup-msys2/issues/52).

Download and install the latest MSYS2. Open RV is NOT a mingw64 build. It is a Microscoft Visual Studio 2022 build. Open RV is built with Microsoft Visual Studio 2022 via the CMake "Visual Studio 17 2022" generator.

MSYS2 is only used for convenience as it comes with a package manager with utility packages required for the Open RV build such as cmake, git, flex, bison, nasm, unzip, zip, etc.

(install_msys2_packages)=

7.1 Install required MSYS2 pacman packages

The MSYS2 MingGW64 terminal MUST be used.\
![MSYS2-MinGW64](../images/rv-msys2-mingw64-shortcut.png)

From a MSYS2-MinGW64 shell, install the following packages which are required to build Open RV:

pacman -Sy --needed \
        mingw-w64-x86_64-autotools \
        mingw-w64-x86_64-glew \
        mingw-w64-x86_64-libarchive \
        mingw-w64-x86_64-make \
        mingw-w64-x86_64-meson \
        mingw-w64-x86_64-toolchain \
        autoconf  \
        automake \
        bison \
        flex \
        git \
        libtool \
        nasm \
        p7zip \
        patch \
        unzip \
        zip

While installing the MSYS packages, review the list for any missing package. Some packages might not be installed after the first command.

Note: To confirm which version/location of any tool used inside the MSYS shell, where can be used e.g. where python. If there's more than one path return, the top one will be used.

(setup_env)=

8. Setup environment variables

This is the step where the path of Strawberry Perl, Python, CMake and Qt will be needed.

Some environment variables need to be set within MSYS2 for the Open RV build system. The PATH environment variable must be modified, new environment variables called ACLOCAL_PATH and QT_HOME must be created.

These modifications will be added to the .bash_profile file located in the User's home directory within the MSYS2 environment. By modifiying .bash_profile, these environment variable will be modified everytime a new MSYS2 MINGW64 terminal is opened.

PATH environment variable

Update the CMake, Strawberry Perl and Python location to reflect your installation path, using **forward slashes (/)** for a Unix-style path 
to prevent issues later on.
(e.g., C:\Python310 becomes /c/Python310).

The following paths must be added to the PATH environment variable within MSYS2:

  • CMake binary directory
  • Python binary directory
  • MSYS2's mingw64/bin
  • Strawberry perl directory

The order is important. Do not put Strawberry perl location before MSYS2's mingw64/bin directory.

echo 'export PATH="/c/Program Files/CMake/bin:/c/Python310:/c/msys64/mingw64/bin:$PATH:/c/Strawberry/perl/bin"' >> ~/.bash_profile

ACLOCAL_PATH

echo "export ACLOCAL_PATH=/c/msys64/usr/share/aclocal" >> ~/.bash_profile

QT_HOME

Update the Qt location to reflect your installation path, using forward slashes (/) for a Unix-style path 
(e.g., C:\Qt\5.15.2\mingw_64 becomes /c/Qt/5.15.2/mingw_64).
echo "export QT_HOME=/c/Qt/5.15.2/msvc2019_64" >> ~/.bash_profile

Apply changes to MSYS2 MINGW64

All the environment variables changes above must be applied. You can do that by closing and re-opening the MSYS2 MINGW64 terminal or by running the following command:

source ~/.bash_profile

(build_windows_openrv)=

9. Build Open RV

Even as of Windows 11, for legacy reasons, a default system path length is still limited to 254 bytes long.
For that reason, it is recommended to clone **Open RV** into the drive's root directory (e.g.: `C:\`).

(build_windows_openrv1)=

Before executing any commands

To maximize your chances of successfully building Open RV, you must:

  • Fully update your code base to the latest version (or the version you want to use) with a command like git pull.
  • Fix all conflicts due to updating the code.
  • Revisit all modified files to ensure they aren't using old code that changed during the update such as when the Visual Studio version changes.

(build_windows_openrv2)=

Get Open RV source code

Open RV repository **should** be cloned into the root of a drive (e.g. ````c:````).\
\
Otherwise, the PySide2 compilation could be failing due to the path being too long. If you can't do that, please take a look 
at [Maximum Path Length Limitation](https://learn.microsoft.com/en-us/windows/win32/fileio/maximum-file-path-limitation) on Microsoft website.

Clone the Open RV repository and change directory into the newly created folder. Typically, the command would be:

Using a password-protected SSH key:

git clone --recursive git@github.com:AcademySoftwareFoundation/OpenRV.git
cd OpenRV

Using the web URL:

git clone --recursive https://github.com/AcademySoftwareFoundation/OpenRV.git
cd OpenRV

(build_windows_openrv3)=

Load aliases for Open RV

From the Open RV directory:

source rvcmds.sh

(build_windows_openrv4)=

Install Python dependencies

This section need to be done only one time when a fresh Open RV repository is cloned. 
The first time the `rvsetup` is executed, it will create a Python virtual environment in the current directory under `.venv`.

From the Open RV directory, the following command will download and install the Python dependencies.

rvsetup

(build_windows_openrv5)=

Configure the project

After executing the ````rvcfg```` command, make sure that you see those lines at the begining for the logs:

```
-- The CXX compiler identification is MSVC 19.40.33815.0
-- The C compiler identification is MSVC 19.40.33815.0
```

It **must** use **MSVC 19.40.X** (not 19.41.X).

From the Open RV directory, the following command will configure CMake for the build:

```{code-tab} bash Release
rvcfg
```
```{code-tab} bash Debug
rvcfgd
```

(build_windows_openrv6)=

Build the dependencies

From the Open RV directory, the following command will build the dependencies:

```{code-tab} bash Release
rvbuildt dependencies
```
```{code-tab} bash Debug
rvbuildtd dependencies
```

(build_windows_openrv7)=

Build the main executable

From the Open RV directory, the following command will build the main executable:

```{code-tab} bash Release
rvbuildt main_executable
```
```{code-tab} bash Debug
rvbuildtd main_executable
```

(build_windows_openrv8)=

Opening Open RV executable

```{tab} Release
Once the build is completed, the Open RV application can be found in the Open RV directory under `_build/stage/bin/rv.exe`.
```
```{tab} Debug
Once the build is completed, the Open RV application can be found in the Open RV directory under `_build_debug/stage/bin/rv.exe`.
```