X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Scheduler%2FWriteHelper.ct;h=3d688ef5f61694eacc1b7639f8ab432f536f8d05;hb=bd9f9d3fd6fbcff0112a7bf48ab9284da9576b11;hp=28bf5b6d2caf6e984d5b047476a106c86b1ce10b;hpb=553781d9e9bce316dca24ac4f0c42e5613e849e0;p=senf.git diff --git a/Scheduler/WriteHelper.ct b/Scheduler/WriteHelper.ct index 28bf5b6..3d688ef 100644 --- a/Scheduler/WriteHelper.ct +++ b/Scheduler/WriteHelper.ct @@ -16,7 +16,7 @@ // along with this program; if not, write to the // Free Software Foundation, Inc., // 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. -// Copyright (C) 2006 +// Copyright (C) 2006 /** \file \brief WriteHelper non-inline template implementation */ @@ -25,30 +25,29 @@ // Custom includes #include -#include "Utils/Exception.hh" +#include +#include "../Utils/Exception.hh" #include "Scheduler.hh" #define prefix_ ///////////////////////////////ct.p//////////////////////////////////////// template -prefix_ senf::WriteHelper::WriteHelper(Handle handle, std::string data, +prefix_ senf::WriteHelper::WriteHelper(Handle handle, std::string const & data, Callback callback) - : handle_(handle), data_(data), callback_(callback), - offset_(0), errno_(0) -{ - senf::Scheduler::instance() - .add(handle_, boost::bind(&WriteHelper::dispatchProcess, ptr(this), _1, _2), - senf::Scheduler::EV_WRITE); -} + : handle_(handle), + fde_("WriteHelper", boost::bind(&WriteHelper::dispatchProcess, ptr(this), _1, _2), + handle, scheduler::FdEvent::EV_WRITE), + data_(data), callback_(callback), offset_(data_.begin()), errno_(0) +{} template prefix_ std::string const & senf::WriteHelper::data() const { - if (offset_ > 0) { - data_.erase(0,offset_); - offset_ = 0; + if (offset_ > data_.begin()) { + data_.erase(data_.begin(),offset_); + offset_ = data_.begin(); } return data_; } @@ -57,14 +56,13 @@ template prefix_ void senf::WriteHelper::revoke() { ptr guard (this); // To ensure, 'this' is deleted only after this method terminates ... - senf::Scheduler::instance() - .remove(handle_, senf::Scheduler::EV_WRITE); + fde_.disable(); + fde_.action(0); // To remove the smart pointer reference to this } template -prefix_ void -senf::WriteHelper::dispatchProcess(ptr helper, Handle handle, - senf::Scheduler::EventId event) +prefix_ void senf::WriteHelper::dispatchProcess(ptr helper, Handle handle, + senf::scheduler::FdEvent::Events event) { // since we have a 'ptr' argument, the instance cannot be deleted // before this method returns @@ -73,22 +71,26 @@ senf::WriteHelper::dispatchProcess(ptr helper, Handle handle, template prefix_ void senf::WriteHelper::process(Handle handle, - senf::Scheduler::EventId event) + senf::scheduler::FdEvent::Events event) { - /** \fixme Move the done() calls to outside the try/catch block */ + bool complete_ (false); try { - if (event != senf::Scheduler::EV_WRITE) - throw senf::SystemException(EPIPE); - offset_ += handle.write(data_.data()+offset_,data_.size()-offset_); - if (offset_ >= data_.size()) { - data_.erase(); - done(); - } + if (event != senf::scheduler::FdEvent::EV_WRITE) + throw SystemException(EPIPE SENF_EXC_DEBUGINFO); + offset_ = handle.write(std::make_pair(offset_,data_.end())); + if (offset_ == data_.end()) { + data_.erase(); + offset_ = data_.begin(); + complete_ = true; + } } catch (senf::SystemException const & ex) { - errno_ = ex.err; - done(); + errno_ = ex.errorNumber(); + done(); + return; } + if (complete_) + done(); } template @@ -104,4 +106,10 @@ prefix_ void senf::WriteHelper::done() // 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: