/horizon

HorizonXYZ/Horizon is a robust and versatile C++ project designed to supersede older Ragnarok Online emulators, namely from the eAthena family.

Primary LanguageLuaGNU General Public License v3.0GPL-3.0

HorizonXYZ/Horizon

MSVC GCC CLANG GPLv3 license Repo Size Contributors

CMake C++ Lua MySQL Boost sol2

HorizonXYZ/Horizon is a robust and versatile C++ project designed to supersede older Ragnarok Online emulators, namely from the eAthena family.

Table of Contents

Why Horizon?

1. Customizability and Extended Functionality

Built with the need for more customizability in mind, Horizon offers a comprehensive solution for the extended functionality of RO features such as the following, through the use of Lua (our scripting language) :

  • Skills
  • Status Effects
  • Combat and damage components
  • In-game At-commands
  • Development oriented Script-commands
  • Server Administration based Console-commands
  • Game Administration based Web-commands

2. High Performance and Maintainability

The project leverages advanced C++ features and OOP design principles and follows best coding practices to ensure high performance and maintainability. Each feature in the project is carefully designed with software design principles such as -

3. Features

It includes a variety of features such as a -

  • Multithreaded infrastructure
  • Packet-based networking system
  • Database Support
  • Lua scripting engine
  • Console interface

making it a go-to choice for server owners that want a modern industry-standard solution for their RO server. It is aimed to be a high-end solution for RO server owners catering to larger user populations, allowing a seamless and uninterrupted support of thousands of players at once.

4. Flexibility

Whether you're looking to build a small server that offers a variety of customizations, or a large one, HorizonXYZ/Horizon provides the tools and flexibility you need to achieve your goals.

5. Open Source

The project is open-source and encourages contributions from developers who are interested in enhancing its capabilities and reach.

Showcase

Here are some videos showcasing the project:

Combat Damage System Test / Damage Delay Test / Walk Delay Test

HorizonXYZ/Horizon: Combat Damage System Test / Damage Delay Test / Walk Delay Test

Item Drop Test

HorizonXYZ/Horizon: Item Drop Test

Skill System Test

HorizonXYZ/Horizon: Skill System Test

Storage / Premium Storage System Test

HorizonXYZ/Horizon: Storage / Premium Storage System Test

Getting Started

To get a local copy up and running, follow these steps:

Prerequisites

Hardware

Minimum

Windows Linux
RAM For Compiling 8192MB 4096MB
RAM For Running 2048MB 2048MB
CPU 2 Cores 1 Core

Recommended

Windows Linux
RAM For Compiling 16384MB 8192MB
RAM For Running 4096MB 4096MB
CPU 4 Cores 2 Cores

Installation

Usage

After compiling and setting up the project, you can start the servers with the following command:

auth.exe --with-config="config/auth-server.lua"
char.exe --with-config="config/char-server.lua"
zone.exe --with-config="config/zone-server.lua"

Contributing

Contributions are what make the open-source community such an amazing place to learn, inspire, and create. Any contributions you make are greatly appreciated.

  1. Fork the project
  2. Create your feature branch (git checkout -b feature/AmazingFeature)
  3. Commit your changes (git commit -m 'Add some AmazingFeature')
  4. Push to the branch (git push origin feature/AmazingFeature)
  5. Open a pull request

License

Distributed under the GNU General Public License v3.0. See LICENSE for more information.

Acknowledgements