From c13be7959439edd03b3fabf8a73a301784bce2b6 Mon Sep 17 00:00:00 2001 From: Fabio Alessandrelli Date: Sun, 30 Jun 2019 19:28:13 +0200 Subject: [PATCH] Add TCP Server is_listening method --- core/io/tcp_server.cpp | 7 +++++++ core/io/tcp_server.h | 1 + doc/classes/TCP_Server.xml | 7 +++++++ 3 files changed, 15 insertions(+) diff --git a/core/io/tcp_server.cpp b/core/io/tcp_server.cpp index be87f47d502..a2756164bc7 100644 --- a/core/io/tcp_server.cpp +++ b/core/io/tcp_server.cpp @@ -34,6 +34,7 @@ void TCP_Server::_bind_methods() { ClassDB::bind_method(D_METHOD("listen", "port", "bind_address"), &TCP_Server::listen, DEFVAL("*")); ClassDB::bind_method(D_METHOD("is_connection_available"), &TCP_Server::is_connection_available); + ClassDB::bind_method(D_METHOD("is_listening"), &TCP_Server::is_listening); ClassDB::bind_method(D_METHOD("take_connection"), &TCP_Server::take_connection); ClassDB::bind_method(D_METHOD("stop"), &TCP_Server::stop); } @@ -75,6 +76,12 @@ Error TCP_Server::listen(uint16_t p_port, const IP_Address &p_bind_address) { return OK; } +bool TCP_Server::is_listening() const { + ERR_FAIL_COND_V(!_sock.is_valid(), false); + + return _sock->is_open(); +} + bool TCP_Server::is_connection_available() const { ERR_FAIL_COND_V(!_sock.is_valid(), false); diff --git a/core/io/tcp_server.h b/core/io/tcp_server.h index 538db175ad0..ef64044599d 100644 --- a/core/io/tcp_server.h +++ b/core/io/tcp_server.h @@ -50,6 +50,7 @@ protected: public: Error listen(uint16_t p_port, const IP_Address &p_bind_address = IP_Address("*")); + bool is_listening() const; bool is_connection_available() const; Ref take_connection(); diff --git a/doc/classes/TCP_Server.xml b/doc/classes/TCP_Server.xml index 432d83f25bc..cac3a0b0824 100644 --- a/doc/classes/TCP_Server.xml +++ b/doc/classes/TCP_Server.xml @@ -16,6 +16,13 @@ Returns [code]true[/code] if a connection is available for taking. + + + + + Returns [code]true[/code] if the server is currently listening for connections. + +