Skip to content

N3rdL0rd/alivecells

Repository files navigation

Alive Cells

A toolkit for modding Dead Cells

Installation

Note

This project is still in development and is not yet quite ready for public use. It is provided here purely to allow for others to play with the game in ways previously not possible.

Warning

This is a Windows-only script. On Linux and MacOS, the game is already configured in such a way as to easily facilitate modding.

Prerequisites

  • Dead Cells v34 (Clean Cut Update) or v35 (The End is Near Update) for Windows (This was tested with the Steam version of the game, but any distribution should work)
  • Python 3.10+ or pyenv and pip (This repository is configured to automatically use 3.10.11 if you have pyenv installed)
  • An Internet connection (I hope you have one of these already...)

Actual Installation

  • Clone the repo
  • pip install -r requirements.txt
  • Run python alivecells.py --help to see the available commands

Usage

Currently, a few tools are provided in a single Python script - alivecells.py. This script can be run from the command line with the following arguments:

usage: alivecells.py [-h] {install,extract} ...

Extract Hashlink bytecode from Dead Cells executable and prepare it for execution.

positional arguments:
  {install,extract}
    install          Install the Hashlink VM in a given folder and copy over game bytecode and dependencies.
    extract          Extract Hashlink bytecode from the Dead Cells executable.

options:
  -h, --help         show this help message and exit

usage: alivecells.py install [-h] [--output OUTPUT] [--no-extract] [--goldberg] dir game_path

positional arguments:
  dir              The directory to install the Hashlink VM in.
  game_path        The path to the Dead Cells game directory.

options:
  -h, --help       show this help message and exit
  --output OUTPUT  The output filename for the Hashlink bytecode.
  --no-extract     Do not extract Hashlink bytecode from the executable - will require you to provide your own hlboot.dat.
  --goldberg       Use Goldberg Emulator to bypass Steam API issues - generally not required.

usage: alivecells.py extract [-h] [--output OUTPUT] [--in-game-dir] exe_path

positional arguments:
  exe_path         The path to the Dead Cells executable (deadcells.exe, not deadcells_gl.exe).

options:
  -h, --help       show this help message and exit
  --output OUTPUT  The output filename for the Hashlink bytecode.
  --in-game-dir    Save the Hashlink bytecode in the Dead Cells game directory as well as the current directory.

Other tools are provided as standalone executables, such as the patched PAKTool, which you can either clone and build yourself, or get from the Releases.

Known Issues

  • When running in a seperate directory than the original Steam installation, the game will fail to sync Steam Cloud saves. This can be fixed by symlinking the save directory in the game directory to the original Steam installation directory, but this is only a temporary fix - a proper solution is being worked on.
  • The game will be able to connect to the Steam Workshop, but will generally not be able to download mods due to the game not being run through Steam. This can be fixed by installing the VM to the actual game directory and running hl.exe from Steam instead of deadcells.exe
  • Sometimes, the game will register itself as Half-Life in Steam and Discord.

For Modders

This is pretty much uncharted territory when it comes to modding - so here's my best guidance for those who want to try their hand at it:

  1. Install Dead Cells with the Hashlink VM outside of the Dead Cells game directory - this will allow you to tamper with the game's bytecode without the game refusing to start
  2. Install Haxe - you'll need this to compile the scripts
  3. Disassemble and decompile the bytecode - you can use hlbc, but be warned - not everything can be decompiled (and, in turn, recompiled) correctly, and you'll probably still end up poking and prodding the bytecode with a hex editor (I recommend ImHex or REHex)
  4. Put everything back and hope it works - you'll need to reassemble the bytecode and put it back in the game directory, then see if it works

Linux Support

Dead Cells on Linux already has hlboot.dat outside of the executable, so you can just use that file directly with your choice of Hashlink VM.

Roadmap

  • Implement a more user-friendly interface
  • Create a proper bytecode patcher/modloader

License

This project is licensed under the MIT License - see the LICENSE file for details. However, the Dead Cells game and its assets are not included in this repository and are subject to their own licensing agreements, and the following licensing exemptions apply:

  • The Dead Cells team, Motion Twin, and Evil Empire are hereby permitted to use this software in any way they see fit, including but not limited to modifying, distributing, and selling it.