1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67
|
/////////////////////////////////////////////////////////////
// //
// Copyright (c) 2003-2011 by The University of Queensland //
// Earth Systems Science Computational Centre (ESSCC) //
// http://www.uq.edu.au/esscc //
// //
// Primary Business: Brisbane, Queensland, Australia //
// Licensed under the Open Software License version 3.0 //
// http://www.opensource.org/licenses/osl-3.0.php //
// //
/////////////////////////////////////////////////////////////
#ifndef ESYS_LSMVECTORPY_H
#define ESYS_LSMVECTORPY_H
#include <boost/python.hpp>
#include <vector>
#include <iterator>
namespace esys
{
namespace lsm
{
template <typename TmplElem>
class VectorPy : public std::vector<TmplElem>
{
public:
typedef std::vector<TmplElem> Inherited;
typedef typename Inherited::const_reference const_reference;
typedef typename Inherited::reference reference;
class PickleSuite : public boost::python::pickle_suite
{
public:
static
boost::python::tuple
getinitargs(VectorPy const& v);
};
VectorPy();
VectorPy(const VectorPy &vec);
VectorPy(const Inherited &vec);
VectorPy(boost::python::object &iterable);
void append(const_reference e);
size_t getIndex(int i) const;
reference getItem(int i);
void setItem(int i, const_reference e);
static boost::python::class_<VectorPy>
exportVector(
const std::string &pyClassName,
const std::string &pyClassDocString
);
};
}
}
#include "Python/esys/lsm/util/VectorPy.hpp"
#endif
|