Fix interface binding

This commit is contained in:
Fabio Alessandrelli
2018-08-12 16:31:44 +02:00
parent 1885036052
commit 662ceddd51
4 changed files with 22 additions and 4 deletions

View File

@@ -61,12 +61,12 @@ void WebRTCPeer::_register_methods() { }
void WebRTCPeer::_init() {
printf("Binding PacketPeer interface");
godot_net_bind_webrtc_peer(_owner, &interface);
register_interface(&interface);
}
WebRTCPeer::~WebRTCPeer() {
if (_owner) {
printf("Unbinding PacketPeer interface");
godot_net_bind_webrtc_peer(_owner, NULL);
register_interface(NULL);
}
}

View File

@@ -1,7 +1,16 @@
#include <gdnative_api_struct.gen.h>
#include "net/WebRTCPeerNative.hpp"
#include "WebRTCPeer.hpp"
/* Godot export stuff */
extern "C" void GDN_EXPORT godot_gdnative_init(godot_gdnative_init_options *o) {
const godot_gdnative_core_api_struct *api = o->api_struct;
for (int i = 0; i < api->num_extensions; i++) {
if (api->extensions[i]->type == GDNATIVE_EXT_NET) {
WebRTCPeerNative::_net_api = (godot_gdnative_ext_net_api_struct *)api->extensions[i];
}
}
godot::Godot::gdnative_init(o);
}

View File

@@ -1,16 +1,23 @@
#include "WebRTCPeerNative.hpp"
const godot_gdnative_ext_net_api_struct *WebRTCPeerNative::_net_api = NULL;
void WebRTCPeerNative::register_interface(const godot_net_webrtc_peer *p_interface) {
ERR_FAIL_COND(!_net_api);
_net_api->godot_net_bind_webrtc_peer(_owner, p_interface);
}
void WebRTCPeerNative::_register_methods() { }
void WebRTCPeerNative::_init() {
printf("Binding PacketPeer interface");
godot_net_bind_webrtc_peer(_owner, &interface);
register_interface(&interface);
}
WebRTCPeerNative::~WebRTCPeerNative() {
if (_owner) {
printf("Unbinding PacketPeer interface");
godot_net_bind_webrtc_peer(_owner, NULL);
register_interface(NULL);
}
}

View File

@@ -52,8 +52,10 @@ protected:
public:
static void _register_methods();
static const godot_gdnative_ext_net_api_struct *_net_api;
void _init();
void register_interface(const godot_net_webrtc_peer *interface);
virtual void set_write_mode(godot_int mode) = 0;
virtual godot_int get_write_mode() const = 0;