2008-05-08 20:05:46 +00:00
|
|
|
// (C) Copyright Jonathan Franklin 2008.
|
|
|
|
// Use, modification and distribution are subject to the
|
|
|
|
// Boost Software License, Version 1.0. (See accompanying file
|
|
|
|
// LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
|
2008-05-08 17:40:52 +00:00
|
|
|
#if ! defined BOOST_ALGORITHM_CLUSTER_CLUSTER_DATA_HPP
|
|
|
|
#define BOOST_ALGORITHM_CLUSTER_CLUSTER_DATA_HPP
|
|
|
|
|
|
|
|
#include <boost/shared_ptr.hpp>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
namespace boost
|
|
|
|
{
|
|
|
|
namespace algorithm
|
|
|
|
{
|
|
|
|
namespace cluster
|
|
|
|
{
|
|
|
|
|
|
|
|
/*! TODO: Document this type.
|
|
|
|
*/
|
2008-05-08 20:05:46 +00:00
|
|
|
template<typename ClusterT>
|
2008-05-08 17:40:52 +00:00
|
|
|
struct cluster_data
|
|
|
|
{
|
2008-05-08 20:05:46 +00:00
|
|
|
typedef ClusterT value_type;
|
2008-05-08 17:40:52 +00:00
|
|
|
typedef std::vector<value_type> clusters;
|
|
|
|
cluster_data() : m_pClusters(new clusters) {}
|
|
|
|
~cluster_data() {}
|
|
|
|
|
|
|
|
cluster_data(cluster_data const & c) : m_pClusters(c.m_pClusters) {}
|
|
|
|
cluster_data const & cluster_data::operator=(cluster_data const & rhs)
|
|
|
|
{ m_pClusters = rhs.m_pClusters; }
|
|
|
|
|
|
|
|
typedef typename clusters::iterator iterator;
|
|
|
|
typedef typename clusters::const_iterator const_iterator;
|
|
|
|
typedef typename clusters::reverse_iterator reverse_iterator;
|
|
|
|
|
|
|
|
iterator begin() { return m_pClusters->begin(); }
|
|
|
|
iterator end() { return m_pClusters->end(); }
|
|
|
|
|
|
|
|
const_iterator begin() const { return m_pClusters->begin(); }
|
|
|
|
const_iterator end() const { return m_pClusters->end(); }
|
|
|
|
|
|
|
|
iterator rbegin() { return m_pClusters->rbegin(); }
|
|
|
|
iterator rend() { return m_pClusters->rend(); }
|
|
|
|
|
|
|
|
iterator insert(iterator loc, value_type const & val)
|
|
|
|
{ return m_pClusters->insert(loc, val); }
|
|
|
|
|
|
|
|
void push_back(value_type const & v) { m_pClusters->push_back(v); }
|
|
|
|
void pop_back() { m_pClusters->pop_back(); }
|
|
|
|
|
|
|
|
value_type & back() { return m_pClusters->back(); }
|
|
|
|
value_type const & back() const { return m_pClusters->back(); }
|
|
|
|
|
|
|
|
private:
|
|
|
|
boost::shared_ptr<clusters> m_pClusters;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // End of namespace cluster
|
|
|
|
|
|
|
|
// TODO: Should we be exporting this?
|
|
|
|
using namespace cluster;
|
|
|
|
|
|
|
|
} // End of namespace algorithm
|
|
|
|
|
|
|
|
} // End of namespace boost
|
|
|
|
|
|
|
|
#endif // BOOST_ALGORITHM_CLUSTER_CLUSTER_DATA_HPP
|