lokinet/llarp/ev/pipe.cpp

68 lines
1.2 KiB
C++
Raw Normal View History

2019-04-08 12:01:52 +00:00
#include <ev/pipe.hpp>
2019-07-30 23:42:13 +00:00
#include <utility>
2019-04-08 14:04:58 +00:00
#ifndef _MSC_VER
2019-04-08 14:04:58 +00:00
#include <unistd.h>
#endif
2019-04-08 14:04:58 +00:00
#include <fcntl.h>
llarp_ev_pkt_pipe::llarp_ev_pkt_pipe(llarp_ev_loop_ptr loop)
2019-07-30 23:42:13 +00:00
: llarp::ev_io(-1, new LosslessWriteQueue_t()), m_Loop(std::move(loop))
2019-04-08 14:04:58 +00:00
{
}
bool
2019-08-22 11:18:05 +00:00
llarp_ev_pkt_pipe::StartPipe()
2019-04-08 14:04:58 +00:00
{
2019-04-10 15:26:50 +00:00
#if defined(_WIN32)
llarp::LogError("llarp_ev_pkt_pipe not supported on win32");
return false;
#else
2019-04-08 14:04:58 +00:00
int _fds[2];
if (pipe(_fds) == -1 && fcntl(_fds[0], F_SETFL, fcntl(_fds[0], F_GETFL) | O_NONBLOCK))
2019-04-09 12:29:10 +00:00
{
return false;
}
fd = _fds[0];
2019-04-08 14:04:58 +00:00
writefd = _fds[1];
2019-08-22 11:18:05 +00:00
return m_Loop->add_pipe(this);
2019-04-10 15:26:50 +00:00
#endif
2019-04-08 14:04:58 +00:00
}
int
llarp_ev_pkt_pipe::read(byte_t* pkt, size_t sz)
{
auto res = ::read(fd, pkt, sz);
if (res <= 0)
2019-04-08 14:04:58 +00:00
return res;
llarp::LogDebug("read ", res, " on pipe");
llarp_buffer_t buf(pkt, res);
OnRead(buf);
return res;
}
ssize_t
llarp_ev_pkt_pipe::do_write(void* buf, size_t sz)
{
return ::write(writefd, buf, sz);
}
bool
llarp_ev_pkt_pipe::Write(const llarp_buffer_t& pkt)
{
const ssize_t sz = pkt.sz;
if (do_write(pkt.base, pkt.sz) != sz)
2019-04-08 14:04:58 +00:00
{
llarp::LogDebug("queue write ", pkt.sz);
return queue_write(pkt.base, pkt.sz);
}
return true;
}
bool
llarp_ev_pkt_pipe::tick()
{
llarp::ev_io::flush_write();
return true;
}