Skip to content

Latest commit

 

History

History
125 lines (90 loc) · 6.42 KB

BUILD.md

File metadata and controls

125 lines (90 loc) · 6.42 KB

Building Lab Recorder

This file includes quick start recipes. To see general principles, look here.

Windows - CMake - Visual Studio 2017

Starting with Visual Studio 2017, Microsoft began to support much closer integration with CMake. Generally, this uses the Visual Studio GUI as a wrapper around the CMake build files, so you should not expect to see most of the Visual Studio Project configuration options that you are familiar with, and CMake projects cannot be directly blended with non-CMake Visual Studio projects. There are also some weird gotchas, described below.

You will need to download and install:

From Visual Studio:

  • File -> Open -> CMake -> labstreaminglayer/CMakeLists.txt
  • Wait while CMake configures automatically and until CMake menu turns black
  • Select x86-Release
  • CMake menu -> Change CMake Settings -> LabStreamingLayer

Add the "variable" section to the x86-Release group, so that it looks approximately like this:

{
  "name": "x86-Release",
  "generator": "Ninja",
  "configurationType": "RelWithDebInfo",
  "inheritEnvironments": [ "msvc_x86" ],
  "buildRoot": "${env.USERPROFILE}\\CMakeBuilds\\${workspaceHash}\\build\\${name}",
  "installRoot": "${env.USERPROFILE}\\CMakeBuilds\\${workspaceHash}\\install\\${name}",
  "cmakeCommandArgs": "",
  "buildCommandArgs": "-v",
  "ctestCommandArgs": "",
  "variables": [
    {
      "name": "Qt5_DIR",
      "value": "C:\\Qt\\5.11.1\\msvc2015\\lib\\cmake\\Qt5 "
    },
    {
      "name": "BOOST_ROOT",
      "value": "C:\\local\\boost_1_65_1"
    },
    {
      "name": "LSLAPPS_LabRecorder",
      "value": "ON"
    }
  ]
}
  • Also consider changing the build and install roots, as the default path is obscure. When you save this file, CMake should reconfigure, and show the output in the output window (including any CMake configuration errors).

  • Note that it is not a typo that Qt refers to msvc2015 rather than msvc2017.

  • Select Startup Item (green arrow dropdown) -> LabRecorder.exe (Install)

  • Click the green arrow. The application should launch.

Note that if you change Qt versions, or other significant changes, it will be necessary to do a full rebuild before CMake correctly notices the change. CMake -> Clean All is not sufficient to force this.

Just deleting the build folder causes an unfortunate error (build folder not found) on rebuild. To do a full rebuild, it is necessary to change the build and install folder paths in CMake -> Change CMake Settings -> LabStreamingLayer, build, then delete the old folder, change the path back, and build again.

Windows - CMake - Legacy

This procedure also works in Visual Studio 2017, if desired. Generally, I'd recommend sticking with the newer procedure and Visual Studio 2017.

This procedure generates a Visual Studio type project from the CMake files, which can then be opened in Visual Studio.

You will need to download and install:

From the command line, from the labstreaminglayer folder:

  • labstreaminglayer\build>cmake .. -G "Visual Studio 14 2015" -DQt5_DIR="C:/Qt/5.11.1/msvc2015/lib/cmake/Qt5" -DBOOST_ROOT=C:\boost\boost_1_65_1 -DLSLAPPS_LabRecorder=ON

  • labstreaminglayer\build>cmake --build . --config Release --target install

To see a list of possible generators, run the command with garbage in the -G option.

The executable is in labstreaminglayer\build\install\LabRecorder.

You can open the Visual Studio Project with labstreaminglayer\build\LabStreamingLayer.sln.

The command line install feature does not put build products in the sample place as when you build inside of Visual Studio. To get running to work inside of Visual Studio, it is necessary to copy the support files from labstreaminglayer\build\install\LabRecorder to labstreaminglayer\build\Apps\LabRecorder\Release. You must also right click LabRecorder -> Set as Startup Project and select Release and Win32.

If any significant changes are made to the project (such as changing Qt or Visual Stuido version) it is recommended that you delete or rename the build folder and start over. Various partial cleaning processes do not work well.

Linux

* Ubuntu (/Debian)
    * `sudo apt-get install build-essential cmake qt5-default libboost-all-dev`
  1. Open a Command Prompt / Terminal (Windows: MSVC Command Prompt) and change into this directory.
  2. Make a build subdirectory: mkdir build && cd build
  3. Call cmake
    • cmake ..
    • If your liblsl binaries are not in ../../LSL/liblsl/build/install, add the path (cmake -DLSL_INSTALL_ROOT=/path/to/liblsl/binaries ..)
    • Optional: Use a generator
  4. You may need to specify additional cmake options. . Build everything and copy the files to the install folder:
    • cmake --build . --target install

OS X

* Use [homebrew](https://brew.sh/)
    * `brew install cmake qt boost`
  1. Open a Command Prompt / Terminal (Windows: MSVC Command Prompt) and change into this directory.
  2. Make a build subdirectory: mkdir build && cd build
  3. Call cmake
    • cmake ..
    • If your liblsl binaries are not in ../../LSL/liblsl/build/install, add the path (cmake -DLSL_INSTALL_ROOT=/path/to/liblsl/binaries ..)
    • Optional: Use a generator
  4. You may need to specify additional cmake options. . Build everything and copy the files to the install folder:
    • cmake --build . --target install