Warning
This toolkit is a Work In Progress!
If you are using parts of it, beware of sudden major changes to the API, structure, and features.
This currently targets Godot v4.3. The interface should be backwards compatible with 4.2, and may even work with 4.1, but it will not work with v4.0. For a version which works with v4.0
use the dev-4.0-2024-02 release.
The bindings to the C Interface are in ./gdextension/lib.odin
. They're based on godot-cpp/gdextension/gdextension_interface.h
.
Clone & generate bindings
git clone --recursive-submodules -j8 https://github.com/dresswithpockets/odin-godot
cd odin-godot
make bindings
Bindings for all enums, classes, utility functions, singletons, and native structs will be generated in core
, editor
, and variant
.
Note
make bindings
expects odin on path, all submodules updated, and odin-godot (this repo) is the working directory.
Alternatively, you may build and run bindgen
yourself:
# temple is the templating engine used by bindgen, temple_cli is temple's preprocessor.
odin build temple/cli/ -o:speed -out:bin/temple_cli.exe
# temple_cli will recursively search all odin files in the specified directory for
# usages of `compiled` and `compiled_inline`, then it will generate Odin code with
# the built templates in templates.odin, in the specified directory. in this case,
# its searching in the bindgen directory, and outputs to bindgen/templates.odin, with
# the `bindgen` package name.
./bin/temple_cli.exe bindgen bindgen bindgen
# bindgen is the tool which uses the temple templates to generate the entire
# GDExtension binding
odin build bindgen/ -o:speed -out:bin/bindgen.exe
# bindgen requires a path to a json file which describes the GDExtension API.
# One is available in godot-cpp.
./bin/bindgen.exe godot-cpp/gdextension/extension_api.json
See the example godot project for a working usage of these bindings.
Then, follow the instructions for using the extension module.
Godin is a preprocessor which generates most of the boilerplate for Extension Classes, Methods, Enums, Properties, Signals, Groups, and Subgroups.
Warning
Godin is suuuuper work in progress!
Godin doesn't produce correct gdextension useage in its current state, and may not even run in some cases.
For example, the following Odin code will produce all of the boilerplate for an extension class "Player" that extends "Node2D".
package test
//+class Player extends Node2D
Player :: struct {
health: i64,
}
To build Godin:
# while in the odin-godot directory
./build_godin.sh
Run godin help
for usage details, including documentation about the Godin preprocessor syntax.