Disable Nagle's algorithm for WebSocket TCP.
This should greatly decrease latency for the most common use cases. A new function WebSocketPeer::set_no_delay will allow to configure it if so desired.
This commit is contained in:
parent
887950b793
commit
a48d0b5eef
@ -53,6 +53,16 @@
|
|||||||
Returns [code]true[/code] if this peer is currently connected.
|
Returns [code]true[/code] if this peer is currently connected.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
|
<method name="set_no_delay">
|
||||||
|
<return type="void">
|
||||||
|
</return>
|
||||||
|
<argument index="0" name="enabled" type="bool">
|
||||||
|
</argument>
|
||||||
|
<description>
|
||||||
|
Disable Nagle's algorithm on the underling TCP socket (default). See [method StreamPeerTCP.set_no_delay] for more information.
|
||||||
|
[b]Note:[/b] Not available in the HTML5 export.
|
||||||
|
</description>
|
||||||
|
</method>
|
||||||
<method name="set_write_mode">
|
<method name="set_write_mode">
|
||||||
<return type="void">
|
<return type="void">
|
||||||
</return>
|
</return>
|
||||||
|
@ -139,6 +139,11 @@ uint16_t EMWSPeer::get_connected_port() const {
|
|||||||
ERR_FAIL_V_MSG(0, "Not supported in HTML5 export.");
|
ERR_FAIL_V_MSG(0, "Not supported in HTML5 export.");
|
||||||
};
|
};
|
||||||
|
|
||||||
|
void EMWSPeer::set_no_delay(bool p_enabled) {
|
||||||
|
|
||||||
|
ERR_FAIL_MSG("'set_no_delay' is not supported in HTML5 export.");
|
||||||
|
}
|
||||||
|
|
||||||
EMWSPeer::EMWSPeer() {
|
EMWSPeer::EMWSPeer() {
|
||||||
peer_sock = -1;
|
peer_sock = -1;
|
||||||
write_mode = WRITE_MODE_BINARY;
|
write_mode = WRITE_MODE_BINARY;
|
||||||
|
@ -68,6 +68,7 @@ public:
|
|||||||
virtual WriteMode get_write_mode() const;
|
virtual WriteMode get_write_mode() const;
|
||||||
virtual void set_write_mode(WriteMode p_mode);
|
virtual void set_write_mode(WriteMode p_mode);
|
||||||
virtual bool was_string_packet() const;
|
virtual bool was_string_packet() const;
|
||||||
|
virtual void set_no_delay(bool p_enabled);
|
||||||
|
|
||||||
EMWSPeer();
|
EMWSPeer();
|
||||||
~EMWSPeer();
|
~EMWSPeer();
|
||||||
|
@ -46,6 +46,7 @@ void WebSocketPeer::_bind_methods() {
|
|||||||
ClassDB::bind_method(D_METHOD("close", "code", "reason"), &WebSocketPeer::close, DEFVAL(1000), DEFVAL(""));
|
ClassDB::bind_method(D_METHOD("close", "code", "reason"), &WebSocketPeer::close, DEFVAL(1000), DEFVAL(""));
|
||||||
ClassDB::bind_method(D_METHOD("get_connected_host"), &WebSocketPeer::get_connected_host);
|
ClassDB::bind_method(D_METHOD("get_connected_host"), &WebSocketPeer::get_connected_host);
|
||||||
ClassDB::bind_method(D_METHOD("get_connected_port"), &WebSocketPeer::get_connected_port);
|
ClassDB::bind_method(D_METHOD("get_connected_port"), &WebSocketPeer::get_connected_port);
|
||||||
|
ClassDB::bind_method(D_METHOD("set_no_delay", "enabled"), &WebSocketPeer::set_no_delay);
|
||||||
|
|
||||||
BIND_ENUM_CONSTANT(WRITE_MODE_TEXT);
|
BIND_ENUM_CONSTANT(WRITE_MODE_TEXT);
|
||||||
BIND_ENUM_CONSTANT(WRITE_MODE_BINARY);
|
BIND_ENUM_CONSTANT(WRITE_MODE_BINARY);
|
||||||
|
@ -64,6 +64,7 @@ public:
|
|||||||
virtual IP_Address get_connected_host() const = 0;
|
virtual IP_Address get_connected_host() const = 0;
|
||||||
virtual uint16_t get_connected_port() const = 0;
|
virtual uint16_t get_connected_port() const = 0;
|
||||||
virtual bool was_string_packet() const = 0;
|
virtual bool was_string_packet() const = 0;
|
||||||
|
virtual void set_no_delay(bool p_enabled) = 0;
|
||||||
|
|
||||||
WebSocketPeer();
|
WebSocketPeer();
|
||||||
~WebSocketPeer();
|
~WebSocketPeer();
|
||||||
|
@ -90,6 +90,7 @@ void WSLClient::_do_handshake() {
|
|||||||
data->is_server = false;
|
data->is_server = false;
|
||||||
data->id = 1;
|
data->id = 1;
|
||||||
_peer->make_context(data, _in_buf_size, _in_pkt_size, _out_buf_size, _out_pkt_size);
|
_peer->make_context(data, _in_buf_size, _in_pkt_size, _out_buf_size, _out_pkt_size);
|
||||||
|
_peer->set_no_delay(true);
|
||||||
_on_connect(protocol);
|
_on_connect(protocol);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -318,6 +318,12 @@ uint16_t WSLPeer::get_connected_port() const {
|
|||||||
return _data->tcp->get_connected_port();
|
return _data->tcp->get_connected_port();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void WSLPeer::set_no_delay(bool p_enabled) {
|
||||||
|
|
||||||
|
ERR_FAIL_COND(!is_connected_to_host() || _data->tcp.is_null());
|
||||||
|
_data->tcp->set_no_delay(p_enabled);
|
||||||
|
}
|
||||||
|
|
||||||
void WSLPeer::invalidate() {
|
void WSLPeer::invalidate() {
|
||||||
if (_data)
|
if (_data)
|
||||||
_data->valid = false;
|
_data->valid = false;
|
||||||
|
@ -109,6 +109,7 @@ public:
|
|||||||
virtual WriteMode get_write_mode() const;
|
virtual WriteMode get_write_mode() const;
|
||||||
virtual void set_write_mode(WriteMode p_mode);
|
virtual void set_write_mode(WriteMode p_mode);
|
||||||
virtual bool was_string_packet() const;
|
virtual bool was_string_packet() const;
|
||||||
|
virtual void set_no_delay(bool p_enabled);
|
||||||
|
|
||||||
void make_context(PeerData *p_data, unsigned int p_in_buf_size, unsigned int p_in_pkt_size, unsigned int p_out_buf_size, unsigned int p_out_pkt_size);
|
void make_context(PeerData *p_data, unsigned int p_in_buf_size, unsigned int p_in_pkt_size, unsigned int p_out_buf_size, unsigned int p_out_pkt_size);
|
||||||
Error parse_message(const wslay_event_on_msg_recv_arg *arg);
|
Error parse_message(const wslay_event_on_msg_recv_arg *arg);
|
||||||
|
@ -206,6 +206,7 @@ void WSLServer::poll() {
|
|||||||
|
|
||||||
Ref<WSLPeer> ws_peer = memnew(WSLPeer);
|
Ref<WSLPeer> ws_peer = memnew(WSLPeer);
|
||||||
ws_peer->make_context(data, _in_buf_size, _in_pkt_size, _out_buf_size, _out_pkt_size);
|
ws_peer->make_context(data, _in_buf_size, _in_pkt_size, _out_buf_size, _out_pkt_size);
|
||||||
|
ws_peer->set_no_delay(true);
|
||||||
|
|
||||||
_peer_map[id] = ws_peer;
|
_peer_map[id] = ws_peer;
|
||||||
remove_peers.push_back(ppeer);
|
remove_peers.push_back(ppeer);
|
||||||
|
Loading…
Reference in New Issue
Block a user