Index: swig/Lib/python/std_carray.i |
=================================================================== |
--- swig/Lib/python/std_carray.i (revision 0) |
+++ swig/Lib/python/std_carray.i (revision 0) |
@@ -0,0 +1,54 @@ |
+%include <pycontainer.swg> |
+ |
+ |
+%fragment("StdCarrayTraits","header",fragment="StdSequenceTraits") |
+{ |
+namespace swig { |
+ template <class T, size_t S> |
+ struct traits_asptr<std::carray<T, S> > { |
+ static int asptr(PyObject *obj, std::carray<T, S> **array) { |
+ return traits_asptr_stdseq<std::carray<T, S> >::asptr(obj, array); |
+ } |
+ }; |
+} |
+} |
+ |
+%warnfilter(SWIGWARN_IGNORE_OPERATOR_INDEX) std::carray::operator[]; |
+ |
+%extend std::carray { |
+ %fragment(SWIG_Traits_frag(std::carray<_Type, _Size >), "header", |
+ fragment="SwigPyIterator_T", |
+ fragment=SWIG_Traits_frag(_Type), |
+ fragment="StdCarrayTraits") { |
+ namespace swig { |
+ template <> struct traits<std::carray<_Type, _Size > > { |
+ typedef pointer_category category; |
+ static const char* type_name() { |
+ return "std::carray<" #_Type "," #_Size " >"; |
+ } |
+ }; |
+ } |
+ } |
+ |
+ %typemaps_asptr(SWIG_TYPECHECK_VECTOR, swig::asptr, |
+ SWIG_Traits_frag(std::carray<_Type, _Size >), |
+ std::carray<_Type, _Size >); |
+ |
+ %typemap(out,noblock=1) iterator, const_iterator { |
+ $result = SWIG_NewPointerObj(swig::make_output_iterator((const $type &)$1), |
+ swig::SwigPyIterator::descriptor(),SWIG_POINTER_OWN); |
+ } |
+ |
+ inline size_t __len__() const { return self->size(); } |
+ |
+ inline const _Type& __getitem__(size_t i) const { return (*self)[i]; } |
+ |
+ inline void __setitem__(size_t i, const _Type& v) { (*self)[i] = v; } |
+ |
+ |
+ swig::SwigPyIterator* __iter__(PyObject **PYTHON_SELF) { |
+ return swig::make_output_iterator(self->begin(), self->begin(), self->end(), *PYTHON_SELF); |
+ } |
+} |
+ |
+%include <std/std_carray.swg> |