// $Id$ // // Copyright (C) 2006 // Fraunhofer Institute for Open Communication Systems (FOKUS) // // The contents of this file are subject to the Fraunhofer FOKUS Public License // Version 1.0 (the "License"); you may not use this file except in compliance // with the License. You may obtain a copy of the License at // http://senf.berlios.de/license.html // // The Fraunhofer FOKUS Public License Version 1.0 is based on, // but modifies the Mozilla Public License Version 1.1. // See the full license text for the amendments. // // Software distributed under the License is distributed on an "AS IS" basis, // WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License // for the specific language governing rights and limitations under the License. // // The Original Code is Fraunhofer FOKUS code. // // The Initial Developer of the Original Code is Fraunhofer-Gesellschaft e.V. // (registered association), Hansastraße 27 c, 80686 Munich, Germany. // All Rights Reserved. // // Contributor(s): // Stefan Bund /** \file \brief ClientSocketHandle inline template implementation */ #include "ClientSocketHandle.ih" // Custom includes #include #define prefix_ inline //-///////////////////////////////////////////////////////////////////////////////////////////////// //-///////////////////////////////////////////////////////////////////////////////////////////////// // senf::detail::ReadRange template prefix_ typename boost::range_iterator::type senf::detail::ReadRange::read(Handle & handle, ForwardWritableRange & range) { typename boost::range_iterator::type const i (boost::begin(range)); char * const ic (reinterpret_cast(storage_iterator(i))); return i + (handle.read( ic, reinterpret_cast(storage_iterator(boost::end(range))) ) - ic); } template prefix_ typename boost::range_iterator::type senf::detail::ReadRange:: readfrom(Handle & handle, ForwardWritableRange & range, typename Handle::Address & addr) { typename boost::range_iterator::type const i (boost::begin(range)); char * const ic (reinterpret_cast(storage_iterator(i))); return i + (handle.readfrom( ic, reinterpret_cast(storage_iterator(boost::end(range))), addr ) - ic); } //-///////////////////////////////////////////////////////////////////////////////////////////////// // senf::detail::WriteRange template prefix_ typename boost::range_const_iterator::type senf::detail::WriteRange:: write(Handle & handle, ForwardReadableRange & range) { typename boost::range_const_iterator::type i (boost::const_begin(range)); char const * const ic (reinterpret_cast(storage_iterator(i))); std::advance(i, handle.write(ic, reinterpret_cast( storage_iterator(boost::const_end(range)))) - ic); return i; } template prefix_ typename boost::range_const_iterator::type senf::detail::WriteRange:: writeto(Handle & handle, ForwardReadableRange & range, typename Handle::Address const & addr) { typename boost::range_const_iterator::type i (boost::const_begin(range)); char const * const ic (reinterpret_cast(storage_iterator(i))); std::advance(i, handle.writeto(addr, ic, reinterpret_cast( storage_iterator(boost::const_end(range)))) - ic); return i; } //-///////////////////////////////////////////////////////////////////////////////////////////////// // senf::ClientSocketHandle //-///////////////////////////////////////////////////////////////////////////////////////////////// // structors template prefix_ senf::ClientSocketHandle::ClientSocketHandle() {} #ifndef DOXYGEN template template prefix_ senf::ClientSocketHandle:: ClientSocketHandle(ClientSocketHandle other, typename SocketHandle::template IsCompatible::type *) : SocketHandle(other,true) {} #else template template prefix_ senf::ClientSocketHandle:: ClientSocketHandle(ClientSocketHandle other) {} #endif template prefix_ senf::ClientSocketHandle::ClientSocketHandle(FileHandle other, bool isChecked) : SocketHandle(other, isChecked) {} template prefix_ senf::ClientSocketHandle::ClientSocketHandle(std::auto_ptr body) : SocketHandle(body) {} #ifndef DOXYGEN template template prefix_ typename senf::SocketHandle::template IsCompatible::type const & senf::ClientSocketHandle::operator=(ClientSocketHandle other) { assign(other); return *this; } #else template template prefix_ OtherPolicy const & senf::ClientSocketHandle::operator=(ClientSocketHandle other) {} #endif //-///////////////////////////////////////////////////////////////////////////////////////////////// // reading and writing // senf::ClientSocketHandle::read #ifndef DOXYGEN template template prefix_ typename boost::disable_if, typename boost::range_iterator::type>::type senf::ClientSocketHandle::read(ForwardWritableRange const & range) { return detail::ReadRange< ClientSocketHandle, ForwardWritableRange const, contiguous_storage_iterator< typename boost::range_iterator::type >::value && sizeof(typename boost::range_value::type)==sizeof(char) >::read(*this, range); } #else template template prefix_ typename boost::range_iterator::type senf::ClientSocketHandle:: read(ForwardWritableRange const & range) {} #endif #ifndef DOXYGEN template template prefix_ typename boost::disable_if, typename boost::range_iterator::type>::type senf::ClientSocketHandle::read(ForwardWritableRange & range) { return detail::ReadRange< ClientSocketHandle, ForwardWritableRange, contiguous_storage_iterator< typename boost::range_iterator::type >::value && sizeof(typename boost::range_value::type)==sizeof(char) >::read(*this, range); } #else template template prefix_ typename boost::range_iterator::type senf::ClientSocketHandle:: read(ForwardWritableRange & range) {} #endif template prefix_ char * senf::ClientSocketHandle::read(char * start, char * end) { return start + SPolicy::ReadPolicy::read(*this, start, end-start); } // senf::ClientSocketHandle::readfrom template template prefix_ typename boost::range_iterator::type senf::ClientSocketHandle::readfrom(ForwardWritableRange const & range, Address & from) { return detail::ReadRange< ClientSocketHandle, ForwardWritableRange const, contiguous_storage_iterator< typename boost::range_iterator::type >::value && sizeof(typename boost::range_value::type)==sizeof(char) >::readfrom(*this, range, from); } template template prefix_ typename boost::range_iterator::type senf::ClientSocketHandle::readfrom(ForwardWritableRange & range, Address & from) { return detail::ReadRange< ClientSocketHandle, ForwardWritableRange, contiguous_storage_iterator< typename boost::range_iterator::type >::value && sizeof(typename boost::range_value::type)==sizeof(char) >::readfrom(*this, range, from); } template prefix_ char * senf::ClientSocketHandle::readfrom(char * start, char * end, Address & from) { return start + SPolicy::ReadPolicy::readfrom(*this, start, end-start, from); } // senf::ClientSocketHandle::write template template prefix_ typename boost::range_const_iterator::type senf::ClientSocketHandle::write(ForwardReadableRange const & range) { return detail::WriteRange< ClientSocketHandle, ForwardReadableRange const, contiguous_storage_iterator< typename boost::range_iterator::type >::value && sizeof(typename boost::range_value::type)==sizeof(char) >::write(*this, range); } template prefix_ char const * senf::ClientSocketHandle::write(char const * start, char const * end) { return start + SPolicy::WritePolicy::write(*this, start, end-start); } // senf::ClientSocketHandle::writeto template template prefix_ typename boost::range_const_iterator::type senf::ClientSocketHandle::writeto(AddressParam addr, ForwardReadableRange const & range) { return detail::WriteRange< ClientSocketHandle, ForwardReadableRange const, contiguous_storage_iterator< typename boost::range_iterator::type >::value && sizeof(typename boost::range_value::type)==sizeof(char) >::writeto(*this, range, addr); } template prefix_ char const * senf::ClientSocketHandle::writeto(AddressParam addr, char const * start, char const * end) { return start + SPolicy::WritePolicy::writeto(*this, addr, start, end-start); } //-///////////////////////////////////////////////////////////////////////////////////////////////// // addressing // senf::ClientSocketHandle::peer template prefix_ typename SPolicy::AddressingPolicy::Address senf::ClientSocketHandle::peer() const { typename SPolicy::AddressingPolicy::Address addr; this->peer(addr); return addr; } template prefix_ void senf::ClientSocketHandle:: peer(typename SPolicy::AddressingPolicy::Address & addr) const { SPolicy::AddressingPolicy::peer(*this, addr); } // senf::ClientSocketHandle::local template prefix_ typename SPolicy::AddressingPolicy::Address senf::ClientSocketHandle::local() const { typename SPolicy::AddressingPolicy::Address addr; this->local(addr); return addr; } template prefix_ void senf::ClientSocketHandle:: local(typename SPolicy::AddressingPolicy::Address & addr) const { SPolicy::AddressingPolicy::local(*this,addr); } // senf::ClientSocketHandle::connect template prefix_ void senf::ClientSocketHandle::connect(AddressParam addr) const { SPolicy::AddressingPolicy::connect(*this, addr); } // senf::ClientSocketHandle::bind template prefix_ void senf::ClientSocketHandle::bind(AddressParam addr) const { SPolicy::AddressingPolicy::bind(*this, addr); } //-///////////////////////////////////////////////////////////////////////////////////////////////// // Casting template prefix_ senf::ClientSocketHandle senf::ClientSocketHandle::cast_static(FileHandle handle) { return ClientSocketHandle(handle, true); } template prefix_ senf::ClientSocketHandle senf::ClientSocketHandle::cast_dynamic(FileHandle handle) { SocketHandle h (SocketHandle::cast_dynamic(handle)); if (static_cast(FileHandle::body(h)).isServer()) throw std::bad_cast(); return cast_static(handle); } //-///////////////////////////////////////////////////////////////////////////////////////////////// // State information template prefix_ void senf::ClientSocketHandle::state(SocketStateMap & map, unsigned lod) { map["handle"] = prettyName(typeid(*this)); if (this->valid()) { map["valid"] << "true"; this->body().state(map,lod); } else map["valid"] << "false"; } template prefix_ std::string senf::ClientSocketHandle::dumpState(unsigned lod) { SocketStateMap map; state(map,lod); return detail::dumpState(map); } //-///////////////////////////////////////////////////////////////////////////////////////////////// #undef prefix_ // 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: