- We use pandoc to generate the documentation. Install a binary distribution from the website and make sure that it is in your
PATH
, otherwise your builds will fail.
- Generally, the cmake scripts don't handle paths with spaces very well, so make sure that you check out the TrenchBroom source repository somewhere on a path without any spaces.
- For Visual Studio:
-
VS2017 is required. The community edition works fine.
-
In the Visual Studio Installer, you'll need to install:
- Workloads
- Desktop development with C++
- Individual components
- VC++ 2017 version 15.9 v14.16 latest v141 tools
- Windows Universal CRT SDK
- Windows XP support for C++
- Workloads
-
Download the following wxWidgets binary packages:
-
Unpack the 4 wxWidgets archives into a
wxWidgets-<version>
directory next to yourTrenchBroom
directory -
The directory layout should look like this:
TrenchBroom \app \benchmark <other subdirectories and files> wxWidgets-3.1.1 \include \msvc \wx \wx <wxwidgets header files> \lib \vc141_dll <wxwidgets libraries>
-
Download and install CMake for Windows
-
Open a command prompt and change into the directory where you unpacked the TrenchBroom sources.
-
Create a new directory, e.g. "build", and change into it.
-
Run the following two commands
cmake .. -T v141_xp -DCMAKE_BUILD_TYPE=Release -DwxWidgets_ROOT_DIR=%cd%/../../wxWidgets-3.1.1 cmake --build . --config Release --target TrenchBroom
The
-T
option selects the "platform toolset" for the Visual Studio generator, which determines which C++ compiler and runtime the project will use.v141_xp
is the Visual Studio 2017 runtime, with compatibility down to Windows XP. TrenchBroom releases and CI builds usev141_xp
; earlier versions won't be able to compile TrenchBroom.You can replace "Release" with "Debug" if you want to create a debug build. This is also recommended if you want to work on the source in Visual Studio.
-
Note: due to current limitations of the TrenchBroom build system, you must specify CMAKE_BUILD_TYPE when invoking cmake, and can't change between Release and Debug from Visual Studio
-
Compiling wxWidgets 3 requires the following dependencies. You should install them using the packager of your Linux distribution.
-
g++ GNU c++ compiler
-
GTK2 and development packages: libgtk2.0-dev (GTK3 will NOT work)
-
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, install them with this command:
sudo apt-get install libgtk2.0-dev freeglut3 freeglut3-dev libglew-dev mesa-common-dev build-essential libglm-dev libxxf86vm-dev libfreeimage-dev pandoc
Compiling and linking TrenchBroom requires a working OpenGL installation. This page may help you if you see linker errors about missing GL libraries.
- Some more detailed (possibly outdated) information about building TrenchBroom on Linux: http://andyp123.blogspot.de/2013/03/running-trenchbroom-quake-editor-on.html
- Currently you must download, patch, and build wxWidgets yourself.
-
Get the latest sources of wxWidgets 3.1 from wxwidgets.org and unpack them.
-
Move the unpacked directory someplace where you want to keep it.
-
Open a terminal and change into the wxwidgets directory.
-
Apply the patches in
TrenchBroom/patches/wxWidgets
as follows:patch -p0 < <path_to_trenchbroom_directory>/patches/wxWidgets/*.patch
-
Create two directories:
build-release
andbuild-debug
(don't rename those!) -
Change into
wxwidgets/build-release
-
Run
../configure --disable-shared --with-opengl --with-gtk=2 --prefix=$(pwd)/install
-
Run
make make install
-
Change into
wxwidgets/build-debug
-
Run
../configure --enable-debug --with-opengl --with-gtk=2 --prefix=$(pwd)/install
-
Run
make make install
-
- Install CMake using your package manager:
sudo apt-get install cmake
-
Open a terminal and change into the directory where you unpacked the TrenchBroom sources
-
Create a new directory, e.g. "build", and change into it.
-
Run the following two commands
cmake .. -DCMAKE_BUILD_TYPE=Release -DwxWidgets_PREFIX=/your/wxWidgets/directory/build-release/install
If you use a system-wide installed wxwidgets, be aware that the CMAKE-script appends
./include/wx-3.1
to the given prefix, so for a wxWidgets installed in/usr/include/wx-3.1/
use:cmake .. -DCMAKE_BUILD_TYPE=Release -DwxWidgets_PREFIX=/usr
cmake --build . --target TrenchBroom
-
You can replace "Release" with "Debug" if you want to create a debug build. Also change the value of the
wxWidgets_PREFIX
variable to point to your wxWidgetsbuild-debug
directory in that case. -
Unless you install TrenchBroom system-wide (see Packaging below), you'll need to set the
TB_DEV_MODE
environment variable to1
when launching TrenchBroom:TB_DEV_MODE=1 ./trenchbroom
This is necessary to tell TrenchBroom to look for resources in the current directory, instead of a system-wide location (in
/usr/
).
-
If you want to create packages for Linux (deb or rpm), then you'll need to install these packages: devscripts, debhelper, rpm
sudo apt-get install devscripts debhelper rpm
-
You can install your preferred wxWidgets configuration using make install. If you wish to do this, then you can omit specifying the
wxWidgets_PREFIX
variable when generating the build configs with Cmake. -
On some systems, such as Xubuntu, you may have to pass the following extra paramter to cmake when creating the build scripts:
-DFREETYPE_INCLUDE_PATH=/usr/include/freetype2/freetype
So the first cmake command should becmake .. -DCMAKE_BUILD_TYPE=Release -DFREETYPE_INCLUDE_PATH=/usr/include/freetype2/freetype
-
Get Xcode from the App Store
-
Dependencies
-
Install cmake (required) and ninja (optional). For example, with homebrew:
brew install cmake ninja
-
-
wxWidgets
-
Get the latest sources of wxWidgets 3.1 from wxwidgets.org and unpack them.
-
Move the unpacked directory someplace where you want to keep it.
-
Open a terminal and change into the wxwidgets directory.
-
Apply the patches in
TrenchBroom/patches/wxWidgets
as follows:patch -p0 < <path_to_trenchbroom_directory>/patches/wxWidgets/*.patch
-
Create two directories:
build-release
andbuild-debug
(don't rename those!) -
Change into
wxwidgets/build-release
-
Run
../configure --with-osx_cocoa --disable-shared --disable-mediactrl --with-opengl --with-macosx-version-min=10.9 --with-cxx=17 --prefix=$(pwd)/install
-
Run
make make install
-
Change into
wxwidgets/build-debug
-
Run
../configure --enable-debug --with-osx_cocoa --disable-mediactrl --with-opengl --with-macosx-version-min=10.9 --with-cxx=17 --prefix=$(pwd)/install
-
Run
make make install
-
-
Build
-
For a release build:
mkdir build-ninja cd build-ninja cmake .. -GNinja -DCMAKE_BUILD_TYPE=Release -DwxWidgets_PREFIX=/your/wxWidgets/directory/build-release/install ninja
-
To generate an Xcode project for developing with:
mkdir build-xcode cd build-xcode cmake .. -GXcode -DCMAKE_BUILD_TYPE=Debug -DwxWidgets_PREFIX=/your/wxWidgets/directory/build-debug/install open TrenchBroom.xcodeproj
Don't enable Address Sanitizer in Xcode; it breaks rebuilding of the project (see #1373).
-
- You can install your preferred wxWidgets configuration using
make install
. If you wish to do this, then you can omit specifying thewxWidgets_PREFIX
variable when generating the build configs with Cmake. - The changelog is generated with
git log --oneline --decorate <LAST_REL_TAG>..HEAD
, where <LAST_REL_TAG> is replaced by whatever tag marks the last release. The generated log is then manually cleaned up. - To create a release, push the appropriate tag, e.g.
git tag -a v2.0.0-RC5 -m "This tag marks TrenchBroom 2 release candidate 5."
, thengit push origin v2.0.0-RC5
.