X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Socket%2FFileHandle.cci;h=6db39f59ebc152913baa09ce9539402dd7a0e9dd;hb=b89e3166f7680755683dccee5e48cb3a820185c0;hp=f69d3e01c21b7c956d5b09dc7d828e970d091e06;hpb=ac6a813d9d99f7add4e13aff7a4bcd314d5604a6;p=senf.git diff --git a/Socket/FileHandle.cci b/Socket/FileHandle.cci index f69d3e0..6db39f5 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 +// Copyright (C) 2006 +// 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 @@ -20,13 +20,16 @@ // Free Software Foundation, Inc., // 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. -// Definition of inline non-template functions +/** \file + \brief FileHandle inline non-template implementation + */ //#include "FileHandle.ih" // Custom includes +#include "../Utils/senfassert.hh" #include -#include "Utils/Exception.hh" +#include "../Utils/Exception.hh" #define prefix_ inline ///////////////////////////////cci.p/////////////////////////////////////// @@ -38,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() @@ -91,30 +72,58 @@ prefix_ bool senf::FileBody::valid() prefix_ bool senf::FileBody::readable() const { - return pollCheck(fd(),true); + return pollCheck(fd(),true,0); } -prefix_ void senf::FileBody::waitReadable() +prefix_ bool senf::FileBody::waitReadable(senf::ClockService::clock_type timeout) const { - pollCheck(fd(),true,true); + return pollCheck(fd(), true, + (timeout==-1?-1:senf::ClockService::in_milliseconds(timeout)) ); } prefix_ bool senf::FileBody::writeable() const { - return pollCheck(fd(),false); + return pollCheck(fd(),false,0); +} + +prefix_ bool senf::FileBody::waitWriteable(senf::ClockService::clock_type timeout) + const +{ + return pollCheck(fd(), false, + (timeout==-1?-1:senf::ClockService::in_milliseconds(timeout)) ); +} + +prefix_ bool senf::FileBody::oobReadable() + const +{ + return pollCheck(fd(),true,0,true); } -prefix_ void senf::FileBody::waitWriteable() +prefix_ bool senf::FileBody::waitOOBReadable(senf::ClockService::clock_type timeout) const { - pollCheck(fd(),false,true); + return pollCheck(fd(), true, + (timeout==-1?-1:senf::ClockService::in_milliseconds(timeout)), true); } /////////////////////////////////////////////////////////////////////////// // 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(); @@ -131,10 +140,10 @@ prefix_ bool senf::FileHandle::readable() return body().readable(); } -prefix_ void senf::FileHandle::waitReadable() +prefix_ bool senf::FileHandle::waitReadable(senf::ClockService::clock_type timeout) const { - body().waitReadable(); + return body().waitReadable(timeout); } prefix_ bool senf::FileHandle::writeable() @@ -143,10 +152,22 @@ prefix_ bool senf::FileHandle::writeable() return body().writeable(); } -prefix_ void senf::FileHandle::waitWriteable() +prefix_ bool senf::FileHandle::waitWriteable(senf::ClockService::clock_type timeout) + const +{ + return body().waitWriteable(timeout); +} + +prefix_ bool senf::FileHandle::oobReadable() + const +{ + return body().oobReadable(); +} + +prefix_ bool senf::FileHandle::waitOOBReadable(senf::ClockService::clock_type timeout) const { - body().waitWriteable(); + return body().waitOOBReadable(timeout); } prefix_ bool senf::FileHandle::blocking() @@ -169,7 +190,7 @@ prefix_ bool senf::FileHandle::eof() prefix_ bool senf::FileHandle::valid() const { - return body().valid(); + return body_ && body().valid(); } prefix_ bool senf::FileHandle::boolean_test() @@ -184,20 +205,23 @@ prefix_ int senf::FileHandle::fd() return body().fd(); } -prefix_ senf::FileHandle::FileHandle(std::auto_ptr body) - : body_(body.release()) +prefix_ senf::FileHandle::FileHandle() + : body_(0) {} -prefix_ senf::FileBody & senf::FileHandle::body() +prefix_ senf::FileHandle::~FileHandle() { - return *body_; + if (body_ && ! body().is_shared()) + body().destroyClose(); } -prefix_ senf::FileBody const & senf::FileHandle::body() - const -{ - return *body_; -} +prefix_ senf::FileHandle::FileHandle(std::auto_ptr body) + : body_(body.release()) +{} + +prefix_ senf::FileHandle::FileHandle(FileBody::ptr body) + : body_(body) +{} prefix_ senf::FileBody & senf::FileHandle::body(FileHandle & handle) { @@ -238,5 +262,10 @@ prefix_ int senf::retrieve_filehandle(FileHandle handle) // Local Variables: // mode: c++ +// fill-column: 100 // c-file-style: "senf" +// indent-tabs-mode: nil +// ispell-local-dictionary: "american" +// compile-command: "scons -u test" +// comment-column: 40 // End: