Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hxdefold/hxdefold
Haxe/Lua externs for Defold game engine
https://github.com/hxdefold/hxdefold
defold-game-engine haxe lua lua-externs
Last synced: 4 days ago
JSON representation
Haxe/Lua externs for Defold game engine
- Host: GitHub
- URL: https://github.com/hxdefold/hxdefold
- Owner: hxdefold
- License: mit
- Created: 2016-06-05T22:17:23.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2024-05-14T08:38:24.000Z (9 months ago)
- Last Synced: 2025-01-15T05:33:27.687Z (11 days ago)
- Topics: defold-game-engine, haxe, lua, lua-externs
- Language: Haxe
- Size: 799 KB
- Stars: 209
- Watchers: 18
- Forks: 18
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome-haxe-gamedev - hxdefold - Haxe/Lua externs for Defold game engine (`Web`, `Mobile`, `Desktop`). (Game engines)
- awesome-defold - hxDefold
README
![image](https://cloud.githubusercontent.com/assets/576184/15849567/80f4ada8-2c93-11e6-8430-5b5dbe5e58a3.png)
# Haxe support library for the [Defold](https://www.defold.com/) game engine
![Defold API version: 1.6.4](https://img.shields.io/badge/api%20version-1.6.4-orange.svg)
This library allows writing beautiful [Haxe](https://haxe.org/) code for the [Defold](https://www.defold.com/) game engine \o/
## Features
- Fully typed Defold API with proper compile-time errors and IDE services.
- Type-safe game object messages and properties with zero overhead.
- Strengths of Haxe without compromises: powerful type system, meta-programming, static optimizations, dead code elimination and cross-target code sharing.
- Defold hot reloading is now supported!## Quick start
(assuming you already [installed Haxe](https://haxe.org/download/)😊)
- Install this library:
- From this repo: `haxelib git hxdefold https://github.com/hxdefold/hxdefold`
- Or from [lib.haxe.org](https://lib.haxe.org/): `haxelib install hxdefold`
- Run `haxelib run hxdefold init` inside your Defold project. It will create a sample `Hello.hx` script component class and a `build.hxml` for building it.
- Read the comments in these files to quickly get some idea.
- Build with `haxe build.hxml` to get the lua output.
- Add `Hello.script` to your game object in the editor and observe the greeting in the debug console.
- Proceed with writing well-structured, expressive and type safe code for your Defold game.## How does it look like
```haxe
import defold.support.Script;// component class that defines the callback methods
// after compiling Haxe, the `Hello.script` will appear in the Defold project that can be attached to game objects
class Hello extends Script {// fields with @property annotation will show up in the editor
@property var power:Int = 9000;// the `init` callback method
override function init() {
trace('Haxe is over ${power}!'); // will be printed to the debug console
}// the `update` callback method
override function update(dt:Float) {}
}
```## Documentation
Here is the [API reference](http://hxdefold.github.io/hxdefold/).
Migration to v2 is documented in the [v2 pull request](https://github.com/hxdefold/hxdefold/pull/37).
Details about usage can be found on [the wiki](https://github.com/hxdefold/hxdefold/wiki).
And here are some example Defold projects, ported from Lua:
* https://github.com/hxdefold/hxdefold-bunnymark## How does it work?
Since version 3.4, Haxe supports compiling to Lua, making it possible to use Haxe with Lua-based engines, such as Defold.
However, this requires a bit of autogenerated glue code, because Defold expects scripts to be in separate files, while Haxe compiles everything in a single lua module. So what we do, is generate a simple glue `.script` file for each class extending the magic `defold.support.Script` base class (there are also `GuiScript` and `RenderScript`).
For example, for the `Hello` script from this README, this glue code is generated in the `Hello.script` file:
```lua
-- Generated by Haxe, DO NOT EDIT (original source: src/Hello.hx:11: lines 11-16)go.property("power", 9000)
require "main"
function init(self)
_hxdefold_.Hello_init(self)
end
```You can then add this script to the game objects in the Defold Editor.
## Versions
- **Major** number will be incremented for significant reworks that are certainly forward-breaking.
- **Minor** number will be incremented when updating to a new Defold API version. These updates may come with forward-breaking changes.
- **Patch** version will be incremented for bug fixes and potentially backwards-breaking changes.Note that this is not standard [semver](https://semver.org/), since we might potentially ship backwards-breaking changes that increment only the patch number.
| hxdefold | Haxe | Defold API |
|:--------:|:----:|:----------:|
| 2.0.* | 4.3 | 1.6.4 |## Logo
Made by the awesome [**@markknol**](https://github.com/markknol). Check out [his website](https://blog.stroep.nl/) for more art&code!