This is a fork of OpenStarbound; all credit for the original code goes to the respective authors. Contributions are welcomed. You must own a copy of Starbound to use xStarbound. Base game assets are not provided for obvious reasons.
Compiled builds for Linux and Windows should be available in the usual place on this repository.
-
Several new commands (by @fezzedone)! Type
/xclient
for info on the new client-side commands, or/help
(on xServer, an xClient host or in single-player on xClient) to see the new server-side ones. -
Nicer (and optimised) non-pixelated humanoid tech and status effect scaling for players and NPCs (reimplementation by @fezzedone).
-
Now runs Pluto, a fork of Lua 5.4!
-
Full Lua sandboxing when
"safeScripts"
is enabled! By @fezzedone.- To replace the old, potentially crash-prone sandbox-breaking code used by certain mods, new Lua callbacks for safely saving and reading variables in global variable tables with the same expected cross-context scopes.
- Note: This causes some mod compatibility issues; see below for affected mods.
-
Full, up-to-date Lua API documentation. (Aside from a lot of engine calls into Lua scripts.)
-
Support for underlaying and overlaying cosmetic items, by @fezzedone. Two types of layering are supported:
- Underlays: You can right-click an item in any armour or inventory slot to underlay it below any item in the associated cosmetic slot. Underlaid items have a red border by default. For instance, you can layer a wig under a hat by putting the hat in the cosmetic slot, the wig in the armour slot and right-clicking the wig. Underlaid armour grants its usual effects; note that particle effects associated with an underlaid item as
"effectSources"
won't spawn, even if the underlaid item is visible. Underlaid items are indicated with a red border. - Overlays: You can right-click while holding Shift with an armour or clothing item in your swap slot to stack and overlay it onto another armour or clothing item of the same slot type in your armour slots or inventory — you can stack as many items as you want! To remove or «pop» the topmost item from an overlay stack, Shift + Right Click with an empty swap slot — you'll see the «popped» item in your swap slot. Items are layered in the order they are stacked, with the lowest-layered item (aside from underlays) being the base item shown in the tooltip. Stacked cosmetic items have a red stack count indicator, and their tooltip preview shows what the entire stack looks like on your player. Overlaid cosmetic items do not give players any additional game effects or spawn particles — they are purely cosmetic.
Underlaid items can have overlays. This client feature is compatible with vanilla multiplayer, but other players must have xClient to see your underlays and overlays.
- Underlays: You can right-click an item in any armour or inventory slot to underlay it below any item in the associated cosmetic slot. Underlaid items have a red border by default. For instance, you can layer a wig under a hat by putting the hat in the cosmetic slot, the wig in the armour slot and right-clicking the wig. Underlaid armour grants its usual effects; note that particle effects associated with an underlaid item as
-
Control multiple characters on a single client! Is fully multiplayer-compatible. By @fezzedone. Replaces OpenStarbound's character swapping feature.
/add
and/adduuid
: Loads and adds a player character from your saves./swap
and/swapuuid
: Swaps to a different character. If the character isn't loaded, replaces your current character./remove
and/removeuuid
: Removes a character you're not currently controlling.- There are some game balance restrictions — dead characters won't respawn until you beam to your ship. The restrictions can be disabled via the Lua API on a per-character basis.
-
xStarbound now has OpenStarbound's world file flattening and bloat fixes! By @novaenia.
-
xStarbound automatically repacks shipworld and celestial world files when loading them, saving you quite a bit of disk space and, for xClient, reducing server lag caused by shipworlds. By @fezzedone.
- Shipworld repacking is client-side; celestial world repacking is server-side.
- Disable this automatic repacking by adding
"disableRepacking": true
toxclient.config
orxserver.config
.
-
Additional Lua callbacks to make player characters fully scriptable, just like NPCs!
-
The UI scale can now be adjusted in the graphics settings dialogue, complete with configurable keybinds and support for fractional scales (@fezzedone). There are also keybinds for changing the in-game camera zoom (@novaenia). Both the UI scale and zoom level are scriptable (@fezzedone). UI scaling mods are no longer needed (and in fact no longer do anything) in xStarbound!
-
Chat message history is now saved to
messages.json
in your storage directory instead of being reset on every disconnection. Use the new/clear
command on xClient to clear the chat history instead. -
Inventory and action bar expansion (or reduction) mods are now fully compatible with vanilla multiplayer with no changes needed on the mod's part. Additionally, these mods can now be safely added or removed without item loss or crashes as long as characters are loaded in xStarbound. Added by @WasabiRaptor and @fezzedone.
- Loading a character after changes to inventory or action bar mods will drop any items that no longer fit on the ground beside the player (which will be picked up if there still is inventory space), instead of showing an error dialogue.
- Warning for users of vanilla clients and other client mods: If you load any characters that have their inventories resized but haven't yet dropped overflowed items on a non-xStarbound client — this can happen if you open xStarbound after changing mods, but don't actually load some characters before switching to another client — you may lose items, so load your characters in xStarbound and save your items first!
- The networked inventory and action bar config can be configured separately with a patch to
$assets/player.config
; see$src/assets/xSBassets/player.config.patch
for the new parameters. Such a patch mod is required for an xClient client to join a non-xServer server with inventory or action bar mods installed, but allows joining the server with mismatched mods (assuming mismatched assets are allowed).
-
Anything that the game converts to a Perfectly Generic Item now has its parameters saved in the item and will be restored once any missing mods are reinstalled (@WasabiRaptor and @fezzedone). Requires xServer (or xClient on the host) for server-side items (such as those in containers on worlds, even shipworlds!) and xClient for single-player and client-side items (those in the player's inventory).
-
Supports scriptable asset preprocessing. By @novaenia; fixed and greatly enhanced by @fezzedone.
-
Modded techs and status effects no longer cause crashes to the menu when the offending mod is removed (@WasabiRaptor and @novaenia).
-
Scriptable shader and lighting parameters are supported (@fezzedone).
-
You can now make
.patch
files that are just merged in, early-beta-style (@novaenia). That's why the patch files inassets/xSBassets
are unusually simple. All of OpenStarbound's JSON patch parameters are also supported. -
Almost all Lua callbacks from the original xSB (by @fezzedone),
input
callbacks (by @novaenia), plus some extraplayer
,chat
,interface
andclipboard
callbacks for compatibility with OpenStarbound mods and some StarExtensions mods (@fezzedone). -
Various crash fixes (@fezzedone and @novaenia).
-
Custom user input support with a keybindings menu (rewrite by @novaenia from StarExtensions).
-
Client-side positional voice chat that works on completely vanilla servers; is compatible with StarExtensions. This uses Opus for crisp, HD audios. Rewrite by @novaenia from StarExtensions.
- The voice chat configuration dialogue is made available in the options menu rather than as a chat command.
- Extra voice chat options, including persistent saved mutes, are available with the
/voice
command (@fezzedone).
-
Multiple font support (switch fonts inline with
^font=name;
,.ttf
assets are auto-detected). Added by @novaenia, fixed by @fezzedone. Additionally, escape codes and custom fonts wrap and propagate across wrapped lines properly in the chat box (@fezzedone). -
Lighting is partially asynchronous (@novaenia).
-
Various changes to the storage of directives and images in memory to greatly reduce their impact on FPS (@novaenia).
-
Client-side tile placement prediction (rewrite by @novaenia from StarExtensions).
- You can also resize the placement area of tiles on the fly.
-
Client- and server-side support for placing foreground tiles with a custom collision type (rewrite by @novaenia from StarExtensions; requires xServer or xClient on the host). Compatible with the overground placement feature of StarExtensions and OpenStarbound clients. xWEdit, a fork of WEdit with support for these features, is available; xWEdit requires xClient for full client-side functionality, but partially works with OpenStarbound clients (not StarExtensions!).
- Additionally, objects can be placed under non-solid foreground tiles (@novaenia).
-
Support for placing tiles in mid-air, not connected to existing ones, via an extra argument to
world.placeMaterial()
(requires both xClient and, in multiplayer, xServer/xClient on the host). By @fezzedone. -
Some polish to UI (@fezzedone and @novaenia).
-
Terraria-like placement animations for objects, tiles and liquids (@fezzedone). Can be disabled with an asset mod if you don't like them.
-
Added Wayland support (@emanueljg).
-
Nix build & install support (emanueljg). See Nix.
Read this to see if xStarbound is compatible with your mods.
Has xStarbound support: The following mods have special functionality that requires or is supported by xStarbound.
- Actionbar Group Scrolling — fully supported by xStarbound.
- Cheap As Dirt — currently fully supported by xStarbound, but due to stupidity, don't expect this to last.
- Drop pixels on death (GitHub) — fully supported by xStarbound.
- Dump IDs to log (GitHub) — Fully supported by xStarbound as of v3.1.5r1.
- Enterable Fore Block — fully supported by xStarbound.
- FezzedTech (GitHub) — requires xStarbound for full functionality, but also supports StarExtensions (with reduced functionality) and is compatible with vanilla Starbound. Is not compatible with OpenStarbound.
- Matter Manipulator Keybinds (GitHub) — fully supported by xStarbound as of v3.1.6.
- More Action Bar Binds — fully supported by xStarbound.
- Planet Search — fully supported by xStarbound.
- Quick Commands! — all OpenStarbound-compatible commands are supported by xStarbound as of v3.1.6.
- Ruler — fully supported by xStarbound, including keybinds, as of v3.1.6. (Bravo for getting rid of the sandbox-breaking code, Patman!)
- Save Inventory Position (GitHub) — fully supported by xStarbound as of v3.1.6; requires
"safeScripts"
to be enabled. - Scanner Shows Printability — fully supported by xStarbound as of v2.3.7.
- Size of Life - Framework, Size of Life - Vanilla Species and other mods based on the framework — xStarbound supports «nice» non-pixelated scaling as of v2.4.1.1.
- Spawnable Item Pack — SIP's universal mod support requires xStarbound v2.5+ or OpenStarbound.
- Tech Loadout Binds — fully supported by xStarbound.
- Time Control Command (GitHub) — fully supported by xStarbound.
- Universal Instant Crafting for All Mods — As of v2.5, fully supported by xStarbound.
- xSIP — xSIP's universal mod support requires xStarbound v2.5+ or OpenStarbound.
- xWEdit — this WEdit fork requires xStarbound for full functionality, but is partially supported by OpenStarbound (no mid-air tile placement) and compatible with vanilla Starbound (with no extra functionality above WEdit).
- Mods that change the size or number of bags in the inventory or hotbar — as of v2.4, xStarbound gives these mods full compatibility with vanilla multiplayer and existing characters «out of the box».
Compatible: Any mod not listed in the «partially compatible» or «not compatible» category should be compatible. Major mods that have been tested to be compatible:
- Arcana — use Quickbar Mini to satisfy this mod's «Stardust Core Lite» dependency (see that mod below for why).
- Avali (Triage) Race Mod.
- Elithian Races Mod.
- Frackin' Universe (GitHub).
- Infinite Inventory — the keybind is not supported by xStarbound solely due to an explicit StarExtensions check.
- Maple32.
- Quickbar Mini. Note that the Classic Quickbar extension (see below) has sandbox-related compatibility issues!
- Shellguard: Starbound Expansion Remastered.
- Updated Quickbar Mini — use this instead of Classic Quickbar (see below) to avoid having to disable
"safeScripts"
.
Note: xStarbound does not and will not support StarExtensions' «body dynamics» and text-to-speech features, and currently doesn't support StarExtensions' species-specific head rotation parameters. Details:
- Armour, clothing and race mods with included SE «body dynamics» support are compatible, but the «non-jiggle» sprites will be displayed.
- Race and race-modifying mods with StarExtensions head rotation parameters, such as Nekify, may have visual sprite glitches — such as Neki ears being clipped off — while xStarbound's head rotation is enabled.
- Mods intended to patch in «body dynamics» support or StarExtensions-specific head rotation parameters for other mods simply will not work at all.
- Race mods that support StarExtensions' text-to-speech feature will work just fine, but the text-to-speech functionality won't work.
Partially compatible: The following mods are only partially compatible with xStarbound:
- 1x UI scaling — won't do anything and is redundant.
- 3x UI scaling — ditto.
- 4x UI scaling — ditto.
- Bottinator22's mods — these have issues with xStarbound's Lua sandbox. You'll probably have to disable
"safeScripts"
inxclient.config
if you use any of these mods. - Classic Quickbar (GitHub) — not compatible with xStarbound's Lua sandbox. You must disable
"safeScripts"
in yourxclient.config
to use this mod. The keybind is supported by xStarbound. - Digital Storage — the server-side scripts are not compatible with xStarbound's Lua sandbox. To use this mod, you must disable
"safeScripts"
server-side — in yourxclient.config
in single-player, or in the host'sxclient.config
or server'sxserver.config
. - Optimizebound and its two counterparts — their PNG compression does not play well with xClient's hardware cursor, potentially making it invisible. Use
/cursor off
if you want to use these mods. - Project Knightfall (GitHub) — some added UIs have minor issues with xStarbound's Lua sandbox.
- Русификатор Zoom Keybinds — technically fully compatible, but the mod it patches isn't compatible anyway.
- Stardust Core and Stardust Core Lite (GitHub) — the server-side scripts may not be compatible with xStarbound's Lua sandbox. Either disable
"safeScripts"
or use Quickbar Mini instead. - Stardust Suite (GitHub) — Ditto.
- Starloader (GitHub) — fully compatible as long as
"safeScripts"
is disabled in yourxclient.config
(but be careful with that!). - Unitilities | Lua Modding Library — the Hasibound-specific functionality is not supported by xStarbound.
- WTM (WTM Teleporter Mod) — the server-side scripts are likely not compatible with xStarbound's Lua sandbox. To use this mod, you may need to disable
"safeScripts"
server-side — on yourxclient.config
in single-player, or in the host'sxclient.config
or server'sxserver.config
. - Other UI scaling mods — these won't do anything and are redundant. Mods that do other stuff besides scaling the UI should work.
Not compatible: The following mods are NOT compatible with xStarbound:
- boner guy — would work if it didn't have an explicit StarExtensions check.
- Futara's Dragon Engine — causes severe server- and client-side entity lag on xStarbound. Use
- Futara's Dragon Race — due to poor coding in this mod, it causes a whole bunch of errors on xStarbound. Also depends on Futara's Dragon Engine and thus inherits its severe lag issue.
- Limited Lives — no longer compatible with xStarbound for stupid reasons. No compatibility patch is planned.
- Remote Module — won't work and is likely to log script errors.
- StarCustomChat — not fully compatible with xStarbound's callbacks and has serious issues with xStarbound's Lua sandbox anyway.
- StarExtensions — won't load on xClient and may cause crashes! However, xServer fully supports the server-side part of SE's «overground» tile placement feature.
- Text to Speech Droids — won't do anything.
- Zoom Keybinds — will log script errors (xStarbound has differently named callbacks) and is redundant anyway because xStarbound already fully supports this feature.
- Mods that patch in StarExtensions «body dynamics» support for other mods. These won't do anything.
This repository is already set up for easy building (mostly @kblaschke's work, with an updated Windows build script and some additional fixes by @fezzedone). Follow the appropriate instructions for your OS if listed; if your OS isn't listed, adjustments generally shouldn't be too complex.
On Linux, the xStarbound binaries are by default built against the system libraries. To build xStarbound on any reasonably up-to-date Linux install (assuming bash
or zsh
):
Wayland should work OOTB if you're using the xclient.sh
. If you're running the binary yourself, you can enable this support yourself with SDL_VIDEODRIVER="wayland"
.
- If you're on SteamOS, run
sudo steamos-readonly disable
. - Make sure you have GCC installed; it should come preinstalled on most distros. If not, install your distribution's «base development» package.
- Install CMake, Git and the required build libraries for xStarbound:
- Arch-based distros (CachyOS, Endeavour, etc.):
sudo pacman -S clang cmake git ninja mesa libx11 glu libxcb libxrender libxi libxkbcommon libxkbcommon-x11 egl-wayland qt6-svg qt6-base sdl2 libpng freetype2 libvorbis opus glew
(you may need to-Syu
first) - RPM/
dnf
-based distros:sudo dnf install gcc-c++ clang cmake git ninja-build mesa-libGLU libXrender libXi libxkbcommon egl-wayland qt6-qtbase qt6-qtsvg SDL2-devel libpng-devel freetype-devel libvorbis-devel opus-devel glew-devel
(yes, Fedora doesn't come with a C++ compiler preinstalled!) - Debian/
apt
-based distros:sudo apt install clang cmake git ninja-build build-essential libgl1-mesa-dev libglu1-mesa-dev mesa-common-dev libx11-xcb-dev libglu1-mesa-dev libxrender-dev libxi-dev libxkbcommon-dev libxkbcommon-x11-dev libegl1-mesa-dev qt6-base qt6-svg libsdl2-dev libpng-dev libfreetype6-dev libvorbis-dev libopus-dev libglew-dev
- Gentoo:
sudo emerge -a sys-devel/clang dev-vcs/git dev-build/cmake dev-build/ninja media-libs/mesa virtual/glu x11-misc/xcb x11-libs/libGLw x11-libs/libXrender x11-libs/libXi x11-libs/libxkbcommon gui-libs/egl-wayland media-libs/libsdl2 dev-qt/qtbase dev-qt/qtsvg media-libs/freetype media-libs/libvorbis media-libs/libpng media-libs/opus media-libs/glew
- SteamOS:
sudo steamos-readonly disable; sudo pacman -Syu clang cmake git ninja mesa libx11 glu libxcb libxrender libxi libxkbcommon libxkbcommon-x11 egl-wayland qt6-svg qt6-base sdl2 libpng freetype2 libvorbis opus; sudo steamos-readonly enable
- Arch-based distros (CachyOS, Endeavour, etc.):
git clone --recursive https://github.com/xStarbound/xStarbound.git
(--recursive
is needed to clone the Opus sources in$src/extern/opus
, which may be necessary on some configurations)cd xStarbound/
CC=/usr/bin/clang CXX=/usr/bin/clang++ cmake -DCMAKE_BUILD_TYPE=Release -DSTAR_ENABLE_STEAM_INTEGRATION=ON -DPACKAGE_XSB_ASSETS=ON -S . -B build/ -G Ninja
(Clang is recommended now, but you can usegcc
andg++
instead for GCC)cmake --build build/
cmake --install build/ --prefix ${sbInstall}/
(replace${sbInstall}
with the path to your Starbound install)cp scripts/linux/{xclient,xserver,mod_uploader}.sh ${sbInstall}/linux/
- Run
./xclient.sh
to play or./xserver.sh
to host the server! Optionally configure Steam or your other launcher to launch${sbInstall}/linux/xclient.sh
.
Important: If you're getting library linking errors while attempting to build or run xStarbound (this is likely on Debian-based distros, Slackware and CentOS due to their older libraries) or your distro is old enough to still use
yum
orapt-get
, you'll need to either build a statically linked version of xStarbound (see below), figure out how to build xStarbound against the Steam runtime (hint: update the runtime's CMake somehow!) or find a way to update your system libraries.
To build a statically linked version of xStarbound (assuming bash
or zsh
):
Important: It is highly recommended you use an older LTS distribution such as Debian 11 or 12, or Ubuntu 20.x or 22.x, in order to guarantee portability. You can use a Docker, Toolbox or Podman container for this. If the chosen distro does not have CMake 3.25+ available in its repositories, download the latest
tar.gz
archive from CMake's website, extract it somewhere, and add itsbin/
directory to your$PATH
instead of installing it via the package manager.
- If you're on SteamOS, run
sudo steamos-readonly disable
. - Make sure you have GCC installed; it should come preinstalled on most distros. If not, install your distribution's «base development» package.
- Install CMake, Git and the required build libraries for xStarbound:
- Arch-based distros (CachyOS, Endeavour, etc.):
sudo pacman -S clang cmake git ninja patchelf mesa libx11 glu libxcb libxrender libxi libxkbcommon libxkbcommon-x11 egl-wayland
(you may need to-Syu
first) - RPM/
dnf
-based distros:sudo dnf install gcc-c++ clang cmake git ninja-build patchelf mesa-libGLU libXrender libXi libxkbcommon egl-wayland xcb* libX11-xcb
(yes, Fedora doesn't come with a compiler preinstalled!) - Debian/
apt
-based distros:sudo apt install clang cmake git ninja-build patchelf build-essential libgl1-mesa-dev libglu1-mesa-dev mesa-common-dev libx11-xcb-dev libglu1-mesa-dev libxrender-dev libxi-dev libxkbcommon-dev libxkbcommon-x11-dev libegl1-mesa-dev libxcb-*
- Gentoo:
sudo emerge -a sys-devel/clang dev-vcs/git dev-build/cmake dev-build/ninja dev-util/patchelf media-libs/mesa virtual/glu x11-misc/xcb x11-libs/libGLw x11-libs/libXrender x11-libs/libXi x11-libs/libxkbcommon gui-libs/egl-wayland
- SteamOS:
sudo steamos-readonly disable; sudo pacman -Syu clang cmake git ninja patchelf mesa libx11 glu libxcb libxrender libxi libxkbcommon libxkbcommon-x11 egl-wayland; sudo steamos-readonly enable
- Arch-based distros (CachyOS, Endeavour, etc.):
mkdir -p ~/.local/opt; git clone https://github.com/microsoft/vcpkg.git ~/.local/opt/vcpkg
cd ~/.local/opt/vcpkg; ./bootstrap-vcpkg.sh -disableMetrics
(yes, VCPKG sends telemetry by default)cd $devDirectory
(where$devDirectory
is the folder you want to put the xStarbound source in)git clone --recursive https://github.com/xStarbound/xStarbound.git
(--recursive
is needed to clone the Opus sources in$src/extern/opus
, which may be necessary on some configurations)cd xStarbound/; export VCPKG_ROOT="${HOME}/.local/opt/vcpkg"; export PATH="${VCPKG_ROOT}:${PATH}"
CC=/usr/bin/clang CXX=/usr/bin/clang++ cmake --build cmake-build-linux-x86_64/ --preset "linux-vcpkg-x86_64-release" -G Ninja
(Clang is recommended on up-to-date distros; GCC —gcc
andg++
— on less up-to-date ones)cmake --build build/
cmake --install build/ --prefix ${sbInstall}/
(replace${sbInstall}
with the path to your Starbound install)cp scripts/linux/{xclient-static,xserver,mod_uploader}.sh ${sbInstall}/linux/
mv ${sbInstall}/linux/xclient-static.sh ${sbInstall}/linux/xclient.sh
- Optionally configure Steam or your other launcher to launch
${sbInstall}/xsb-linux/xclient.sh
.
See $xsbSrc/nix/README.md
as well as the nix/
directory.
To build and install xStarbound on Windows 10 or 11:
- Download and install Visual Studio 2022 and CMake. For Visual Studio, make sure to install C++ support (and optionally the game dev stuff) when the VS installer asks you what to install. For CMake, make sure you download and use the
.msi
installer for 64-bit Windows. - Install Git; the build script requires Git. On the «Adjusting your PATH environment» page of the installation wizard, make sure to select the second option1, which the wizard recommends anyway.
- Open up Git Bash and run
git clone https://github.com/xStarbound/xStarbound.git
or download the latest xStarbound source ZIP archive and extract it somewhere. - Go into
scripts\windows\
and double-clickbuild.bat
. CMake and VCPKG will take care of the entire build process. - If the build succeeds, you will be prompted to select your Starbound install directory.
- Optionally configure Steam, GoG or MultiBound2 to launch
xsb-win64\xclient.exe
.
Building on older Windows versions: Building on earlier versions of Windows is not recommended, although it should still be possible to build xStarbound on Windows 7, 8 or 8.1 if you can get VS 2022 installed.
The basic process for building on other OSes:
- Install CMake, a C++ compiler toolchain and (optionally) Git.
- On macOS 10.11+, you should use Homebrew to install CMake, Git and the needed build dependencies on your system. Manual installation of dependencies via wizards or drag-and-drop is likely to cause build issues or be a pain to work with.
- If you're targeting older versions of macOS / OS X, look into Tigerbrew. Expect to do more tinkering and/or manual installation of build dependencies.
- Most BSDs and other reasonably up-to-date *nix OSes (like Haiku) should have the necessary packages in their ports system or equivalent. Make sure to disable Steam and Discord integrations.
- For Windows XP or Vista targets, your best bet is to use Visual Studio 2017 or 2019 on a newer version of Windows or on WINE with the
v141_xp
toolchain (it doesn't work on VS 2022!). Make sure to disable Steam and Discord integrations. - Targetting older Windows versions, pre-OSX Mac OS, Android, the Switch or any other niche device or OS is left as an exercise for the reader.
- If you can, install any dependencies needed to build SDL2 and GLEW on your OS. If you can't, hopefully VCPKG runs on your build OS and/or has packages for your target OS. If not, get ready for a lot of tinkering.
- If you're not using Git or don't have it installed, download the latest xStarbound source ZIP, extract it somewhere and go to step 5. Otherwise go to the next step.
- If you're using Git, run
git clone https://github.com/xStarbound/xStarbound.git
in a terminal or command prompt, or use a graphical Git utility to download the repo. - In the xStarbound directory, run
cmake -DCMAKE_BUILD_TYPE=Release -S . -B build/
. On some OSes, you may need to add the full path to your CMake executable to the beginning of the command. If necessary, add-DCMAKE_C_COMPILER=<path to C++ compiler> -DCMAKE_CXX_COMPILER=<path to C++ compiler>
. Note that a CMake build preset already exists for modern macOS; consider using that if you have build issues.
The build system can automatically take care of packaging the additional xSB assets and install the resulting .pak file automatically. To enable asset packing, pass -DPACKAGE_XSB_ASSETS=ON
to the CMake command, e.g. after the --preset
argument. This will create a directory xsb-assets
in the project's main dir, and package the resources in assets/xSBassets
into a packed.pak
file.
It is important to note that automatic packaging will only work if the built binaries (specifically asset_packer[.exe]) run on the host system. If you are cross-compiling, e.g. for a different CPU architecture (building for ARM64 on a x64 OS) or a different OS (building with MinGW on Linux, or with WSL on Windows), this feature cannot be used. In this case, you have to manually package the assets with an asset_packer that runs locally, and copy the resulting file to xsb-assets/packed.pak
before installing the project. Due to how CPack works, this is only feasible when packaging manually from the install dir.
For support, suggestions or just plain old chit-chat, check out the xStarbound Discord server.
Footnotes
-
Linux/WSL nerds can use the third option; xStarbound's build script doesn't depend on the overridden CLI tools. ↩