X-Git-Url: http://g0dil.de/git?a=blobdiff_plain;f=Socket%2FClientSocketHandle.ct;h=c6fa8fd4de22ae470902d572ce5e65b264f16bb6;hb=fd3a0e8ac95d1158e9ea661ddf9187b67c70169f;hp=9502fd70b50dff2af91ce00474a75c57f069e0ae;hpb=31d85cd6b8e03c5ecc924ca8892906be1bab702f;p=senf.git diff --git a/Socket/ClientSocketHandle.ct b/Socket/ClientSocketHandle.ct index 9502fd7..c6fa8fd 100644 --- a/Socket/ClientSocketHandle.ct +++ b/Socket/ClientSocketHandle.ct @@ -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 @@ -28,7 +28,8 @@ // Custom includes #include -#include "Utils/Buffer.hh" +#include +#include "../Utils/Buffer.hh" #define prefix_ ///////////////////////////////ct.p//////////////////////////////////////// @@ -60,25 +61,29 @@ readfrom(Handle & handle, ForwardWritableRange & range, typename Handle::Address // senf::detail::WriteRange template -prefix_ typename boost::range_iterator::type +prefix_ typename boost::range_const_iterator::type senf::detail::WriteRange:: write(Handle & handle, ForwardReadableRange & range) { typename boost::range_size::type nwrite (boost::size(range)); + typename boost::range_const_iterator::type i (boost::begin(range)); SENF_SCOPED_BUFFER(char, buffer, nwrite); - std::copy(boost::begin(range), boost::end(range), buffer); - return handle.write(std::make_pair(buffer, buffer+nwrite)); + std::copy(i, boost::end(range), buffer); + std::advance(i, handle.write(std::make_pair(buffer, buffer+nwrite)) - buffer); + return i; } template -prefix_ typename boost::range_iterator::type +prefix_ typename boost::range_const_iterator::type senf::detail::WriteRange:: writeto(Handle & handle, ForwardReadableRange & range, typename Handle::Address const & addr) { typename boost::range_size::type nwrite (boost::size(range)); + typename boost::range_const_iterator::type i (boost::begin(range)); SENF_SCOPED_BUFFER(char, buffer, nwrite); - std::copy(boost::begin(range), boost::end(range), buffer); - return handle.writeto(std::make_pair(buffer, buffer+nwrite), addr); + std::copy(i, boost::end(range), buffer); + std::advance(i, handle.writeto(std::make_pair(buffer, buffer+nwrite), addr) - buffer); + return i; } /////////////////////////////////////////////////////////////////////////// @@ -89,41 +94,40 @@ writeto(Handle & handle, ForwardReadableRange & range, typename Handle::Address // senf::ClientSocketHandle::read -template -prefix_ std::string senf::ClientSocketHandle::read(unsigned limit) +template +prefix_ std::string senf::ClientSocketHandle::read(unsigned limit) { std::string rv; - this->read(rv,limit); + this->read(rv, limit); return rv; } -template +template template -prefix_ void senf::ClientSocketHandle::read(Sequence & container, unsigned limit) +prefix_ void senf::ClientSocketHandle::read(Sequence & container, unsigned limit) { - unsigned nread (available()); - if (limit>0 && nread>limit) - nread = limit; - container.resize(nread); + if (limit == 0) + limit = available(); + container.resize(limit); container.erase(read( std::make_pair(container.begin(), container.end()) ), container.end()); } -// senf::ClientSocketHandle::readfrom +// senf::ClientSocketHandle::readfrom -template -prefix_ std::pair -senf::ClientSocketHandle::readfrom(unsigned limit) +template +prefix_ std::pair +senf::ClientSocketHandle::readfrom(unsigned limit) { std::string rv; - typename Policy::AddressingPolicy::Address addr; - this->readfrom(rv,addr,limit); - return std::make_pair(rv,addr); + boost::value_initialized addr; + this->readfrom(rv, addr.data(), limit); + return std::make_pair(rv, addr.data()); } -template +template template -prefix_ void senf::ClientSocketHandle::readfrom(Sequence & container, Address & from, +prefix_ void senf::ClientSocketHandle::readfrom(Sequence & container, Address & from, unsigned limit) { unsigned nread (available()); @@ -137,10 +141,10 @@ prefix_ void senf::ClientSocketHandle::readfrom(Sequence & container, Ad //////////////////////////////////////// // private members -// senf::ClientSocketHandle::available +// senf::ClientSocketHandle::available -template -prefix_ unsigned senf::ClientSocketHandle::available() +template +prefix_ unsigned senf::ClientSocketHandle::available() { unsigned nread = this->protocol().available(); if (nread == 0 && this->blocking()) { @@ -167,4 +171,5 @@ prefix_ unsigned senf::ClientSocketHandle::available() // indent-tabs-mode: nil // ispell-local-dictionary: "american" // compile-command: "scons -u test" +// comment-column: 40 // End: