Please note that reverse-engineering projects are not supported for this project, where the original executable is used to create the engine, instead of creating it in a more open source manner. If you have any questions on this, please feel free to create an issue or talk on discord.
Each package has a folder with the build scripts and any static assets, such as a launcher script or custom configuration files for the game. These are located in the engines
folder, so if you wanted to create a package for the dhewm3 engine, the path would be engines/dhewm3
. For any dependencies that are needed by the engine, use vcpkg where possible. See fs2open/vcpkg.json
for an example.
The structure of an engine folder is as follows:
env.json
- Contains the steam app id list for the games that this engine applies to, as well as the path to the license file from the engine repository, if exists. If there are multiple app ids, then each one should be an element in the array.build.sh
- Script that will pull down the source repository, run any necessary configuration, and then build the engine.assets/*
- If needed, an assets folder can be created for any static assets needed for the engine.
In the build script, there are three main phases, that are denoted by the comments separating them.
Phase where any necessary repositories are cloned and the correct branch or hash is checked out.
A simple clone phase can look like the following. The engine should always be cloned into the source
directory
# CLONE PHASE
git clone https://github.com/dhewm/dhewm3.git source
pushd source
git checkout 3a763fc6
popd
For engines with submodules, it can look like the following:
# CLONE PHASE
git clone https://github.com/Try/OpenGothic source
pushd source
git checkout -f b6a1260
git submodule update --init --recursive
popd
Phase where the building of the engine occurs. This would be where the engine's make scripts could be run.
# BUILD PHASE
pushd source/neo
mkdir build
cd build
cmake -DCMAKE_INSTALL_PREFIX=../../../tmp ..
make -j "$(nproc)"
make install
popd
Phase where the copying of the binaries and libraries occur, to create the final package.
The path to copy into should follow this template: $diststart/<appid>/dist/
, replacing <appid>
with the app id necessary. If an engine supports multiple games, then the files would need to be copied into each app id, as shown below.
# COPY PHASE
cp -rfv tmp/bin/* "$diststart/9050/dist/"
cp -rfv tmp/lib/dhewm3/* "$diststart/9050/dist/"
cp -rfv tmp/bin/* "$diststart/9070/dist/"
cp -rfv tmp/lib/dhewm3/* "$diststart/9070/dist/"
-
Fork the packages repo and create a branch, named after the engine that should be built.
-
In the engines folder, create a new folder named after the engine use this folder for the following steps.
-
Create env.json file, using the following template. COMMIT_TAG should be used for a release, while COMMIT_HASH should be used for grabbing from the latest of a branch.
{
"STEAM_APP_ID_LIST": [
"9050",
"9070",
"9100"
],
"LICENSE_PATH": "./source/COPYING.txt",
"ADDITIONAL_LICENSES": [
"./source/README.md"
],
"COMMON_PACKAGE": true,
"COMMIT_TAG": "1.5.2"
}
- Create build.sh, using the following template.
#!/bin/bash
# CLONE PHASE
git clone https://github.com/dhewm/dhewm3.git source
pushd source
git checkout "$COMMIT_TAG"
popd
# BUILD PHASE
pushd source/neo
mkdir build
cd build
cmake -DCMAKE_INSTALL_PREFIX=../../../tmp ..
make -j "$(nproc)"
make install
popd
# COPY PHASE
cp -rfv tmp/bin/* "$diststart/9050/dist/"
cp -rfv tmp/lib/dhewm3/* "$diststart/9050/dist/"
cp -rfv tmp/bin/* "$diststart/9070/dist/"
cp -rfv tmp/lib/dhewm3/* "$diststart/9070/dist/"
- Set the appropriate permisions on the scripts.
chmod +x build.sh
-
Test building the new package, using the instructions on the Testing a Package document.
-
Update
metadata/packages.json
to reflect the new package, using the following template. The information object will be used to display any necessary metadata on the packages list webpage. The download array will be created once the package has been built for the first time.
{
"game_name": "DOOM 3",
"download": [
{
"name": "dhewm3",
"url": "https://github.com/luxtorpeda-dev/packages/releases/download/dhewm3-52/",
"file": "dhewm3-common-52.tar.xz",
"cache_by_name": true
}
],
"command": "./run-dhewm3.sh",
"engine_name": "dhewm3",
"cloudAvailable": true,
"cloudSupported": true,
"app_id": "9050"
}
Engines that need further setup can use the following template:
{
"game_name": "Unreal Tournament 2004: Editor's Choice Edition",
"download": [],
"download_config": {
"binaries": {
"extract_location": "../linuxdata",
"strip_prefix": "UT2004-Patch/",
"setup": true,
"copy_only": false
}
},
"setup": {
"complete_path": "../ready",
"command": "./setup-ut2004.sh",
"uninstall_command": "./uninstall-ut2004.sh",
"license_path": "../System/License.int"
},
"command": "./run-ut2004.sh",
"use_original_command_directory": true,
"app_id": "13230"
}
Engines that need choices can look like the following:
{
"game_name": "X-COM: Terror from the Deep",
"download": [
{
"name": "openxcom",
"url": "https://github.com/luxtorpeda-dev/packages/releases/download/openxcom-1/",
"file": "openxcom-common-1.tar.xz",
"cache_by_name": true
}
],
"download_config": {
"openxcom": {
"extract_location": "./openxcom"
},
"openxcom-oxce": {
"extract_location": "./openxcom-oxce"
}
},
"choices": [
{
"name": "openxcom",
"command": "./openxcom/run-tftd.sh",
"download": ["openxcom"]
},
{
"name": "openxcom-oxce",
"command": "./openxcom-oxce/run-tftd.sh",
"download": ["openxcom-oxce"]
}
],
"app_id": "7650"
}
-
At the root level of packages.json, there is an engines key. Inside here is all of the engine information. A new engine should contain a new element inside engines, following the format of the others. For your app_id information, engine_name can be used to associate a game with a particular engine.
-
Make sure to add the engine metadata as well as the game information.
-
Once done with the new package, create a new pull request. Each pull request should only have one engine.
A steam_input_template.vdf
can be provided in the engine assets, where the client expects it to be in the directory of the game before launching. This will then be imported to steam, where it can be found in the Search section, like below.
Further details about creating the template can be found here: https://www.steamcontrollerdb.com/home/about/