An open source re-implementation of RollerCoaster Tycoon 2 🎢
Find a file
Michał Janiszewski 3d0fcc948d POSIX: use mincore to detect impending doom
Call to mmap (or next malloc) will likely fail if there are already
mapped pages within the region we want to map ourselves. Using mincore
we can detect if such pages exist and warn user about what's going to
happen.
2015-12-09 00:57:42 +01:00
data Merge Localisation/master into OpenRCT2/develop. 2015-12-03 04:00:17 +00:00
distribution fix #2449: Turning off Day/Night Circle while it is night doesn't reset back to day 2015-12-08 20:50:30 +00:00
dockerfiles use docker for 32bit build 2015-09-28 21:48:41 +02:00
projects OS X platform implementation 2015-11-28 10:40:58 +01:00
resources add icons to server list for password and version 2015-11-27 18:54:59 +00:00
src POSIX: use mincore to detect impending doom 2015-12-09 00:57:42 +01:00
test Strip all whitespace 2015-10-20 20:48:51 +02:00
.gitattributes Cleanup .gitattributes formatting 2014-08-05 19:10:28 -07:00
.gitignore add new cache file to .gitignore (introduced in VS2015 Update 1) 2015-12-02 17:53:01 +00:00
.travis.yml Use 'trusty' image for travis now that it's public 2015-10-23 00:04:19 +02:00
appveyor.yml add appveyor configuration 2015-08-30 16:51:41 +01:00
build.bat add twitch integration, part 2 2015-05-25 20:38:33 +01:00
build.sh Update lodepng to 20151024 2015-11-13 11:52:13 +01:00
build_g2.bat improve sprite compiler 2015-06-03 03:11:54 +01:00
build_g2.sh fix directories in linux 2015-10-02 14:48:10 -06:00
clean.sh remove libs from orct repo, add dependencies pull to prebuilds, update unix scripts 2015-07-03 08:45:56 +01:00
CMakeLists.txt Fixes for building optimized binary on Linux 2015-11-18 21:29:08 +01:00
CMakeLists_mingw.txt Fixes for travis builds of new AT&T syntax 2015-10-22 23:59:10 +02:00
CONTRIBUTING.md Update CONTRIBUTING.md 2015-09-24 13:03:44 +01:00
contributors.md added myself to contibutors 2015-12-07 10:41:04 -06:00
curl-ca-bundle.crt add twitch integration, part 2 2015-05-25 20:38:33 +01:00
install.sh Change pre-built link to http://openrct2.website/ 2015-11-13 23:33:24 +01:00
licence.txt (test commit for travis please ignore) 2014-05-25 22:35:54 +02:00
openrct2.exe patch exe to remove DirectDraw, DirectInput and DirectPlay dependencies. 2015-08-18 21:32:21 +01:00
pre-build.ps1 Change pre-built link to http://openrct2.website/ 2015-11-13 23:33:24 +01:00
readme.md Re-added rct subreddit 2015-11-24 18:34:04 +01:00
run.bat add twitch integration, part 2 2015-05-25 20:38:33 +01:00
SDL2.dll initial commit 2014-04-02 00:31:55 +01:00
test.bat refactor test project and add ride ratings test 2015-06-04 12:46:17 +01:00

OpenRCT2

An open source clone of RollerCoaster Tycoon 2 built by decompiling the original game one bit at a time.

Linux Build:
Travis CI
Windows Build:
AppVeyor

