Skip to content

Building From Source

TheMaverickProgrammer edited this page Jan 3, 2022 · 3 revisions

#development branch is stable but also experimental! You will have the latest and greatest code

Windows

Watch the youtube tutorial to build, compile, and play the game!

Unix OS

Build and install vcpkg. Make sure it is in your system PATH.

vcpkg install poco fluidsynth lua

Then install the following:

apt-get install cmake-qt-gui
apt-get install libvorbis-dev
apt-get install libopenal-dev
apt-get install libfreetype-dev
apt-get install libflac++-dev

Use cmake-gui to build the source code. Be sure to set CMAKE_TOOLCHAIN_FILE to the vcpkg's cmake script. Mine is located at vcpkg/scripts/buildsystems/vcpkg.cmake

If you're having trouble with the GUI, you can use cmake from CLI to create a build folder:

mkdir build
cd build
cmake .. -DCMAKE_TOOLCHAIN_FILE=[path to vcpkg]/scripts/buildsystems/vcpkg.cmake

From the build folder you can use make to compile the project.

I have had a good experience with CodeBlocks as the IDE using Makefile generator.

Configure, Generate, then Build, and finally Run!

Linux

In the root directory of the repo there is a makefile. Run make clean && make to build the engine. It will output an executable to the /Debug folder. All the executable needs is the /resources folder. You can move this executable anywhere and copy the /resources folder next to it.

Before you can run, you need to let the executable know where the dynamic libraries are. In the root directory, open your terminal and type

export LD_LIBRARY_PATH=`pwd`/extern/libs

This tells the system to look for the dynamic libs in the provided extern folder. Check to make sure it is set with

echo $LD_LIBRARY_PATH

Now you can play BattleNetwork:

./battlenetwork

screenshot-linux

Mac OS

Compiling on mac is almost identical to Linux with one extra step: you must have the SFML Framework dependencies installed in Library/Framework on your mac. See here for help. Follow the same steps for Linux, running make, providing the /resources folder, and set your LD_LIBRARY_PATH variable.

Then run

./battlenetwork

screenshot-mac

Contributing

This project is open source so that anyone can contribute art, ideas, and code. This is a big undertaking and the foundation is nearly complete. Please refer to the following links to see the state of the engine and how you can help.

Clone this wiki locally