This is an early-stage library to bind the Rust language to Godot 4.
Godot is an open-source game engine, whose upcoming version 4.0 brings several improvements. Its GDExtension API allows integrating third-party languages and libraries.
Note: if you are looking for a Rust binding for GDNative (Godot 3), checkout
gdnative
.
Warning: this library is experimental and rapidly evolving. In particular, this means:
- Lots of bugs. A lot of the scaffolding is still being ironed out. There are known safety issues, possible undefined behavior as well as other potential problems.
- Lots of missing features. The priority is to get basic interactions working; as such, edge case APIs are deliberately neglected at this stage.
- No stability guarantees. APIs will break frequently (for releases, we try to take SemVer seriously though). Resolving the above two points has currently more weight than a stable API.
We do not recommend building a larger project in GDExtension-Rust yet. However, the library can serve as a playground for experimenting.
To get an overview of currently supported features, consult #24.
At this point, there is no support for Android, iOS or WASM. Contributions are very welcome!
You need to have LLVM installed to use bindgen
, see the book for instructions.
To find a version of Godot 4, the library expects either an executable of name godot4
in the PATH, or an environment variable GODOT4_BIN
containing the path to the executable (including filename).
We currently only have a GitHub version, crates.io releases are planned once more of the foundation is ready.
In your Cargo.toml, add:
[dependencies]
godot = { git = "https://github.com/godot-rust/gdextension", branch = "master" }
To get the latest changes, you can regularly run a cargo update
(possibly breaking). Keep your Cargo.lock
file under version control, so that it's easy to revert updates.
To register the GDExtension library with Godot, you need to create two files relative to your Godot project folder:
-
First, add
res://MyExt.gdextension
, which is the equivalent of.gdnlib
for GDNative.The
[configuration]
section should be copied as-is.
The[libraries]
section should be updated to match the paths of your dynamic Rust libraries.[configuration] entry_symbol = "gdextension_rust_init" [libraries] linux.64 = "res://../rust/target/debug/lib{my_ext}.so" windows.64 = "res://../rust/target/debug/{my_ext}.dll" macos.64 = "res://../rust/target/debug/{my_ext}.dylib"
-
A second file
res://.godot/extension_list.cfg
should be generated once you open the Godot editor for the first time. If not, you can also manually create it, simply containing the Godot path to your.gdextension
file:res://MyExt.gdextension
We highly recommend to have a look at a working example in the examples/dodge-the-creeps
directory.
This integrates a small game with Godot and has all the necessary steps set up.
API documentation can be generated locally using cargo doc -p godot --no-deps --open
.
If you need help, join our Discord server and ask in the #help-gdextension
channel!
We use the Mozilla Public License 2.0. MPL tries to find a balance between permissive (MIT, Apache, Zlib) and copyleft licenses (GPL, LGPL).
The license provides a lot of freedom: you can use the library commercially and keep your own code closed-source, i.e. game development is not restricted. The main condition is that if you change godot-rust itself, you need to make those changes available (and only those, no surrounding code).
At this stage, we appreciate if users experiment with the library, use it in small projects and report issues and bugs they encounter.
If you plan to make bigger contributions, make sure to discuss them in a GitHub issue first. Since the library is evolving quickly, this
avoids that multiple people work on the same thing or implement features in a way that doesn't work with other parts. Also don't hesitate
to talk to the developers in the #gdext-dev
channel on Discord!