ef9c418aaa82568d7b24008e0e8be5c487605add
3 * This file is part of the libCEC(R) library.
5 * libCEC(R) is Copyright (C) 2011-2012 Pulse-Eight Limited. All rights reserved.
6 * libCEC(R) is an original work, containing original code.
8 * libCEC(R) is a trademark of Pulse-Eight Limited.
10 * This program is dual-licensed; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 2 of the License, or
13 * (at your option) any later version.
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
20 * You should have received a copy of the GNU General Public License
21 * along with this program; if not, write to the Free Software
22 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
25 * Alternatively, you can license this library under a commercial license,
26 * please contact Pulse-Eight Licensing for more information.
28 * For more information contact:
29 * Pulse-Eight Licensing <license@pulse-eight.com>
30 * http://www.pulse-eight.com/
31 * http://www.pulse-eight.net/
36 #if defined(__WINDOWS__)
37 #include "../windows/os-tcp.h"
39 #include "../posix/os-tcp.h"
46 class CTcpSocket
: public CSocket
50 virtual ~CTcpSocket(void) {}
52 virtual bool Open(const CStdString
&strHostname
, uint16_t iPort
, uint64_t nTimeout
)
55 struct addrinfo
*address(NULL
), *addr(NULL
);
56 CLockObject
lock(m_mutex
);
57 if (!TcpResolveAddress(strHostname
.c_str(), iPort
, &m_iError
, &address
))
59 m_strError
= strerror(m_iError
);
63 for(addr
= address
; !bReturn
&& addr
; addr
= addr
->ai_next
)
65 m_socket
= TcpCreateSocket(addr
, &m_iError
, nTimeout
);
66 if (m_socket
!= INVALID_SOCKET
&& m_socket
!= SOCKET_ERROR
)
69 m_strError
= strerror(m_iError
);
72 freeaddrinfo(address
);
76 virtual void Shutdown(void)
78 CLockObject
lock(m_mutex
);
79 if (m_socket
!= INVALID_SOCKET
&& m_socket
!= SOCKET_ERROR
)
80 TcpShutdownSocket(m_socket
);
81 m_socket
= INVALID_SOCKET
;
86 virtual socket_t
TcpCreateSocket(struct addrinfo
* addr
, int* iError
, uint64_t iTimeout
)
88 socket_t fdSock
= socket(addr
->ai_family
, addr
->ai_socktype
, addr
->ai_protocol
);
89 if (fdSock
== INVALID_SOCKET
|| fdSock
== SOCKET_ERROR
)
92 return (socket_t
)SOCKET_ERROR
;
95 if (!TcpConnectSocket(fdSock
, addr
, iError
, iTimeout
))
98 return (socket_t
)SOCKET_ERROR
;
101 TcpSetNoDelay(fdSock
);