summaryrefslogtreecommitdiff
path: root/drivers/unix/tcp_server_posix.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/unix/tcp_server_posix.cpp')
-rw-r--r--drivers/unix/tcp_server_posix.cpp43
1 files changed, 22 insertions, 21 deletions
diff --git a/drivers/unix/tcp_server_posix.cpp b/drivers/unix/tcp_server_posix.cpp
index 98451957fd..0178f08b8c 100644
--- a/drivers/unix/tcp_server_posix.cpp
+++ b/drivers/unix/tcp_server_posix.cpp
@@ -5,7 +5,7 @@
/* GODOT ENGINE */
/* http://www.godotengine.org */
/*************************************************************************/
-/* Copyright (c) 2007-2016 Juan Linietsky, Ariel Manzur. */
+/* Copyright (c) 2007-2017 Juan Linietsky, Ariel Manzur. */
/* */
/* Permission is hereby granted, free of charge, to any person obtaining */
/* a copy of this software and associated documentation files (the */
@@ -55,6 +55,9 @@
#include <netinet/in.h>
#include <sys/socket.h>
#include <assert.h>
+
+#include "drivers/unix/socket_helpers.h"
+
TCP_Server* TCPServerPosix::_create() {
return memnew(TCPServerPosix);
@@ -67,10 +70,11 @@ void TCPServerPosix::make_default() {
Error TCPServerPosix::listen(uint16_t p_port,const List<String> *p_accepted_hosts) {
- printf("********* listening on port %i\n", p_port);
int sockfd;
- sockfd = socket(AF_INET, SOCK_STREAM, 0);
+ sockfd = _socket_create(ip_type, SOCK_STREAM, IPPROTO_TCP);
+
ERR_FAIL_COND_V(sockfd == -1, FAILED);
+
#ifndef NO_FCNTL
fcntl(sockfd, F_SETFL, O_NONBLOCK);
#else
@@ -80,17 +84,15 @@ Error TCPServerPosix::listen(uint16_t p_port,const List<String> *p_accepted_host
int reuse=1;
if(setsockopt(sockfd, SOL_SOCKET, SO_REUSEADDR, (char *)&reuse, sizeof(reuse)) < 0) {
-
- printf("REUSEADDR failed!");
+ WARN_PRINT("REUSEADDR failed!")
}
- struct sockaddr_in my_addr;
- my_addr.sin_family = AF_INET; // host byte order
- my_addr.sin_port = htons(p_port); // short, network byte order
- my_addr.sin_addr.s_addr = INADDR_ANY; // automatically fill with my IP TODO: use p_accepted_hosts
- memset(my_addr.sin_zero, '\0', sizeof my_addr.sin_zero);
+ struct sockaddr_storage addr;
+ size_t addr_size = _set_listen_sockaddr(&addr, p_port, ip_type, p_accepted_hosts);
- if (bind(sockfd, (struct sockaddr *)&my_addr, sizeof my_addr) != -1) {
+ // automatically fill with my IP TODO: use p_accepted_hosts
+
+ if (bind(sockfd, (struct sockaddr *)&addr, addr_size) != -1) {
if (::listen(sockfd, 1) == -1) {
@@ -103,14 +105,11 @@ Error TCPServerPosix::listen(uint16_t p_port,const List<String> *p_accepted_host
};
if (listen_sockfd != -1) {
-
- printf("FAILED\n");
stop();
};
listen_sockfd = sockfd;
- printf("OK! %i\n", listen_sockfd);
return OK;
};
@@ -129,7 +128,6 @@ bool TCPServerPosix::is_connection_available() const {
ERR_FAIL_COND_V(ret < 0, FAILED);
if (ret && (pfd.revents & POLLIN)) {
- printf("has connection!\n");
return true;
};
@@ -142,9 +140,9 @@ Ref<StreamPeerTCP> TCPServerPosix::take_connection() {
return Ref<StreamPeerTCP>();
};
- struct sockaddr_in their_addr;
- socklen_t sin_size = sizeof(their_addr);
- int fd = accept(listen_sockfd, (struct sockaddr *)&their_addr, &sin_size);
+ struct sockaddr_storage their_addr;
+ socklen_t size = sizeof(their_addr);
+ int fd = accept(listen_sockfd, (struct sockaddr *)&their_addr, &size);
ERR_FAIL_COND_V(fd == -1, Ref<StreamPeerTCP>());
#ifndef NO_FCNTL
fcntl(fd, F_SETFL, O_NONBLOCK);
@@ -155,8 +153,11 @@ Ref<StreamPeerTCP> TCPServerPosix::take_connection() {
Ref<StreamPeerTCPPosix> conn = memnew(StreamPeerTCPPosix);
IP_Address ip;
- ip.host = (uint32_t)their_addr.sin_addr.s_addr;
- conn->set_socket(fd, ip, ntohs(their_addr.sin_port));
+
+ int port;
+ _set_ip_addr_port(ip, port, &their_addr);
+
+ conn->set_socket(fd, ip, port, ip_type);
return conn;
};
@@ -164,7 +165,6 @@ Ref<StreamPeerTCP> TCPServerPosix::take_connection() {
void TCPServerPosix::stop() {
if (listen_sockfd != -1) {
- print_line("CLOSING CONNECTION");
int ret = close(listen_sockfd);
ERR_FAIL_COND(ret!=0);
};
@@ -176,6 +176,7 @@ void TCPServerPosix::stop() {
TCPServerPosix::TCPServerPosix() {
listen_sockfd = -1;
+ ip_type = IP::TYPE_ANY;
};
TCPServerPosix::~TCPServerPosix() {