summaryrefslogtreecommitdiff
path: root/src/net/WebRTCPeerNative.cpp
diff options
context:
space:
mode:
authorFabio Alessandrelli <fabio.alessandrelli@gmail.com>2018-08-12 04:18:44 +0200
committerFabio Alessandrelli <fabio.alessandrelli@gmail.com>2018-08-12 04:50:28 +0200
commitb238ad6dad6942fc6a53dfee5d22e12ad8b13df5 (patch)
tree4f7aa168855296b5d6c98c7b273987759d805247 /src/net/WebRTCPeerNative.cpp
parent46f45cc37388b442aa83fab76d26b81cc13bb9ca (diff)
downloadfork-godot-webrtc-native-b238ad6dad6942fc6a53dfee5d22e12ad8b13df5.tar.gz
fork-godot-webrtc-native-b238ad6dad6942fc6a53dfee5d22e12ad8b13df5.tar.bz2
fork-godot-webrtc-native-b238ad6dad6942fc6a53dfee5d22e12ad8b13df5.zip
Add initial interface
Diffstat (limited to 'src/net/WebRTCPeerNative.cpp')
-rw-r--r--src/net/WebRTCPeerNative.cpp72
1 files changed, 72 insertions, 0 deletions
diff --git a/src/net/WebRTCPeerNative.cpp b/src/net/WebRTCPeerNative.cpp
new file mode 100644
index 0000000..62d1040
--- /dev/null
+++ b/src/net/WebRTCPeerNative.cpp
@@ -0,0 +1,72 @@
+#include "WebRTCPeerNative.hpp"
+
+void WebRTCPeerNative::_register_methods() { }
+
+void WebRTCPeerNative::_init() {
+ printf("Binding PacketPeer interface");
+ godot_net_bind_webrtc_peer(_owner, &interface);
+}
+
+WebRTCPeerNative::~WebRTCPeerNative() {
+ if (_owner) {
+ printf("Unbinding PacketPeer interface");
+ godot_net_bind_webrtc_peer(_owner, NULL);
+ }
+}
+
+/*
+ * The C interface that implements WebRTCPeer.
+ * In this case it forwards calls to our C++ class, but could be plain C,
+ * and you could use void *user for any kind of state struct pointer you have.
+ */
+godot_error get_packet_wp(void *user, const uint8_t **r_buffer, int &r_len) {
+ return ((WebRTCPeerNative *) user)->get_packet(r_buffer, r_len);
+}
+
+godot_error put_packet_wp(void *user, const uint8_t *p_buffer, int p_len) {
+ return ((WebRTCPeerNative *) user)->put_packet(p_buffer, p_len);
+}
+
+godot_int get_available_packet_count_wp(const void *user) {
+ return ((WebRTCPeerNative *) user)->get_available_packet_count();
+}
+
+godot_int get_max_packet_size_wp(const void *user) {
+ return ((WebRTCPeerNative *) user)->get_max_packet_size();
+}
+
+void set_write_mode_wp(void *user, godot_int write_mode) {
+ ((WebRTCPeerNative *) user)->set_write_mode(write_mode);
+}
+
+godot_int get_write_mode_wp(const void *user) {
+ return ((WebRTCPeerNative *) user)->get_write_mode();
+}
+
+bool was_string_packet_wp(const void *user) {
+ return ((WebRTCPeerNative *) user)->was_string_packet();
+}
+
+godot_int get_connection_state_wp(const void *user) {
+ return ((WebRTCPeerNative *) user)->get_connection_state();
+}
+
+godot_error create_offer_wp(void *user) {
+ return ((WebRTCPeerNative *) user)->create_offer();
+}
+
+godot_error set_remote_description_wp(void *user, godot_string type, godot_string sdp) {
+ return ((WebRTCPeerNative *) user)->set_remote_description(type, sdp);
+}
+
+godot_error set_local_description_wp(void *user, godot_string type, godot_string sdp) {
+ return ((WebRTCPeerNative *) user)->set_local_description(type, sdp);
+}
+
+godot_error add_ice_candidate_wp(void *user, godot_string sdpMidName, int sdpMlineIndexName, godot_string sdpName) {
+ return ((WebRTCPeerNative *) user)->add_ice_candidate(sdpMidName, sdpMlineIndexName, sdpName);
+}
+
+godot_error poll_wp(void *user) {
+ return ((WebRTCPeerNative *) user)->poll();
+}