#ifndef BATCHED_APPEND_H #define BATCHED_APPEND_H #include <algorithm> //swap #include <cstddef> template <class SRange,class Vector> void batched_append(Vector &v,SRange const& s) { std::size_t news=v.size()+s.size(); v.reserve(news); v.insert(v.end(),s.begin(),s.end()); } //destroys input s, but moves its resources to the end of v. //TODO: use move ctor in c++0x template <class SRange,class Vector> void batched_append_swap(Vector &v,SRange & s) { using namespace std; // to find the right swap via ADL size_t i=v.size(); size_t news=i+s.size(); v.resize(news); typename SRange::iterator si=s.begin(); for (;i<news;++i,++si) swap(v[i],*si); s.clear(); } #endif