Skip to content

Commit

Permalink
Finally add readme
Browse files Browse the repository at this point in the history
  • Loading branch information
maxmitti committed Aug 16, 2024
1 parent ffeb33e commit e0db3fe
Showing 1 changed file with 121 additions and 0 deletions.
121 changes: 121 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,121 @@
# LegacyClonk

![Logo](planet/Graphics.c4g/Logo.png)

LC (short for LegacyClonk) is a fan project based on Clonk Rage.
LegacyClonk continues to receive updates and ensures compatibility with existing Clonk Rage content.

The goal is to fix as many bugs and inelegances as possible, improving quality-of-life and adding nice-to-have features while not impacting the gameplay we’re all used to.

## Installation
Please refer to the [English](https://clonkspot.org/lc-en#installation-1) or [German](https://clonkspot.org/lc#installation-1) installation manual if you simply want to play the game.

[clonkspot.org](https://clonkspot.org) hosts the community forum, content developer documentation and masterserver.

## Compiling - Quick Start
**Disclaimer**: This readme is fairly new and may contain mistakes. In case of problems [reach out](#Contact). Readme improvement PRs are welcome.

Essential dependencies:
- CMake
- Fairly modern C++ compiler
- Windows: **Latest MSVC** (mingw-w64 g++ ≥ 13.1 *should* work with cmake option `-DUSE_WINDOWS_RUNTIME=OFF`, but is *not tested regularly*)
- Linux: **g++ ≥ 13.1** or **clang++ ≥ 18.1**
- macOS: **open source clang++ ≥ 18.1** - e.g. `brew install llvm@18 ninja`
- Make or Ninja

Extract the [latest pre-built dependencies](https://github.com/legacyclonk/deps/releases/latest) for your platform into a folder called `deps`.
Make sure that besides the `CMakeLists.txt` of LegacyClonk there are folders `deps/include`, `deps/lib`, etc. as extracted from the binary package.


### Configuring and compiling the engine
Open a Terminal and navigate to the repository root, such that `CMakeLists.txt` is in the current directory.

#### Windows
Use the MSVC developer PowerShell.

Configure with CMake
```PowerShell
cmake . -B build -DCMAKE_BUILD_TYPE=RelWithDebInfo
```

Open the resulting Visual Studio solution or simply compile with CMake as follows
```PowerShell
cmake --build build
```

#### Linux
Configure with CMake
```bash
cmake . -B build -DCMAKE_BUILD_TYPE=RelWithDebInfo -DWITH_DEVELOPER_MODE=ON
```

Compile with CMake
```bash
cmake --build build
```

#### macOS
Configure with CMake (FIXME: Rename toolchain file, the version number doesn’t matter)
```bash
cmake . -B build -DCMAKE_TOOLCHAIN_FILE=$PWD/autobuild/clang16_mac.cmake
```

Compile with CMake
```bash
cmake --build build
```

Create the `.app`-bundle
```bash
DESTDIR=build/destdir cmake --build build --target install
```

The `clonk.app` should be generated at `build/destdir/usr/local/clonk.app`.


### Setup game folder
The engine needs various files to run placed next to the engine binary.
The cleanest way is to create and setup a game folder somewhere outside of the source code repository.

If you want to use an existing game folder (e.g. obtained via the simple binary [Installation](#Installation)) use that folder instead and only do step 2.

1. Create an empty folder at the desired location.
The guide assumes the directory path to be `~/clonk`.
1. Create a symbolic link to the binary in the folder
- Windows: `mklink /H ~/clonk/MyClonk.exe build/clonk.exe`
- Linux: `ln -s build/clonk ~/clonk/myclonk`
- macOS: `ln -s build/clonk.app ~/clonk/myclonk.app`
1. Create symbolic links to [Graphics.c4g](planet/Graphics.c4g) and [System.c4g](planet/System.c4g). Without them, the engine won’t start.
- Windows
```PowerShell
mklink /J ~/clonk/Graphics.c4g planet/Graphics.c4g
mklink /J ~/clonk/System.c4g planet/System.c4g
```

- Linux / macOS
```bash
ln -s planet/Graphics.c4g planet/System.c4g ~/clonk
```
1. Get official content (optional, but can’t play without some content)
- Pre-built: Extract `lc_content.zip` from the [latest release](https://github.com/legacyclonk/content/releases/latest) in the game folder.
- From repository
1. Clone the content repository in a different folder, e.g. `~/lc_content`: `git clone https://github.com/legacyclonk/content ~/lc_content`
2. Create symbolic links for all groups
- Windows
- Easier: Copy all directories with ending `.c4?`
- When planning to edit the content: https://superuser.com/a/1489528
- Linux / macOS: `ln -s ~/lc_content/*.c4? ~/clonk`

### Play

- Enter your game folder, e.g. `~/clonk`.
- Launch `clonk.exe`/`clonk.app`/the `clonk` binary.
- Enjoy

Remark: In order to join network games with other players (who use release binaries) your `System.c4g` needs to match the one from the host. It can be obtained from [Releases](https://github.com/legacyclonk/LegacyClonk/releases/latest).

## Contact

- IRC: [irc://irc.euirc.net/#legacyclonk](irc://irc.euirc.net/#legacyclonk)
- Discord: [Server](https://discord.gg/km58ETK)
- Forum: [https://forum.clonkspot.org](https://forum.clonkspot.org)

0 comments on commit e0db3fe

Please sign in to comment.