Skip to content

Latest commit

 

History

History
191 lines (117 loc) · 4.89 KB

Build.md

File metadata and controls

191 lines (117 loc) · 4.89 KB

Building TrenchBroom

Follow these instructions if you want to get started developing on TrenchBroom.

To see how releases of TrenchBroom are packaged, consult our CI scripts instead.

All Platforms

First, clone the TrenchBroom repository. If you are using the official repository and not a fork, you can clone the repository by running

git clone --recursive https://github.com/kduske/TrenchBroom.git

Windows

Visual Studio 2017 or 2019 can be used for development. TrenchBroom needs to compile with VS 2017 (that's what our releases are built with).

Prerequisites

In order to develop, debug and compile TrenchBroom, you need to install tools listed below.

Visual Studio 2017

Download VS 2017 and install it.

You'll also need to install these dependencies using Visual Studio Installer (included with main installer):

  • Workloads
    • Desktop development with C++

Visual Studio 2019

Download VS 2019 and install it.

You'll also need to install these dependencies using Visual Studio Installer (included with main installer):

  • Workloads
    • Desktop development with C++

Project dependencies

  • Download and install Qt for MSVC 2017 32-bit
    • Important: You have to create a personal account
    • Minimum required version is 5.9
  • Download and install latest version of CMake for Windows
  • Download and install latest version of pandoc

Project configuration with cmake

Create a subdirectory in TrenchBroom directory called build.

Visual Studio 2017

Open a command prompt and change directory to build:

cd <path/to/TrenchBroom>/build

Then, execute this command to configure the project:

cmake .. -T v141 -DCMAKE_PREFIX_PATH="C:\Qt\5.13.0\msvc2017"

Note: Make sure to specify the correct Qt as CMAKE_PREFIX_PATH value.

Visual Studio 2019

Open a command prompt and change directory to build:

cd <path/to/TrenchBroom>/build

Then, execute this command to configure the project:

cmake .. -G "Visual Studio 16 2019" -A Win32 -DCMAKE_PREFIX_PATH="C:\Qt\5.13.0\msvc2017"

Note: Make sure to specify the correct Qt as CMAKE_PREFIX_PATH value.

Build and debug TrenchBroom

To build and debug TrenchBroom, press F5 key. After a success compilation process, TrenchBroom should automatically be opened in Debug mode.


Linux

Prerequisites

In order to develop, debug and compile TrenchBroom, you need to install tools listed below.

Project dependencies

TrenchBroom depends on:

  • g++ >= 7
  • Qt >= 5.9
  • FreeImage: libfreeimage-dev
  • OpenGL and GLU development headers (Mesa OpenGL development packages) freeglut3, freeglut3-dev, mesa-common-dev
  • X11 video mode extension library: libxxf86vm-dev

If you have a debian-based distribution, open a command prompt and execute this command to install required dependencies:

sudo apt-get install g++-7 qt5-default freeglut3-dev libglew-dev mesa-common-dev build-essential libglm-dev libxxf86vm-dev libfreeimage-dev libfreetype6-dev pandoc cmake p7zip-full ninja-build

Build TrenchBroom

Create a subdirectory in TrenchBroom directory called build.

Open a command prompt and change directory to build:

cd <path/to/TrenchBroom>/build

Then, execute this command to configure the project:

cmake .. -DCMAKE_BUILD_TYPE=Debug
cmake --build . --target TrenchBroom

Note: You can replace Debug with Release if you want to create a release build.


Mac OS X

Prerequisites

In order to develop, debug and compile TrenchBroom, you need to install tools listed below.

Xcode

Download Xcode from the App Store.

Project dependencies

Open a command prompt and execute this command to install required dependencies:

brew install cmake qt pandoc

Finally, build the project:

mkdir build-xcode
cd build-xcode
cmake .. -GXcode -DCMAKE_PREFIX_PATH="$(brew --prefix qt)"
open TrenchBroom.xcodeproj

Note: Don't enable Address Sanitizer in Xcode; it breaks rebuilding of the project (see #1373).


How to release

Open a new command prompt.

Generate a changelog:

git log --oneline --decorate <LAST_REL_TAG>..HEAD

Note: <LAST_REL_TAG> is replaced by whatever tag marks the last release. The generated log is then manually cleaned up.

Then, tag your changes:

git tag -a v2019.1 -m "This tag marks TrenchBroom 2019.1."

And finally, push the tagged release:

git push origin v2019.1