- Microsoft Visual Studio
- Setup default MSVC compiler
- Install Python 3
- Install CMake
- Install Qt
- Install Strawberry Perl
- Install MSYS2
- Setup environment variables
- 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)=
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.
**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)=
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:
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)=
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).
Same as VFX 2023 but download and install the latest Python 3.11 with binaries.
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)=
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)=
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)=
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)=
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)=
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)=
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)=
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.
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
echo "export ACLOCAL_PATH=/c/msys64/usr/share/aclocal" >> ~/.bash_profile
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
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)=
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)=
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)=
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)=
From the Open RV directory:
source rvcmds.sh
(build_windows_openrv4)=
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)=
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)=
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)=
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)=
```{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`.
```