add 'iterator'(sequences) and 'key_iterator'(maps). The first returns allways the C++ iterator. In sequences __iter__ returns 'iterator()', in maps, __iter__ returns 'key_iterator()'
git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk@7775 626c5289-ae23-0410-ae9c-e8d60b6d4f22
This commit is contained in:
parent
6508e06af8
commit
51796ebcce
3 changed files with 30 additions and 23 deletions
|
|
@ -4,26 +4,30 @@ a1 = li_std_map.A(3)
|
|||
a2 = li_std_map.A(7)
|
||||
|
||||
|
||||
if 1:
|
||||
p0 = li_std_map.pairii(1,2)
|
||||
p1 = li_std_map.pairA(1,a1.this)
|
||||
m = {}
|
||||
m[1] = a1
|
||||
m[2] = a2
|
||||
|
||||
pp1 = li_std_map.p_identa(p1)
|
||||
mm = li_std_map.m_identa(m)
|
||||
p0 = li_std_map.pairii(1,2)
|
||||
p1 = li_std_map.pairA(1,a1.this)
|
||||
m = {}
|
||||
m[1] = a1
|
||||
m[2] = a2
|
||||
|
||||
pp1 = li_std_map.p_identa(p1)
|
||||
mm = li_std_map.m_identa(m)
|
||||
|
||||
|
||||
|
||||
m = li_std_map.mapA()
|
||||
m[1] = a1
|
||||
m[2] = a2
|
||||
for i in m:
|
||||
if m[i[0]].this != i[1].this:
|
||||
print m[i[0]].this, i[1].this
|
||||
raise RuntimeError
|
||||
m = li_std_map.mapA()
|
||||
m[1] = a1
|
||||
m[2] = a2
|
||||
|
||||
|
||||
pm ={}
|
||||
for k in m:
|
||||
pm[k] = m[k]
|
||||
|
||||
for k in m:
|
||||
if pm[k].this != m[k].this:
|
||||
print pm[k], m[k]
|
||||
raise RuntimeError
|
||||
|
||||
|
||||
|
||||
|
|
|
|||
|
|
@ -623,16 +623,15 @@ namespace swig
|
|||
|
||||
%fragment("PySequence_Cont");
|
||||
|
||||
%newobject output_iterator(PyObject *seq);
|
||||
%newobject iterator(PyObject *PYTHON_SELF);
|
||||
%extend {
|
||||
swig::PySequence_OutputIterator* output_iterator(PyObject *seq) {
|
||||
return swig::make_output_iterator(self->begin(), self->begin(), self->end(), seq);
|
||||
swig::PySequence_OutputIterator* iterator(PyObject **PYTHON_SELF) {
|
||||
return swig::make_output_iterator(self->begin(), self->begin(), self->end(), *PYTHON_SELF);
|
||||
}
|
||||
|
||||
%pythoncode {
|
||||
def __iter__(self):
|
||||
i = self.output_iterator(self)
|
||||
return i
|
||||
return self.iterator()
|
||||
}
|
||||
}
|
||||
#endif //SWIG_EXPORT_ITERATOR_METHODS
|
||||
|
|
|
|||
|
|
@ -140,8 +140,7 @@
|
|||
return self->find(key) != self->end();
|
||||
}
|
||||
|
||||
#if !defined(SWIG_EXPORT_ITERATOR_METHODS) || defined(SWIG_USE_OLD_MAP_ITERATOR)
|
||||
PyObject* __iter__() {
|
||||
PyObject* key_iterator() {
|
||||
Map::size_type size = self->size();
|
||||
int pysize = (size <= (Map::size_type) INT_MAX) ? (int) size : -1;
|
||||
if (pysize < 0) {
|
||||
|
|
@ -162,6 +161,11 @@
|
|||
return keyTuple;
|
||||
%#endif
|
||||
}
|
||||
#if !defined(SWIG_USE_STD_MAP_ITERATOR)
|
||||
%pythoncode {
|
||||
def __iter__(self):
|
||||
return self.key_iterator()
|
||||
}
|
||||
#endif
|
||||
}
|
||||
%enddef
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue