X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Socket%2FFileHandle.cci;h=e04980a3ac4081bba7478ecd5981f782d560dcd6;hb=3c3f12e715cd474208351347316f59fdaf19ef81;hp=9f82d08a3be780287ce05c523dfaf22cf0eaebfa;hpb=a1a6c76a214ad1935032826713cabaf9ac57bf07;p=senf.git diff --git a/Socket/FileHandle.cci b/Socket/FileHandle.cci index 9f82d08..e04980a 100644 --- a/Socket/FileHandle.cci +++ b/Socket/FileHandle.cci @@ -41,33 +41,6 @@ prefix_ senf::FileBody::FileBody(int fd) : fd_(fd) {} -prefix_ senf::FileBody::~FileBody() -{ - if (valid()) - try { - close(); - } - catch (...) { - terminate(); - } -} - -prefix_ void senf::FileBody::close() -{ - if (!valid()) - throwErrno(EBADF); - v_close(); - fd_ = -1; -} - -prefix_ void senf::FileBody::terminate() -{ - if (valid()) { - v_terminate(); - fd_ = -1; - } -} - prefix_ senf::FileHandle senf::FileBody::handle() { return FileHandle(ptr(this)); @@ -123,6 +96,19 @@ prefix_ void senf::FileBody::waitWriteable() /////////////////////////////////////////////////////////////////////////// // senf::FileHandle +prefix_ senf::FileBody & senf::FileHandle::body() +{ + SENF_ASSERT(body_); + return *body_; +} + +prefix_ senf::FileBody const & senf::FileHandle::body() + const +{ + SENF_ASSERT(body_); + return *body_; +} + prefix_ void senf::FileHandle::close() { body().close(); @@ -196,6 +182,12 @@ prefix_ senf::FileHandle::FileHandle() : body_(0) {} +prefix_ senf::FileHandle::~FileHandle() +{ + if (body_ && ! body().is_shared()) + body().destroyClose(); +} + prefix_ senf::FileHandle::FileHandle(std::auto_ptr body) : body_(body.release()) {} @@ -204,19 +196,6 @@ prefix_ senf::FileHandle::FileHandle(FileBody::ptr body) : body_(body) {} -prefix_ senf::FileBody & senf::FileHandle::body() -{ - SENF_ASSERT(body_); - return *body_; -} - -prefix_ senf::FileBody const & senf::FileHandle::body() - const -{ - SENF_ASSERT(body_); - return *body_; -} - prefix_ senf::FileBody & senf::FileHandle::body(FileHandle & handle) { return handle.body();