Go to file
Ted John 29c9958422 Update .clang-format for new version of clang-format 2020-03-17 21:02:25 +00:00
.github Move code format check to GitHub Actions 2020-03-17 21:02:25 +00:00
cmake Fix Travis CMake builds for Linux and MinGW targets. 2018-10-08 09:29:17 +02:00
data/language Include Russian translation from dump (#346) 2020-03-13 17:43:39 +01:00
distribution Generate and build macOS app bundles through CMake. 2019-02-26 09:38:44 +01:00
dockerfiles Add mingw32-libpng to Fedora mingw Dockerfile 2020-03-14 00:13:12 +01:00
resources Set window icon to OpenLoco logo 2019-02-24 20:53:47 +00:00
scripts Run clang-format on CI 2018-01-23 23:11:58 +01:00
src/openloco Explicitly add VcpkgTriplet value 2020-03-13 17:48:38 +01:00
.clang-format Update .clang-format for new version of clang-format 2020-03-17 21:02:25 +00:00
.gitignore Generate and build macOS app bundles through CMake. 2019-02-26 09:38:44 +01:00
.travis.yml Move code format check to GitHub Actions 2020-03-17 21:02:25 +00:00
CHANGELOG.md Make keypad enter work the same as normal enter (#380) 2019-11-17 18:00:00 +01:00
CMakeLists.txt Fix tag detection for shallow clones (#368) 2020-03-13 13:38:59 +01:00
CMakeLists_mingw.txt Add mingw toolchain file for cmake 2018-01-29 00:00:53 +01:00
CONTRIBUTORS.MD Added initial version of Slovak translation (#337) 2019-05-10 23:15:14 +02:00
LICENSE Update license to reflect project state. (#281) 2019-02-24 22:54:39 +00:00
README.md Change phrasing around the Gitter chat. (#360) 2019-06-10 22:51:08 +02:00
appveyor.yml Update dependencies to version 1.2.0. 2020-03-13 17:48:38 +01:00
docker-compose.yml Change version in docker-compose.yml to 2 2018-01-31 23:48:14 +01:00
loco.exe Cleanup loco.exe file (#6) 2018-01-21 13:18:43 +00:00
openloco.common.props Allow any Windows SDK to be used via %UCRTVersion% 2018-10-03 18:44:52 +01:00
openloco.sln Add initial working wrapper 2018-01-07 03:18:38 +00:00

README.md

OpenLoco

An open source re-implementation of Chris Sawyer's Locomotion. A construction and management simulation video game that simulates running a transport company.


Contents


Build Status

Windows Linux / Mac Download
master AppVeyor Travis CI GitHub release

Chat

Feel free to join our Gitter channel to talk about developing the game, or for help getting it to run. You only need an account with either GitHub, GitLab, or Twitter to join the Gitter chat.

Gitter

1 Introduction

OpenLoco is an open-source re-implementation of Chris Sawyer's Locomotion (CSL). CSL is the spiritual successor to Transport Tycoon and OpenLoco aims to improve the game similar to how OpenTTD improved Transport Tycoon and OpenRCT2 improved RollerCoaster Tycoon.

Chris Sawyer's Locomotion was written by Chris Sawyer in x86 assembly building on top of his RollerCoaster Tycoon 2 engine. Much of the code is 1:1 with RollerCoaster Tycoon 2. This means that only select areas of the game such as the update logic should be written. The engine code such as audio, drawing and the window system should be left alone as it would only repeat the work that has already been done for OpenRCT2. It is more beneficial to share as much code as possible between OpenRCT2 and OpenLoco.


2 Downloading the game (pre-built)

OpenLoco requires original files of Chris Sawyer's Locomotion to play. It can be bought at either Steam or GOG.com.

The latest release can be found on GitHub.


3 Building the game

3.1 Building prerequisites

OpenLoco requires original files of Chris Sawyer's Locomotion to play. It can be bought at either Steam or GOG.com.

Windows:

Linux / macOS:


3.2 Compiling and running

Windows:

  1. Check out the repository. This can be done using GitHub Desktop or other tools.
  2. Install dependencies using vcpkg or use the nuget package.
  3. Open a new Developer Command Prompt for VS 2017, then navigate to the repository (e.g. cd C:\GitHub\OpenLoco).
  4. Run msbuild openloco.sln
  5. Run mklink /D bin\data ..\data or xcopy data bin\data /EIY
  6. Run the game, bin\openloco

Linux / macOS:

The standard CMake build procedure is to install the required libraries, then:

mkdir build
cd build
CXXFLAGS="-m32" cmake ..
make

Running the game will need the data directory from the root of the source code next to the binary. Assuming you're in $SRC/build,

ln -s ../data
OR
cp -r ../data ./data 

4 Licence

OpenLoco is licensed under the MIT License.


5 More information