summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/WebRTCLibDataChannel.cpp5
-rw-r--r--src/WebRTCLibDataChannel.hpp1
-rw-r--r--src/net/WebRTCDataChannelNative.cpp4
-rw-r--r--src/net/WebRTCDataChannelNative.hpp20
4 files changed, 29 insertions, 1 deletions
diff --git a/src/WebRTCLibDataChannel.cpp b/src/WebRTCLibDataChannel.cpp
index f29d562..bab9c79 100644
--- a/src/WebRTCLibDataChannel.cpp
+++ b/src/WebRTCLibDataChannel.cpp
@@ -144,6 +144,11 @@ bool WebRTCLibDataChannel::is_negotiated() const {
return channel->negotiated();
}
+int WebRTCLibDataChannel::get_buffered_amount() const {
+ ERR_FAIL_COND_V(channel.get() == nullptr, 0);
+ return channel->buffered_amount();
+}
+
godot_error WebRTCLibDataChannel::poll() {
return GODOT_OK;
}
diff --git a/src/WebRTCLibDataChannel.hpp b/src/WebRTCLibDataChannel.hpp
index 1d1ce0f..63c7fdd 100644
--- a/src/WebRTCLibDataChannel.hpp
+++ b/src/WebRTCLibDataChannel.hpp
@@ -87,6 +87,7 @@ public:
int get_max_retransmits() const;
const char *get_protocol() const;
bool is_negotiated() const;
+ int get_buffered_amount() const;
godot_error poll();
void close();
diff --git a/src/net/WebRTCDataChannelNative.cpp b/src/net/WebRTCDataChannelNative.cpp
index 86d0afa..4e6b114 100644
--- a/src/net/WebRTCDataChannelNative.cpp
+++ b/src/net/WebRTCDataChannelNative.cpp
@@ -113,6 +113,10 @@ bool is_negotiated_wdc(const void *user) {
return ((WebRTCDataChannelNative *)user)->is_negotiated();
}
+int get_buffered_amount_wdc(const void *user) {
+ return ((WebRTCDataChannelNative *)user)->get_buffered_amount();
+}
+
godot_error poll_wdc(void *user) {
return ((WebRTCDataChannelNative *)user)->poll();
}
diff --git a/src/net/WebRTCDataChannelNative.hpp b/src/net/WebRTCDataChannelNative.hpp
index 37b8616..20ef38e 100644
--- a/src/net/WebRTCDataChannelNative.hpp
+++ b/src/net/WebRTCDataChannelNative.hpp
@@ -54,13 +54,30 @@ int get_max_packet_life_time_wdc(const void *);
int get_max_retransmits_wdc(const void *);
const char *get_protocol_wdc(const void *);
bool is_negotiated_wdc(const void *);
+int get_buffered_amount_wdc(const void *);
godot_error poll_wdc(void *);
void close_wdc(void *);
+#if GODOT_NET_WEBRTC_API_MAJOR == 3 && GODOT_NET_WEBRTC_API_MINOR < 4
+extern "C" {
+/* Extensions to WebRTCDataChannel */
+typedef struct {
+ int (*get_buffered_amount)(const void *);
+
+ void *next; /* For extension? */
+} godot_net_webrtc_data_channel_ext;
+}
+#endif
+
class WebRTCDataChannelNative : public godot::WebRTCDataChannelGDNative {
GODOT_CLASS(WebRTCDataChannelNative, godot::WebRTCDataChannelGDNative);
protected:
+ godot_net_webrtc_data_channel_ext interface_ext = {
+ &get_buffered_amount_wdc,
+ NULL,
+ };
+
godot_net_webrtc_data_channel interface = {
{ 3, 1 },
this,
@@ -84,7 +101,7 @@ protected:
&poll_wdc,
&close_wdc,
- NULL,
+ &interface_ext,
};
public:
@@ -105,6 +122,7 @@ public:
virtual int get_max_retransmits() const = 0;
virtual const char *get_protocol() const = 0;
virtual bool is_negotiated() const = 0;
+ virtual int get_buffered_amount() const = 0;
virtual godot_error poll() = 0;
virtual void close() = 0;