49 lines
2.2 KiB
Markdown
49 lines
2.2 KiB
Markdown
# scroll-rs
|
|
Experimental Clash Royale server emulator on top of libg.so (v1.3.2)
|
|
# 
|
|
|
|
# Why?
|
|
Supercell's games have their game logic implementation included in both client and server, for independent execution (the `Logic*` family of classes is shared). However, to implement a feature-complete server emulator, you should rewrite the logic entirely. This experimental way is to use logic that is retained in the game, basically turning client into a server.
|
|
|
|
# Current features
|
|
- All cards are unlocked
|
|
- Training battles
|
|
- More features are planned to be implemented (including PvP battles), stay tuned
|
|
|
|
# Implementation
|
|
Server side code is written in Rust. We provide idiomatic bindings for the structures/functions from `libg.so`.
|
|
|
|
# Getting started
|
|
#### NOTE: you have to use a device with support of armeabi-v7a binaries
|
|
### a) Using pre-built apk files
|
|
Navigate to the [Releases](https://git.xeondev.com/Supercell/Scroll/releases) page and download both Server and Client APK files (by default, they're targeted to the `127.0.0.1:9339` endpoint). Next, install both of them. Open the server application first (it should stay with black screen), then leave it running in the background. Open the client and play!
|
|
### b) Building from sources
|
|
#### Requirements:
|
|
- [Rust 1.85+](https://www.rust-lang.org/tools/install)
|
|
- [Android NDK](https://developer.android.com/ndk/downloads)
|
|
- [cargo-ndk](https://docs.rs/crate/cargo-ndk/3.5.4)
|
|
|
|
#### Preparing the toolchain
|
|
- Install android armv7 target via rustup:
|
|
```sh
|
|
rustup target add armv7-linux-androideabi
|
|
```
|
|
- Install cargo-ndk extension:
|
|
```sh
|
|
cargo install cargo-ndk
|
|
```
|
|
|
|
##### NOTE: make sure you have configured the `ANDROID_NDK_HOME` environment variable before invoking build command.
|
|
|
|
#### Compiling server library
|
|
```sh
|
|
git clone https://git.xeondev.com/Supercell/Scroll
|
|
cd Scroll
|
|
cargo ndk -t armeabi-v7a build --release
|
|
```
|
|
|
|
### Community
|
|
[Our Discord Server](https://discord.gg/reversedrooms) is open for everyone who's interested in our projects!
|
|
|
|
### Support
|
|
Your support for this project is greatly appreciated! If you'd like to contribute, feel free to send a tip [via Boosty](https://boosty.to/xeondev/donate)!
|