diff options
Diffstat (limited to 'modules/websocket/wsl_peer.cpp')
| -rw-r--r-- | modules/websocket/wsl_peer.cpp | 12 | 
1 files changed, 11 insertions, 1 deletions
diff --git a/modules/websocket/wsl_peer.cpp b/modules/websocket/wsl_peer.cpp index 1dbadfed74..7f027e1c0d 100644 --- a/modules/websocket/wsl_peer.cpp +++ b/modules/websocket/wsl_peer.cpp @@ -205,7 +205,9 @@ void WSLPeer::make_context(PeerData *p_data, unsigned int p_in_buf_size, unsigne  	ERR_FAIL_COND(p_data == nullptr);  	_in_buffer.resize(p_in_pkt_size, p_in_buf_size); -	_packet_buffer.resize((1 << MAX(p_in_buf_size, p_out_buf_size))); +	_packet_buffer.resize(1 << p_in_buf_size); +	_out_buf_size = p_out_buf_size; +	_out_pkt_size = p_out_pkt_size;  	_data = p_data;  	_data->peer = this; @@ -239,6 +241,8 @@ void WSLPeer::poll() {  Error WSLPeer::put_packet(const uint8_t *p_buffer, int p_buffer_size) {  	ERR_FAIL_COND_V(!is_connected_to_host(), FAILED); +	ERR_FAIL_COND_V(_out_pkt_size && (wslay_event_get_queued_msg_count(_data->ctx) >= (1ULL << _out_pkt_size)), ERR_OUT_OF_MEMORY); +	ERR_FAIL_COND_V(_out_buf_size && (wslay_event_get_queued_msg_length(_data->ctx) >= (1ULL << _out_buf_size)), ERR_OUT_OF_MEMORY);  	struct wslay_event_msg msg; // Should I use fragmented?  	msg.opcode = write_mode == WRITE_MODE_TEXT ? WSLAY_TEXT_FRAME : WSLAY_BINARY_FRAME; @@ -280,6 +284,12 @@ int WSLPeer::get_available_packet_count() const {  	return _in_buffer.packets_left();  } +int WSLPeer::get_current_outbound_buffered_amount() const { +	ERR_FAIL_COND_V(!_data, 0); + +	return wslay_event_get_queued_msg_length(_data->ctx); +} +  bool WSLPeer::was_string_packet() const {  	return _is_string;  }  |