https://github.com/asmaloney/gdextensiontemplate
๐ A template project for building Godot 4 GDExtensions using CMake
Science Score: 13.0%
This score indicates how likely this project is to be science-related based on various indicators:
-
โCITATION.cff file
-
โcodemeta.json file
Found codemeta.json file -
โ.zenodo.json file
-
โDOI references
-
โAcademic publication links
-
โCommitters with academic emails
-
โInstitutional organization owner
-
โJOSS paper metadata
-
โScientific vocabulary similarity
Low similarity (15.2%) to scientific vocabulary
Keywords
Repository
๐ A template project for building Godot 4 GDExtensions using CMake
Basic Info
Statistics
- Stars: 259
- Watchers: 4
- Forks: 23
- Open Issues: 12
- Releases: 3
Topics
Metadata Files
README.md
GDExtensionTemplate
This project is meant as a starting point for creating new C++/CMake-based Godot 4 extensions. The goal is to lower the barrier to entry to building a GDExtension using CMake.
It is currently set up to work with the Godot 4.2 release (see tags for previous versions).
Since the majority of C++ open source projects use CMake, I wanted to offer an alternative to the scons system for building Godot extensions (if you use scons, check out Nathan Franke's gdextension template or Patrick's GDExtensionSummator template).
Note: This project is not meant to be a dependency. It is intended to be copied (not forked) and made into your own project. Git itself doesn't provide a nice way to do this (as far as I can tell), but GitHub provides a Use this template button (beside where you clone a repo). This will create a copy for you without all the history.
Features
This template project sets up a lot of the build details so you can get started and focus on your code:
- includes godot-cpp as a submodule and links it statically to your shared library
- creates
<project>.gdextensionfiles based on your project name - copies over any support files from the
support_filesdirectory into your extension directory - includes example of adding custom icons to your classes/nodes (see below)
- automatically generates a Version.h header file which:
- includes a preprocessor macro for conditional compilation
cpp #if GDEXTENSIONTEMPLATE_VERSION < GDEXTENSIONTEMPLATE_VERSION_CHECK(2, 1, 0) // do stuff #endif - includes git information in the version strings (e.g.
GDExtensionTemplate v1.0.1-gf6446f8) - includes an example which exposes the version string to GDScript so you can call it like this
py print( GDExtensionTemplate.version() ) - keeps itself up-to-date when the git branch/tag/HEAD changes
- includes a preprocessor macro for conditional compilation
- uses ccache (if available) for faster rebuilds
- builds universal library (x86_64 and arm64) on macOS
- provides cmake targets:
- install: install all files with the correct structure to
CMAKE_INSTALL_PREFIX - clang-format: runs
clang-formaton all sources
- install: install all files with the correct structure to
- includes GitHub workflows (CI) for:
- building the extension on Linux x86_64 (gcc), macOS universal (clang), and Windows x86_64 (MSVC)
- generating debug & release packages on each commit
- using
ccacheto improve CI build times when available - checking code formatting using
clang-format
Prerequisites
To use this locally on your machine, you will need the following:
- CMake v3.22+
- C++ Compiler with at least C++17 support (any recent compiler)
- (optional) ccache for faster rebuilds
- (optional) clang-format for linting and automatic code formatting (CI uses clang-format version 15)
The GitHub actions (CI) are set up to include all of these tools. To see how to download them on your platform, take a look at the workflow file.
How To Use
Setup
To use this for your own project:
- copy this repository and rename the directory to the name of your extension > GitHub provides a Use this template button (beside where you clone a repo). This will create a copy for you without all the history.
- in CMakeLists.txt, change
GDExtensionTemplatein theprojectmacro to the name of your extensioncmake project( <your_extension_name_here> LANGUAGES CXX VERSION 0.1.0 )If you also have plain C files in your project, addCto the languages. - replace the example code in
srcwith your own (I would suggest keeping RegisterExtension.cpp and using it to register your classes) > Note: If you change the entry symbol (GDExtensionInit) in RegisterExtension.cpp, you will need to update yourtemplates/*.gdextension.infiles. - replace
CHANGELOG.mdwith your own (I would encourage adhering to Semantic Versioning and the use of Keep a Changelog ) - replace this
README.mdwith your own - replace custom node icon (see below)
Optional:
- contribute to the project (it's not just ๐ฐ!)
- change the platforms/architectures you want to support:
- edit the gdextension templates (
templates/*.gdextension.in) - change the GitHub workflows to build the right stuff
- edit the gdextension templates (
- change the
.clang-formatconfig file to fit your C++ style (option documentation) - change the compiler warnings you want to enforce (see CompilerWarnings.cmake)
- change the LICENSE
Custom Node Icons
I have included a custom icon for the Example node (icon is CC0 from SVGRepo), so you will want to remove or modify it for your own classes/nodes.
The icon itself is in support_files/icons it is referenced in the templates/*.gdextension.in files.
To add an icon for your custom node:
- add the icon file to
support_files/iconsand name it after your node (e.g.MyNode.svg) - in each of the
templates/*.gdextension.infiles add an entry for your node in the[icons]section:MyNode = "icons/MyNode.svg"
Everything in the support_files directory is copied into your extension, so if you don't want to use icons, remove that directory and remove the [icons] section from the templates/*.gdextension.in files.
Build & Install
Here's an example of how to build & install a release version (use the terminal to run the following commands in the parent directory of this repo):
Not MSVC
sh
$ cmake -B GDExtensionTemplate-build -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=GDExtensionTemplate-install GDExtensionTemplate
$ cmake --build GDExtensionTemplate-build --parallel
$ cmake --install GDExtensionTemplate-build
MSVC
sh
$ cmake -B GDExtensionTemplate-build -G"Visual Studio 17 2022" -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=GDExtensionTemplate-install GDExtensionTemplate
$ cmake --build GDExtensionTemplate-build --config Release
$ cmake --install GDExtensionTemplate-build
This tells CMake to use Visual Studio 2022. There is a list of Visual Studio generators on the CMake site - pick the one you are using.
Cmake Options
This template defines the following additional CMake options:
| Option | Description | Default |
| ------------------------------------------------------------------------ | ------------------------------------------------ | ------------------------------------------------------------------------------------------------------- |
| CCACHE_PROGRAM | Path to ccache for faster rebuilds | This is automatically set ON if ccache is found. If you do not want to use it, set this to "". |
| CLANG_FORMAT_PROGRAM | Path to clang-format for code formatting. | This is automatically set ON if clang-format is on. If you do not want to use it, set this to "". |
| ${PROJECT_NAME_UPPERCASE}_WARN_EVERYTHING (e.g. FOOWARNEVERYTHING) | Turns on all warnings. (Not available for MSVC.) | OFF (too noisy, but can be useful sometimes) |
| ${PROJECT_NAME_UPPERCASE}_WARNING_AS_ERROR (e.g. FOOWARNINGAS_ERROR) | Turns warnings into errors. | ON |
Ongoing Updates
Once your project is up and running you might want to keep up with newer versions of Godot & godot-cpp.
The key thing is that the version of godot-cpp must match the version of Godot you are using (see the godot-cpp Versioning section). So if you want to use Godot 4.0 stable, then you need to match that with the correct tag in godot-cpp.
Once you know the correct version of godot-cpp, change the submodule (extern/godot-cpp) in your extension to point at that version.
Updating the submodule and making any necessary changes to your code due to changes in the API are the only things you need to pin to a specific version of Godot.
How To Contribute
These are some of the things you can do to contribute to the project:
โ Write About The Project
If you find the project useful, spread the word! Articles, mastodon posts, tweets, blog posts, instagram photos - whatever you're into.
โญ๏ธ Add a Star
If you found this project useful, please consider starring it! It helps me gauge how useful this project is.
โ Raise Issues
If you run into something which doesn't work as expected, raising an issue with all the relevant information to reproduce it would be helpful.
๐ Bug Fixes & ๐งช New Things
I am happy to review any pull requests. Please keep them as short as possible. Each pull request should be atomic and only address one issue. This helps with the review process.
Note that I will not accept everything, but I welcome discussion. If you are proposing a big change, please raise it as an issue first for discussion.
๐ฐ Financial
Given that I'm an independent developer without funding, financial support is always appreciated. If you would like to support the project financially, you can use GitHub sponsors or Ko-fi for one-off or recurring support. Thank you!
Owner
- Name: Andy Maloney
- Login: asmaloney
- Kind: user
- Location: Canada, Earth, Sol, Oort Cloud
- Website: https://asmaloney.com
- Repositories: 104
- Profile: https://github.com/asmaloney
Software guy & independent researcher. Writer of code & hater of pseudo-"AI".
GitHub Events
Total
- Issues event: 4
- Watch event: 42
- Delete event: 1
- Issue comment event: 3
- Push event: 4
- Fork event: 3
- Create event: 1
Last Year
- Issues event: 4
- Watch event: 42
- Delete event: 1
- Issue comment event: 3
- Push event: 4
- Fork event: 3
- Create event: 1
Committers
Last synced: 9 months ago
Top Committers
| Name | Commits | |
|---|---|---|
| Andy Maloney | a****y@g****m | 85 |
| Elias Steurer | i@k****t | 1 |
| Alex Drozd | 3****2 | 1 |
Committer Domains (Top 20 + Academic)
Issues and Pull Requests
Last synced: 9 months ago
All Time
- Total issues: 21
- Total pull requests: 52
- Average time to close issues: 2 months
- Average time to close pull requests: about 13 hours
- Total issue authors: 14
- Total pull request authors: 3
- Average comments per issue: 2.62
- Average comments per pull request: 0.19
- Merged pull requests: 52
- Bot issues: 0
- Bot pull requests: 0
Past Year
- Issues: 4
- Pull requests: 0
- Average time to close issues: 7 minutes
- Average time to close pull requests: N/A
- Issue authors: 4
- Pull request authors: 0
- Average comments per issue: 1.25
- Average comments per pull request: 0
- Merged pull requests: 0
- Bot issues: 0
- Bot pull requests: 0
Top Authors
Issue Authors
- asmaloney (6)
- oparisy (3)
- The0Dev (1)
- RafaDdS (1)
- smbanasik (1)
- sava41 (1)
- Painthingy (1)
- Sythelux (1)
- ahrbe1 (1)
- rutexd (1)
- svdragster (1)
- Aversiac (1)
- athyfr (1)
- BrianWiz (1)
- Medie1 (1)
Pull Request Authors
- asmaloney (48)
- kelteseth (1)
- brno32 (1)
Top Labels
Issue Labels
Pull Request Labels
Dependencies
- actions/cache v3 composite
- actions/checkout v3 composite
- actions/upload-artifact v3 composite
- conda-incubator/setup-miniconda v2 composite
- ilammy/msvc-dev-cmd v1 composite
- jidicula/clang-format-action v4.9.0 composite