X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Socket%2FClientSocketHandle.ct;h=8e51c2bfd1252f8c8be6e8b96ffd79fb910ea179;hb=7a1872f6702d6206bf1d8364c4e894f98d1c64f0;hp=17a518ef6da176338612ac04cdaa0b8d22a1d70d;hpb=85ab07d100a382467a42e19d741d403a7a96c951;p=senf.git diff --git a/Socket/ClientSocketHandle.ct b/Socket/ClientSocketHandle.ct index 17a518e..8e51c2b 100644 --- a/Socket/ClientSocketHandle.ct +++ b/Socket/ClientSocketHandle.ct @@ -24,13 +24,50 @@ \brief ClientSocketHandle non-inline template implementation */ -//#include "ClientSocketHandle.ih" +#include "ClientSocketHandle.ih" // Custom includes +#include +#include "Utils/Buffer.hh" #define prefix_ ///////////////////////////////ct.p//////////////////////////////////////// +/////////////////////////////////////////////////////////////////////////// +// senf::detail::ReadRange + +// senf::detail::ReadRange::read + +template +prefix_ typename boost::range_iterator::type +senf::detail::ReadRange:: +read(Handle & handle, ForwardWritableRange & range) +{ + typename boost::range_size::type nread (boost::size(range)); + SENF_SCOPED_BUFFER(char, buffer, nread); + return std::copy(buffer, handle.read(buffer,buffer+nread), boost::begin(range)); +} + +// senf::detail::ReadRange::readfrom + +template +prefix_ typename boost::range_iterator::type +senf::detail::ReadRange:: +readfrom(Handle & handle, ForwardWritableRange & range, typename Handle::Address & addr) +{ + typename boost::range_size::type nread (boost::size(range)); + SENF_SCOPED_BUFFER(char, buffer, nread); + return std::copy(buffer, handle.readfrom(buffer,buffer+nread,addr), boost::begin(range)); +} + +/////////////////////////////////////////////////////////////////////////// +// senf::ClientSocketHandle + +//////////////////////////////////////// +// reading and writing + +// senf::ClientSocketHandle::read + template prefix_ std::string senf::ClientSocketHandle::read(unsigned limit) { @@ -40,40 +77,44 @@ prefix_ std::string senf::ClientSocketHandle::read(unsigned limit) } template -prefix_ void senf::ClientSocketHandle::read(std::string & buffer, unsigned limit) +template +prefix_ void senf::ClientSocketHandle::read(Sequence & container, unsigned limit) { - unsigned nread = available(); + unsigned nread (available()); if (limit>0 && nread>limit) nread = limit; - /** \fixme This is not necessary correct and more or less a hack ... */ - buffer.assign(nread,0); - unsigned rv = this->read(const_cast(buffer.data()),nread); - if (rv < nread) - buffer.erase(buffer.begin()+rv,buffer.end()); + container.resize(nread); + container.erase(read( std::make_pair(container.begin(), container.end()) ), + container.end()); } +// senf::ClientSocketHandle::readfrom + template prefix_ std::pair -senf::ClientSocketHandle::readfrom() +senf::ClientSocketHandle::readfrom(unsigned limit) { std::string rv; typename Policy::AddressingPolicy::Address addr; - this->readfrom(rv,addr); + this->readfrom(rv,addr,limit); return std::make_pair(rv,addr); } template -prefix_ void senf::ClientSocketHandle:: -readfrom(std::string & buffer, typename Policy::AddressingPolicy::Address & from) +template +prefix_ void senf::ClientSocketHandle::readfrom(Sequence & container, Address & from, + unsigned limit) { - unsigned nread = available(); - /** \fixme This is not necessary correct and more or less a hack ... */ - buffer.assign(nread,0); - unsigned rv = this->readfrom(const_cast(buffer.data()), nread, from); - if (rv < nread) - buffer.erase(buffer.begin()+rv,buffer.end()); + unsigned nread (available()); + if (limit>0 && nread>limit) + nread = limit; + container.resize(nread); + container.erase(readfrom( std::make_pair(container.begin(), container.end()), from ), + container.end()); } +// senf::ClientSocketHandle::write + template prefix_ unsigned senf::ClientSocketHandle::write(std::string const & data) { @@ -95,6 +136,11 @@ prefix_ unsigned senf::ClientSocketHandle::write(std::string const & dat return written; } +//////////////////////////////////////// +// private members + +// senf::ClientSocketHandle::available + template prefix_ unsigned senf::ClientSocketHandle::available() {