Come talk with us if you have any questions:
![Gitter](https://badges.gitter.im/Join Chat.svg)

Contents

1 Introduction

1.1 Background

OpenRCT2 is an attempt to decompile RollerCoaster Tycoon 2 into C. RollerCoaster Tycoon 2 was originally written in MASM and Visual C++ where functions related to interfacing with the operating system were written in C (supposedly 1%), with the rest of the game being written in pure x86 assembly. For an example of this method, OpenTTD was formed through a similar procedure; the original game, Transport Tycoon Deluxe, was decompiled into C which allowed for the addition of thousands of features to the game. RollerCoaster Tycoon 2 uses the third version of Chris Sawyer's engine, which shares some code with Transport Tycoon. This is reflected in the usage of OpenTTD 0.1 code such as the windowing system and graphics rendering. While the version of the engine used in Chris Sawyer's Locomotion is newer, OpenRCT2 is currently targeting the RollerCoaster Tycoon 2 engine to ease the decompilation process.

1.2 Decompiling the game

In order to decompile the game gradually without introducing new bugs, each procedure in RollerCoaster Tycoon 2 is to be re-written in C on an individual basis. To test the accuracy of the re-written procedures, the decompiled C procedures are compiled into a DLL (openrct2.dll) which exports an entry procedure mimicking the WinMain function in RollerCoaster Tycoon 2. The original executable rct2.exe has been patched so that openrct2.dll and WinMain are in the DLL import table and the WinMain export procedure in openrct2.dll is called at the start of the WinMain procedure in rct2.exe before returning. With this system implemented, starting rct2.exe calls the new DLL as part of its initialization; the DLL can then run all the decompiled code whilst still being able to read / write to the rct2.exe memory model and run rct2.exe procedures.

The project therefore acts as a patch to RollerCoaster Tycoon 2, allowing each procedure to be gradually implemented while simultaneously adding new features where possible. Until all procedures of the original game are re-written in C, the project must remain a DLL which is called from the patched rct2.exe.

1.3 Progress

Currently, the windowing system, graphics rendering and basic game loop are being decompiled. Decompiling all of the game's procedures is a convenient way of identifying the game's memory structure. SDL2 has been used as a replacement for the operating system calls, allowing for cross-platform support after the dependency on the original game's executable has been removed.

As of 9th September 2015, a vast set of improvements have been added such as improved UI, tools, cheats, localisation and configuration. The entire window system and UI has been implemented, all file format handling such as loading and saving of parks, graphics and tracks, ride logic, game management (e.g. peep generation, awards, cash out) and a lot of the peep logic. What remains is a lot of code to draw the map, the rest of the peep logic, and the entirety of vehicle logic. The rest are small parts around different areas that aren't particularly significant. More information can be found in changes to original game.

1.4 Aim

The aim is to completely decompile RollerCoaster Tycoon 2 into C so that cross-platform support, new features, and new gameplay can be added in a similar fashion to OpenTTD. With the addition of SDL2, the game can already be run in a resizeable window (which was not possible originally). Once the game has been fully decompiled, additional gameplay features, gameplay tweaks, and improvements can be introduced. The following is only a brief, non-exhaustive list of the possibilities - there are many more:

  • Improved peep path-finding
  • Increased window / ride / object / map / construction limits
  • More sandbox-friendly gameplay
  • Editing available objects
  • Improved title sequence
  • Translation into more languages
  • Re-introduction of RollerCoaster Tycoon 1 mechanics:
    • Shuttle Loop compatibility
    • Have Fun! objective
    • Finish building five coasters objective
    • Using the mountain tool during the game

2 Downloading the game / Building the source code

Several third party build servers offer precompiled builds and installers of the latest stable and the develop branch. OpenRCT2.com OpenRCT.net UrsaLabs

There is also a Launcher available from OpenRCT.net that will automatically update your build so that you always have the current version as they are released.

2.1 Building prerequisites

OpenRCT2 requires original files of Rollercoaster Tycoon 2 to play. It can be bought at either Steam or GOG.com.

Windows:

Mac OS X:

Mac OS X / Linux:

2.2 Compiling and running

Windows:

  1. Check out the repository. This can be done using GitHub Windows or other tools.
  2. Open the solution in the projects directory (openrct2.sln) with Visual Studio.
  3. Select the 'Release' configuration and click Build -> Rebuild Solution. The dropdown menu to enable the 'release' configuration is towards the top of the VS Express window, near the "TEST" menu.
  4. Start debugging. Press the "Local Windows Debugger" button with a green "play" icon next to it. If Visual Studio shows a warning about openrct2.exe not having debug information, press Continue.
  5. When OpenRCT2 is run for the first time, it creates a settings file in My Documents/OpenRCT2. If it can't find the original installation of RCT2, you will need to edit config.ini in that folder and change the value of game_path to where RCT2 is installed.
  6. If the game crashes, you may need to press the red, square Stop button along the top of VS Express to stop the program.

Alternatively, to simply build the project you can just execute build.bat within VS2015 Native Tools Command prompt or Github Windows prompt.

Mac OS X:

Providing Homebrew or MacPorts are installed (but not both!), OpenRCT2's dependencies and Wine can be installed automatically through install.sh.

bash install.sh
bash build.sh
wine openrct2.exe

Linux:

As the easiest approach depends on your distribution, please take a look at the wiki.

3 Contributing

OpenRCT2 uses the gitflow workflow. If you are implementing a new feature or logic from the original game, please branch off and perform pull requests to develop. If you are fixing a bug for the next release, please branch off and perform pull requests to the correct release branch. master only contains tagged releases, you should never branch off this.

Please read our contributing guidelines for information.

3.1 Decompiling

Experience with reverse engineering and x86 assembly is necessary to decompile the original game. IDA 5.0 is currently being used to disassemble and analyze the game. You are welcome to contribute to the process by taking an undecompiled procedure, disassembling it, and rewriting it in C. For more information and the latest IDA database, contact IntelOrca.

3.2 Naming of procedures and variables

During the development phase, many variables and procedures are referenced by their memory address in OpenRCT2. This is a result of ongoing reverse engineering efforts; the functionality and use of these values has yet to be determined. To help with identification, there are multiple methods you can use. For variables:

  • Modify the variable and see how the game is affected
  • Reverse-engineer RCT2 and find where the variable is used or modified

For procedures:

  • Remove the call to the procedure in OpenRCT2 and observe the effects
  • Reverse-engineer RCT2 and find where the procedure is called

3.3 Cleaning and documenting the source code

As the source code is formed from decompilation, it is unorganized and undocumented. Efforts towards cleaning up and documenting code are appreciated; for example, blocks of code can be moved into their own functions, and macros can be created for operations that occur frequently. However, be aware that the overall structure of the code should remain the same to ensure that OpenRCT2 is kept in sync with the original game to ease the integration of additional decompiled code.

In general, small changes that improve code quality and make it easier to reason about the logic are appreciated. More significant changes, such as changing the game's architecture, are to be avoided during the ongoing decompilation of the original game.

3.4 Implementing new features / fixing bugs

While decompilation is an ongoing process, this does not prohibit changes being made to the game. New features or bugfixes can be added, with caution, if the underlying code has been decompiled. When implementing these changes, ensure that comments are added to clearly identify where code has been intentionally changed so that it functions differently to the original game; this is essential to ensuring all research from reverse-engineering can still be applied.

3.5 Translation

Translations are in progress for German, Dutch, French, Hungarian, Polish, Spanish, Swedish, Italian, and more. You can translate the game into other languages by editing the language files in the data directory. Please join discussions and submit pull requests to https://github.com/OpenRCT2/Localisation.

4 Licence

OpenRCT2 is licensed under the GNU General Public License version 3.

5 More information