5#ifdef USE_SOCKET_IMPL_LWIP_SOCKETS
12class LwIPSocketImpl final :
public Socket {
14 LwIPSocketImpl(
int fd,
bool monitor_loop =
false) : fd_(fd) {
15#ifdef USE_SOCKET_SELECT_SUPPORT
17 if (monitor_loop && this->fd_ >= 0) {
21 this->loop_monitored_ =
false;
28 ~LwIPSocketImpl()
override {
34 return lwip_connect(this->fd_, addr, addrlen);
36 std::unique_ptr<Socket> accept(
struct sockaddr *addr,
socklen_t *addrlen)
override {
37 int fd = lwip_accept(this->fd_, addr, addrlen);
40 return make_unique<LwIPSocketImpl>(fd,
false);
42 std::unique_ptr<Socket> accept_loop_monitored(
struct sockaddr *addr,
socklen_t *addrlen)
override {
43 int fd = lwip_accept(this->fd_, addr, addrlen);
46 return make_unique<LwIPSocketImpl>(fd,
true);
49 int bind(
const struct sockaddr *addr,
socklen_t addrlen)
override {
return lwip_bind(this->fd_, addr, addrlen); }
50 int close()
override {
52#ifdef USE_SOCKET_SELECT_SUPPORT
54 if (this->loop_monitored_) {
58 int ret = lwip_close(this->fd_);
64 int shutdown(
int how)
override {
return lwip_shutdown(this->fd_, how); }
67 return lwip_getpeername(this->fd_, addr, addrlen);
70 return lwip_getsockname(this->fd_, addr, addrlen);
72 int getsockopt(
int level,
int optname,
void *optval,
socklen_t *optlen)
override {
73 return lwip_getsockopt(this->fd_, level, optname, optval, optlen);
75 int setsockopt(
int level,
int optname,
const void *optval,
socklen_t optlen)
override {
76 return lwip_setsockopt(this->fd_, level, optname, optval, optlen);
78 int listen(
int backlog)
override {
return lwip_listen(this->fd_, backlog); }
79 ssize_t read(
void *buf,
size_t len)
override {
return lwip_read(this->fd_, buf,
len); }
81 return lwip_recvfrom(this->fd_, buf,
len, 0, addr,
addr_len);
83 ssize_t readv(
const struct iovec *iov,
int iovcnt)
override {
return lwip_readv(this->fd_, iov, iovcnt); }
84 ssize_t write(
const void *buf,
size_t len)
override {
return lwip_write(this->fd_, buf,
len); }
86 ssize_t writev(
const struct iovec *iov,
int iovcnt)
override {
return lwip_writev(this->fd_, iov, iovcnt); }
88 return lwip_sendto(this->fd_, buf,
len,
flags, to, tolen);
90 int setblocking(
bool blocking)
override {
91 int fl = lwip_fcntl(this->fd_, F_GETFL, 0);
97 lwip_fcntl(this->fd_, F_SETFL, fl);
101 int get_fd()
const override {
return this->fd_; }
103#ifdef USE_SOCKET_SELECT_SUPPORT
104 bool ready()
const override {
105 if (!this->loop_monitored_)
114#ifdef USE_SOCKET_SELECT_SUPPORT
115 bool loop_monitored_{
false};
120static std::unique_ptr<Socket> create_socket(
int domain,
int type,
int protocol,
bool loop_monitored =
false) {
121 int ret = lwip_socket(domain,
type, protocol);
124 return std::unique_ptr<Socket>{
new LwIPSocketImpl(ret, loop_monitored)};
127std::unique_ptr<Socket>
socket(
int domain,
int type,
int protocol) {
128 return create_socket(domain,
type, protocol,
false);
132 return create_socket(domain,
type, protocol,
true);
bool is_socket_ready(int fd) const
Check if there's data available on a socket without blocking This function is thread-safe for reading...
void unregister_socket_fd(int fd)
bool register_socket_fd(int fd)
Register/unregister a socket file descriptor to be monitored for read events.
std::unique_ptr< Socket > socket(int domain, int type, int protocol)
Create a socket of the given domain, type and protocol.
std::unique_ptr< Socket > socket_loop_monitored(int domain, int type, int protocol)
Create a socket and monitor it for data in the main loop.
Application App
Global storage of Application pointer - only one Application can exist.