| /* |
| Sets |
| */ |
| |
| %fragment("StdSetTraits","header",fragment="StdSequenceTraits") |
| %{ |
| namespace swig { |
| template <class SwigPySeq, class T> |
| inline void |
| assign(const SwigPySeq& swigpyseq, std::set<T>* seq) { |
| // seq->insert(swigpyseq.begin(), swigpyseq.end()); // not used as not always implemented |
| typedef typename SwigPySeq::value_type value_type; |
| typename SwigPySeq::const_iterator it = swigpyseq.begin(); |
| for (;it != swigpyseq.end(); ++it) { |
| seq->insert(seq->end(),(value_type)(*it)); |
| } |
| } |
| |
| template <class T> |
| struct traits_asptr<std::set<T> > { |
| static int asptr(PyObject *obj, std::set<T> **s) { |
| return traits_asptr_stdseq<std::set<T> >::asptr(obj, s); |
| } |
| }; |
| |
| template <class T> |
| struct traits_from<std::set<T> > { |
| static PyObject *from(const std::set<T>& vec) { |
| return traits_from_stdseq<std::set<T> >::from(vec); |
| } |
| }; |
| } |
| %} |
| |
| %define %swig_set_methods(set...) |
| %swig_sequence_iterator(set); |
| %swig_container_methods(set); |
| |
| %extend { |
| void append(value_type x) { |
| self->insert(x); |
| } |
| |
| bool __contains__(value_type x) { |
| return self->find(x) != self->end(); |
| } |
| |
| value_type __getitem__(difference_type i) const throw (std::out_of_range) { |
| return *(swig::cgetpos(self, i)); |
| } |
| |
| }; |
| %enddef |
| |
| %include <std/std_set.i> |