// $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 VectorParser non-inline template implementation */ #include "VectorParser.ih" // Custom includes #define prefix_ //-///////////////////////////////////////////////////////////////////////////////////////////////// //-///////////////////////////////////////////////////////////////////////////////////////////////// // senf::VectorParser template prefix_ void senf::VectorParser::init() const { AuxPolicy::aux(0, i(), state()); iterator i (begin()); iterator const e (end()); for (; i!=e; ++i) i->init(); } //-///////////////////////////////////////////////////////////////////////////////////////////////// // senf::VectorParser_Container template prefix_ void senf::VectorParser_Container::init() const { iterator i (begin()); iterator const e (end()); for (; i!=e; ++i) i->init(); } // Mutators template prefix_ typename senf::VectorParser_Container::iterator senf::VectorParser_Container::shift(iterator pos, size_type n) { size_type ix (std::distance(data().begin(),pos.raw())); setSize(size()+n); data().insert(pos.raw(),n*ElementParser::fixed_bytes,0); return iterator(boost::next(data().begin(),ix),state()); } template template prefix_ void senf::VectorParser_Container::insert(iterator pos, size_type n, Value const & t) { for (iterator j (shift(pos,n)); n; --n, ++j) *j << t; } #ifndef DOXYGEN template template prefix_ void senf::VectorParser_Container:: insert(iterator pos, ForwardIterator f, ForwardIterator l, typename boost::disable_if< boost::is_convertible >::type *) { for (iterator j (shift(pos,std::distance(f,l))); f!=l; ++f,++j) *j << *f; } #else template template prefix_ void senf::VectorParser_Container:: insert(iterator pos, ForwardIterator f, ForwardIterator l) {} #endif template prefix_ void senf::VectorParser_Container::resize(size_type n) { if (size()>=n) erase(boost::next(begin(),n),end()); else push_back_space(n-size()); } template template prefix_ void senf::VectorParser_Container::resize(size_type n, Value value) { if (size()>=n) erase(boost::next(begin(),n),end()); else push_back(value,n-size()); } //-///////////////////////////////////////////////////////////////////////////////////////////////// #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: