X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Socket%2FFileHandle.cc;h=bc8ea9caf21923dd77cdb2897f91116240ca2fe6;hb=b8ca4a544cce3e6023bb56b712a03d6362f2bb79;hp=3b3ef9d7ca987454525db7937b5cbbc20ffa5083;hpb=1d247d12d1759ffd77f456efe3a52f03dd289994;p=senf.git diff --git a/Socket/FileHandle.cc b/Socket/FileHandle.cc index 3b3ef9d..bc8ea9c 100644 --- a/Socket/FileHandle.cc +++ b/Socket/FileHandle.cc @@ -44,7 +44,7 @@ prefix_ void senf::FileBody::close() { if (!valid()) - throw SystemException(EBADF); + throw SystemException(EBADF SENF_EXC_DEBUGINFO); v_close(); fd_ = -1; } @@ -71,7 +71,7 @@ prefix_ void senf::FileBody::destroyClose() prefix_ void senf::FileBody::v_close() { if (::close(fd_) != 0) - throw SystemException(); + SENF_THROW_SYSTEM_EXCEPTION(""); } prefix_ void senf::FileBody::v_terminate() @@ -95,43 +95,46 @@ prefix_ bool senf::FileBody::blocking() const { int flags = ::fcntl(fd(),F_GETFL); - if (flags < 0) throw SystemException(); + if (flags < 0) SENF_THROW_SYSTEM_EXCEPTION(""); return ! (flags & O_NONBLOCK); } prefix_ void senf::FileBody::blocking(bool status) { int flags = ::fcntl(fd(),F_GETFL); - if (flags < 0) throw SystemException(); + if (flags < 0) SENF_THROW_SYSTEM_EXCEPTION(""); if (status) flags &= ~O_NONBLOCK; else flags |= O_NONBLOCK; - if (::fcntl(fd(), F_SETFL, flags) < 0) throw SystemException(); + if (::fcntl(fd(), F_SETFL, flags) < 0) SENF_THROW_SYSTEM_EXCEPTION(""); } /* We don't take POLLIN/POLLOUT as argument to avoid having to include sys/poll.h in the .cci file (and therefore indirectly into the .hh and then every file which uses FileHandle) */ -prefix_ bool senf::FileBody::pollCheck(int fd, bool incoming, bool block) +prefix_ bool senf::FileBody::pollCheck(int fd, bool incoming, int timeout, bool oob) const { struct ::pollfd pfd; ::memset(&pfd,0,sizeof(pfd)); pfd.fd = fd; - pfd.events = incoming?POLLIN:POLLOUT; + pfd.events = incoming?(oob?POLLPRI:POLLIN):POLLOUT; int rv = -1; do { - rv = ::poll(&pfd,1,block?-1:0); + rv = ::poll(&pfd,1,timeout); if (rv<0) switch (errno) { case EINTR: break; default: - throw SystemException(); + SENF_THROW_SYSTEM_EXCEPTION(""); } } while (rv<0); return rv>0; } +prefix_ senf::FileBody::~FileBody() +{} + ///////////////////////////////cc.e//////////////////////////////////////// #undef prefix_