X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Socket%2FFileHandle.cci;h=e04980a3ac4081bba7478ecd5981f782d560dcd6;hb=8475937b6551f73a1cddd8fa830b7128d4c8ebf7;hp=8038c7fb44c31e17f38545cf47f96683cb530171;hpb=31d85cd6b8e03c5ecc924ca8892906be1bab702f;p=senf.git diff --git a/Socket/FileHandle.cci b/Socket/FileHandle.cci index 8038c7f..e04980a 100644 --- a/Socket/FileHandle.cci +++ b/Socket/FileHandle.cci @@ -1,9 +1,9 @@ // $Id$ // // Copyright (C) 2006 -// Fraunhofer Institut fuer offene Kommunikationssysteme (FOKUS) -// Kompetenzzentrum fuer Satelitenkommunikation (SatCom) -// Stefan Bund +// Fraunhofer Institute for Open Communication Systems (FOKUS) +// Competence Center NETwork research (NET), St. Augustin, GERMANY +// Stefan Bund // // This program is free software; you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by @@ -27,8 +27,9 @@ //#include "FileHandle.ih" // Custom includes +#include "../Utils/senfassert.hh" #include -#include "Utils/Exception.hh" +#include "../Utils/Exception.hh" #define prefix_ inline ///////////////////////////////cci.p/////////////////////////////////////// @@ -40,31 +41,9 @@ prefix_ senf::FileBody::FileBody(int fd) : fd_(fd) {} -prefix_ senf::FileBody::~FileBody() +prefix_ senf::FileHandle senf::FileBody::handle() { - if (valid()) - try { - close(); - } - catch (...) { - terminate(); - } -} - -prefix_ void senf::FileBody::close() -{ - if (!valid()) - throw SystemException(EBADF); - v_close(); - fd_ = -1; -} - -prefix_ void senf::FileBody::terminate() -{ - if (valid()) { - v_terminate(); - fd_ = -1; - } + return FileHandle(ptr(this)); } prefix_ int senf::FileBody::fd() @@ -117,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(); @@ -190,22 +182,19 @@ 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()) {} -prefix_ senf::FileBody & senf::FileHandle::body() -{ - BOOST_ASSERT(body_); - return *body_; -} - -prefix_ senf::FileBody const & senf::FileHandle::body() - const -{ - BOOST_ASSERT(body_); - return *body_; -} +prefix_ senf::FileHandle::FileHandle(FileBody::ptr body) + : body_(body) +{} prefix_ senf::FileBody & senf::FileHandle::body(FileHandle & handle) { @@ -251,4 +240,5 @@ prefix_ int senf::retrieve_filehandle(FileHandle handle) // indent-tabs-mode: nil // ispell-local-dictionary: "american" // compile-command: "scons -u test" +// comment-column: 40 // End: