Fixed swig::ConstIterator to use a GC_VALUE
instead of a normal value. Fixed container iterator typemaps to pass self in as sequence (this makes iterator print itself ok) Fixed typo in rubycomplex comment. git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk@9790 626c5289-ae23-0410-ae9c-e8d60b6d4f22
This commit is contained in:
parent
6b68617166
commit
d162646475
3 changed files with 348 additions and 280 deletions
|
|
@ -4,7 +4,7 @@
|
|||
the complex Constructor method, and the Real and Imag complex
|
||||
accesor methods.
|
||||
|
||||
See the std_complex.i and ccomplex.i for concret examples.
|
||||
See the std_complex.i and ccomplex.i for concrete examples.
|
||||
*/
|
||||
|
||||
/*
|
||||
|
|
|
|||
|
|
@ -163,6 +163,14 @@ namespace swig {
|
|||
{
|
||||
namespace swig
|
||||
{
|
||||
|
||||
/**
|
||||
* This class is a proxy class for references, used to return and set values
|
||||
* of an element of a Ruby Array of stuff.
|
||||
* It can be used by RubySequence_InputIterator to make it work with STL
|
||||
* algorithms.
|
||||
*
|
||||
*/
|
||||
template <class T>
|
||||
struct RubySequence_Ref
|
||||
{
|
||||
|
|
@ -201,6 +209,14 @@ namespace swig
|
|||
int _index;
|
||||
};
|
||||
|
||||
|
||||
/**
|
||||
* This class is a proxy to return a pointer to a class, usually
|
||||
* RubySequence_Ref.
|
||||
* It can be used by RubySequence_InputIterator to make it work with STL
|
||||
* algorithms.
|
||||
*
|
||||
*/
|
||||
template <class T>
|
||||
struct RubySequence_ArrowProxy
|
||||
{
|
||||
|
|
@ -210,7 +226,13 @@ namespace swig
|
|||
T m_value;
|
||||
};
|
||||
|
||||
template <class T, class Reference >
|
||||
|
||||
/**
|
||||
* Input Iterator. This adapator class is a random access iterator that
|
||||
* allows you to use STL algorithms with a Ruby class (a Ruby Array by default).
|
||||
*
|
||||
*/
|
||||
template <class T, class Reference = RubySequence_Ref< T > >
|
||||
struct RubySequence_InputIterator
|
||||
{
|
||||
typedef RubySequence_InputIterator<T, Reference > self;
|
||||
|
|
@ -219,7 +241,7 @@ namespace swig
|
|||
typedef Reference reference;
|
||||
typedef T value_type;
|
||||
typedef T* pointer;
|
||||
typedef int difference_type;
|
||||
typedef ptrdiff_t difference_type;
|
||||
|
||||
RubySequence_InputIterator()
|
||||
{
|
||||
|
|
@ -306,6 +328,11 @@ namespace swig
|
|||
};
|
||||
|
||||
|
||||
/**
|
||||
* This adaptor class allows you to use a Ruby Array as if it was an STL
|
||||
* container, giving it begin(), end(), and iterators.
|
||||
*
|
||||
*/
|
||||
template <class T>
|
||||
struct RubySequence_Cont
|
||||
{
|
||||
|
|
@ -404,22 +431,24 @@ namespace swig
|
|||
|
||||
%typemap(out,noblock=1,fragment="RubySequence_Cont")
|
||||
const_iterator, const_reverse_iterator {
|
||||
$result = SWIG_NewPointerObj(swig::make_output_iterator(%static_cast($1,const $type &)),
|
||||
$result = SWIG_NewPointerObj(swig::make_const_iterator(%static_cast($1,const $type &),
|
||||
self),
|
||||
swig::ConstIterator::descriptor(),SWIG_POINTER_OWN);
|
||||
}
|
||||
|
||||
%typemap(out,noblock=1,fragment="RubySequence_Cont")
|
||||
iterator, reverse_iterator {
|
||||
$result = SWIG_NewPointerObj(swig::make_inout_iterator(%static_cast($1,const $type &)),
|
||||
$result = SWIG_NewPointerObj(swig::make_nonconst_iterator(%static_cast($1,const $type &),
|
||||
self),
|
||||
swig::Iterator::descriptor(),SWIG_POINTER_OWN);
|
||||
}
|
||||
|
||||
%typemap(out,noblock=1,fragment="RubySequence_Cont")
|
||||
std::pair<const_iterator, const_iterator> {
|
||||
$result = rb_ary_new2(2);
|
||||
RARRAY_PTR($result)[0] = SWIG_NewPointerObj(swig::make_output_iterator(%static_cast($1,const $type &).first),
|
||||
RARRAY_PTR($result)[0] = SWIG_NewPointerObj(swig::make_const_iterator(%static_cast($1,const $type &).first),
|
||||
swig::ConstIterator::descriptor(),SWIG_POINTER_OWN);
|
||||
RARRAY_PTR($result)[1] = SWIG_NewPointerObj(swig::make_output_iterator(%static_cast($1,const $type &).second),
|
||||
RARRAY_PTR($result)[1] = SWIG_NewPointerObj(swig::make_const_iterator(%static_cast($1,const $type &).second),
|
||||
swig::ConstIterator::descriptor(),SWIG_POINTER_OWN);
|
||||
RARRAY_LEN($result) = 2;
|
||||
}
|
||||
|
|
@ -427,9 +456,9 @@ namespace swig
|
|||
%typemap(out,noblock=1,fragment="RubySequence_Cont")
|
||||
std::pair<iterator, iterator> {
|
||||
$result = rb_ary_new2(2);
|
||||
RARRAY_PTR($result)[0] = SWIG_NewPointerObj(swig::make_inout_iterator(%static_cast($1,const $type &).first),
|
||||
RARRAY_PTR($result)[0] = SWIG_NewPointerObj(swig::make_nonconst_iterator(%static_cast($1,const $type &).first),
|
||||
swig::Iterator::descriptor(),SWIG_POINTER_OWN);
|
||||
RARRAY_PTR($result)[1] = SWIG_NewPointerObj(swig::make_inout_iterator(%static_cast($1,const $type &).second),
|
||||
RARRAY_PTR($result)[1] = SWIG_NewPointerObj(swig::make_nonconst_iterator(%static_cast($1,const $type &).second),
|
||||
swig::Iterator::descriptor(),SWIG_POINTER_OWN);
|
||||
RARRAY_LEN($result) = 2;
|
||||
}
|
||||
|
|
@ -440,7 +469,7 @@ namespace swig
|
|||
%typemap(out,noblock=1,fragment="RubyPairBoolOutputIterator")
|
||||
std::pair<const_iterator, bool> {
|
||||
$result = rb_ary_new2(2);
|
||||
RARRAY_PTR($result)[0] = SWIG_NewPointerObj(swig::make_output_iterator(%static_cast($1,const $type &).first),
|
||||
RARRAY_PTR($result)[0] = SWIG_NewPointerObj(swig::make_const_iterator(%static_cast($1,const $type &).first),
|
||||
swig::ConstIterator::descriptor(),SWIG_POINTER_OWN);
|
||||
RARRAY_PTR($result)[1] = SWIG_From(bool)(%static_cast($1,const $type &).second);
|
||||
RARRAY_LEN($result) = 2;
|
||||
|
|
@ -449,7 +478,7 @@ namespace swig
|
|||
%typemap(out,noblock=1,fragment="RubyPairBoolOutputIterator")
|
||||
std::pair<iterator, bool> {
|
||||
$result = rb_ary_new2(2);
|
||||
RARRAY_PTR($result)[0] = SWIG_NewPointerObj(swig::make_inout_iterator(%static_cast($1,const $type &).first),
|
||||
RARRAY_PTR($result)[0] = SWIG_NewPointerObj(swig::make_nonconst_iterator(%static_cast($1,const $type &).first),
|
||||
swig::Iterator::descriptor(),SWIG_POINTER_OWN);
|
||||
RARRAY_PTR($result)[1] = SWIG_From(bool)(%static_cast($1,const $type &).second);
|
||||
RARRAY_LEN($result) = 2;
|
||||
|
|
@ -491,7 +520,8 @@ namespace swig
|
|||
%typecheck(%checkcode(ITERATOR),noblock=1,fragment="RubySequence_Cont")
|
||||
const_iterator, const_reverse_iterator {
|
||||
swig::ConstIterator *iter = 0;
|
||||
int res = SWIG_ConvertPtr($input, %as_voidptrptr(&iter), swig::ConstIterator::descriptor(), 0);
|
||||
int res = SWIG_ConvertPtr($input, %as_voidptrptr(&iter),
|
||||
swig::ConstIterator::descriptor(), 0);
|
||||
$1 = (SWIG_IsOK(res) && iter && (dynamic_cast<swig::ConstIterator_T<$type > *>(iter) != 0));
|
||||
}
|
||||
|
||||
|
|
@ -509,12 +539,12 @@ namespace swig
|
|||
// %newobject const_iterator;
|
||||
// %extend {
|
||||
// swig::Iterator* iterator(VALUE* RUBY_SELF) {
|
||||
// return swig::make_inout_iterator($self->begin(), $self->begin(),
|
||||
// $self->end(), *RUBY_SELF);
|
||||
// return swig::make_nonconst_iterator($self->begin(), $self->begin(),
|
||||
// $self->end(), *RUBY_SELF);
|
||||
// }
|
||||
|
||||
// swig::ConstIterator* const_iterator(VALUE* RUBY_SELF) {
|
||||
// return swig::make_output_iterator($self->begin(), $self->begin(),
|
||||
// return swig::make_const_iterator($self->begin(), $self->begin(),
|
||||
// $self->end(), *RUBY_SELF);
|
||||
// }
|
||||
// }
|
||||
|
|
|
|||
|
|
@ -15,70 +15,102 @@
|
|||
%include <std_common.i>
|
||||
|
||||
|
||||
/**
|
||||
* Abstract base class used to represent all iterators of STL containers.
|
||||
*/
|
||||
%fragment("ConstIterator","header") {
|
||||
namespace swig {
|
||||
struct stop_iteration {
|
||||
};
|
||||
|
||||
/**
|
||||
* Abstract base class used to represent all iterators of STL containers.
|
||||
*/
|
||||
struct ConstIterator {
|
||||
public:
|
||||
typedef ConstIterator self_type;
|
||||
|
||||
protected:
|
||||
VALUE _seq;
|
||||
GC_VALUE _seq;
|
||||
|
||||
protected:
|
||||
ConstIterator(VALUE seq) : _seq(seq)
|
||||
{
|
||||
}
|
||||
|
||||
// Random access iterator methods, but not required in Ruby
|
||||
virtual ptrdiff_t distance(const ConstIterator &x) const
|
||||
{
|
||||
throw std::invalid_argument("distance not supported");
|
||||
}
|
||||
|
||||
virtual bool equal (const ConstIterator &x) const
|
||||
{
|
||||
throw std::invalid_argument("equal not supported");
|
||||
}
|
||||
|
||||
virtual self_type* advance(ptrdiff_t n)
|
||||
{
|
||||
throw std::invalid_argument("advance not supported");
|
||||
}
|
||||
|
||||
public:
|
||||
virtual ~ConstIterator() {}
|
||||
|
||||
// Access iterator method, required by Ruby
|
||||
virtual VALUE value() const = 0;
|
||||
virtual VALUE value() const {
|
||||
throw std::invalid_argument("value not supported");
|
||||
return Qnil;
|
||||
};
|
||||
|
||||
// Forward iterator method, required by Ruby
|
||||
virtual ConstIterator *incr(size_t n = 1) = 0;
|
||||
|
||||
// Backward iterator method, very common in C++, but not required in Ruby
|
||||
virtual ConstIterator *decr(size_t n = 1)
|
||||
{
|
||||
throw stop_iteration();
|
||||
virtual VALUE setValue( const VALUE& v ) {
|
||||
throw std::invalid_argument("value= not supported");
|
||||
return Qnil;
|
||||
}
|
||||
|
||||
// Random access iterator methods, but not required in Ruby
|
||||
virtual ptrdiff_t distance(const ConstIterator &x) const
|
||||
virtual self_type* next( size_t n = 1 )
|
||||
{
|
||||
throw std::invalid_argument("operation not supported");
|
||||
return this->advance( n );
|
||||
}
|
||||
|
||||
virtual bool equal (const ConstIterator &x) const
|
||||
virtual self_type* previous( size_t n = 1 )
|
||||
{
|
||||
throw std::invalid_argument("operation not supported");
|
||||
return this->advance( -n );
|
||||
}
|
||||
|
||||
virtual VALUE to_s() const {
|
||||
throw std::invalid_argument("to_s not supported");
|
||||
return Qnil;
|
||||
}
|
||||
|
||||
virtual VALUE inspect() const {
|
||||
throw std::invalid_argument("inspect not supported");
|
||||
return Qnil;
|
||||
}
|
||||
|
||||
// C++ common/needed methods
|
||||
virtual ConstIterator *dup() const = 0;
|
||||
|
||||
VALUE next()
|
||||
virtual ConstIterator *dup() const
|
||||
{
|
||||
VALUE obj = value();
|
||||
incr();
|
||||
return obj;
|
||||
throw std::invalid_argument("dup not supported");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
VALUE previous()
|
||||
//
|
||||
// C++ common/needed methods. We emulate a bidirectional
|
||||
// operator, to be compatible with all the STL.
|
||||
// The iterator traits will then tell the STL what type of
|
||||
// iterator we really are.
|
||||
//
|
||||
ConstIterator() : _seq( Qnil )
|
||||
{
|
||||
decr();
|
||||
return value();
|
||||
}
|
||||
|
||||
ConstIterator *advance(ptrdiff_t n)
|
||||
ConstIterator( const self_type& b ) : _seq( b._seq )
|
||||
{
|
||||
return (n > 0) ? incr(n) : decr(-n);
|
||||
}
|
||||
|
||||
|
||||
self_type& operator=( const self_type& b )
|
||||
{
|
||||
_seq = b._seq;
|
||||
return *this;
|
||||
}
|
||||
|
||||
bool operator == (const ConstIterator& x) const
|
||||
{
|
||||
return equal(x);
|
||||
|
|
@ -89,6 +121,34 @@ namespace swig {
|
|||
return ! operator==(x);
|
||||
}
|
||||
|
||||
// Pre-decrement operator
|
||||
self_type& operator--()
|
||||
{
|
||||
return *previous();
|
||||
}
|
||||
|
||||
// Pre-increment operator
|
||||
self_type& operator++()
|
||||
{
|
||||
return *next();
|
||||
}
|
||||
|
||||
// Post-decrement operator
|
||||
self_type operator--(int)
|
||||
{
|
||||
self_type r = *this;
|
||||
previous();
|
||||
return r;
|
||||
}
|
||||
|
||||
// Post-increment operator
|
||||
self_type operator++(int)
|
||||
{
|
||||
self_type r = *this;
|
||||
next();
|
||||
return r;
|
||||
}
|
||||
|
||||
ConstIterator& operator += (ptrdiff_t n)
|
||||
{
|
||||
return *advance(n);
|
||||
|
|
@ -98,7 +158,7 @@ namespace swig {
|
|||
{
|
||||
return *advance(-n);
|
||||
}
|
||||
|
||||
|
||||
ConstIterator* operator + (ptrdiff_t n) const
|
||||
{
|
||||
return dup()->advance(n);
|
||||
|
|
@ -123,22 +183,28 @@ namespace swig {
|
|||
}
|
||||
return desc;
|
||||
}
|
||||
|
||||
// Ruby common/needed printing methods
|
||||
virtual VALUE inspect() const = 0;
|
||||
virtual VALUE to_s() const = 0;
|
||||
};
|
||||
|
||||
|
||||
/**
|
||||
* Abstract base class used to represent all non-const iterators of STL containers.
|
||||
*
|
||||
*/
|
||||
struct Iterator : public ConstIterator {
|
||||
public:
|
||||
typedef Iterator self_type;
|
||||
|
||||
protected:
|
||||
Iterator(VALUE seq) : ConstIterator(seq)
|
||||
{
|
||||
}
|
||||
|
||||
public:
|
||||
// Iterator setter method, required by Ruby
|
||||
virtual bool set( const VALUE& v ) = 0;
|
||||
virtual self_type* advance(ptrdiff_t n)
|
||||
{
|
||||
throw std::invalid_argument("operation not supported");
|
||||
}
|
||||
|
||||
public:
|
||||
static swig_type_info* descriptor() {
|
||||
static int init = 0;
|
||||
static swig_type_info* desc = 0;
|
||||
|
|
@ -148,15 +214,23 @@ namespace swig {
|
|||
}
|
||||
return desc;
|
||||
}
|
||||
|
||||
// C++ common/needed methods
|
||||
virtual Iterator *dup() const = 0;
|
||||
|
||||
Iterator *advance(ptrdiff_t n)
|
||||
|
||||
virtual Iterator *dup() const
|
||||
{
|
||||
return (Iterator*) ( (n > 0) ? incr(n) : decr(-n) );
|
||||
throw std::invalid_argument("dup not supported");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
virtual self_type* next( size_t n = 1 )
|
||||
{
|
||||
return this->advance( n );
|
||||
}
|
||||
|
||||
virtual self_type* previous( size_t n = 1 )
|
||||
{
|
||||
return this->advance( -n );
|
||||
}
|
||||
|
||||
bool operator == (const ConstIterator& x) const
|
||||
{
|
||||
return equal(x);
|
||||
|
|
@ -201,29 +275,21 @@ namespace swig {
|
|||
namespace swig {
|
||||
|
||||
/**
|
||||
* Abstract base classes for all custom const_iterators.
|
||||
* Templated base classes for all custom const_iterators.
|
||||
*
|
||||
*/
|
||||
template<typename OutConstIterator>
|
||||
class ConstIterator_T : public ConstIterator
|
||||
{
|
||||
public:
|
||||
typedef OutConstIterator out_iterator;
|
||||
typedef typename std::iterator_traits<out_iterator>::value_type value_type;
|
||||
typedef ConstIterator_T<out_iterator> self_type;
|
||||
typedef OutConstIterator const_iter;
|
||||
typedef typename std::iterator_traits<const_iter>::value_type value_type;
|
||||
typedef ConstIterator_T<const_iter> self_type;
|
||||
|
||||
ConstIterator_T(out_iterator curr, VALUE seq = Qnil)
|
||||
: ConstIterator(seq), current(curr)
|
||||
{
|
||||
}
|
||||
|
||||
const out_iterator& get_current() const
|
||||
{
|
||||
return current;
|
||||
}
|
||||
protected:
|
||||
|
||||
|
||||
bool equal (const ConstIterator &iter) const
|
||||
virtual bool equal (const ConstIterator &iter) const
|
||||
{
|
||||
const self_type *iters = dynamic_cast<const self_type *>(&iter);
|
||||
if (iters) {
|
||||
|
|
@ -242,7 +308,24 @@ namespace swig {
|
|||
throw std::invalid_argument("bad iterator type");
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
virtual ConstIterator* advance(ptrdiff_t n)
|
||||
{
|
||||
std::advance( current, n );
|
||||
return this;
|
||||
}
|
||||
|
||||
public:
|
||||
ConstIterator_T(const_iter curr, VALUE seq = Qnil)
|
||||
: ConstIterator(seq), current(curr)
|
||||
{
|
||||
}
|
||||
|
||||
const const_iter& get_current() const
|
||||
{
|
||||
return current;
|
||||
}
|
||||
|
||||
virtual VALUE inspect() const
|
||||
{
|
||||
VALUE ret = rb_str_new2("#<");
|
||||
|
|
@ -264,33 +347,33 @@ namespace swig {
|
|||
}
|
||||
|
||||
protected:
|
||||
out_iterator current;
|
||||
const_iter current;
|
||||
};
|
||||
|
||||
|
||||
/**
|
||||
* Abstract base classes for all custom iterators.
|
||||
* Templated base classes for all custom non-const iterators.
|
||||
*
|
||||
*/
|
||||
template<typename InOutIterator>
|
||||
class Iterator_T : public Iterator
|
||||
{
|
||||
public:
|
||||
typedef InOutIterator inout_iterator;
|
||||
typedef typename std::iterator_traits<inout_iterator>::value_type value_type;
|
||||
typedef Iterator_T<inout_iterator> self_type;
|
||||
typedef InOutIterator nonconst_iter;
|
||||
|
||||
Iterator_T(inout_iterator curr, VALUE seq = Qnil)
|
||||
: Iterator(seq), current(curr)
|
||||
{
|
||||
}
|
||||
// Make this class iterator STL compatible, by using iterator_traits
|
||||
typedef typename std::iterator_traits<nonconst_iter >::iterator_category iterator_category;
|
||||
typedef typename std::iterator_traits<nonconst_iter >::value_type value_type;
|
||||
typedef typename std::iterator_traits<nonconst_iter >::difference_type difference_type;
|
||||
typedef typename std::iterator_traits<nonconst_iter >::pointer pointer;
|
||||
typedef typename std::iterator_traits<nonconst_iter >::reference reference;
|
||||
|
||||
const inout_iterator& get_current() const
|
||||
{
|
||||
return current;
|
||||
}
|
||||
typedef Iterator base;
|
||||
typedef Iterator_T< nonconst_iter > self_type;
|
||||
|
||||
bool equal (const ConstIterator &iter) const
|
||||
protected:
|
||||
|
||||
virtual bool equal (const ConstIterator &iter) const
|
||||
{
|
||||
const self_type *iters = dynamic_cast<const self_type *>(&iter);
|
||||
if (iters) {
|
||||
|
|
@ -309,6 +392,36 @@ namespace swig {
|
|||
throw std::invalid_argument("bad iterator type");
|
||||
}
|
||||
}
|
||||
|
||||
virtual Iterator* advance(ptrdiff_t n)
|
||||
{
|
||||
std::advance( current, n );
|
||||
return this;
|
||||
}
|
||||
|
||||
public:
|
||||
|
||||
Iterator_T(nonconst_iter curr, VALUE seq = Qnil)
|
||||
: Iterator(seq), current(curr)
|
||||
{
|
||||
}
|
||||
|
||||
const nonconst_iter& get_current() const
|
||||
{
|
||||
return current;
|
||||
}
|
||||
|
||||
self_type& operator=( const self_type& b )
|
||||
{
|
||||
base::operator=( b );
|
||||
return *this;
|
||||
}
|
||||
|
||||
self_type& operator=( const value_type& b )
|
||||
{
|
||||
*current = b;
|
||||
return *this;
|
||||
}
|
||||
|
||||
virtual VALUE inspect() const
|
||||
{
|
||||
|
|
@ -331,11 +444,15 @@ namespace swig {
|
|||
}
|
||||
|
||||
protected:
|
||||
inout_iterator current;
|
||||
nonconst_iter current;
|
||||
};
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* Auxiliary functor to store the value of a ruby object inside
|
||||
* a reference of a compatible C++ type. ie: Ruby -> C++
|
||||
*
|
||||
*/
|
||||
template <class ValueType>
|
||||
struct asval_oper
|
||||
{
|
||||
|
|
@ -347,6 +464,11 @@ namespace swig {
|
|||
}
|
||||
};
|
||||
|
||||
/**
|
||||
* Auxiliary functor to return a ruby object from a C++ type.
|
||||
* ie: C++ -> Ruby
|
||||
*
|
||||
*/
|
||||
template <class ValueType>
|
||||
struct from_oper
|
||||
{
|
||||
|
|
@ -370,12 +492,12 @@ namespace swig {
|
|||
{
|
||||
public:
|
||||
FromOper from;
|
||||
typedef OutConstIterator out_iterator;
|
||||
typedef OutConstIterator const_iter;
|
||||
typedef ValueType value_type;
|
||||
typedef ConstIterator_T<out_iterator> base;
|
||||
typedef ConstIterator_T<const_iter> base;
|
||||
typedef ConstIteratorOpen_T<OutConstIterator, ValueType, FromOper> self_type;
|
||||
|
||||
ConstIteratorOpen_T(out_iterator curr, VALUE seq = Qnil)
|
||||
ConstIteratorOpen_T(const_iter curr, VALUE seq = Qnil)
|
||||
: ConstIterator_T<OutConstIterator>(curr, seq)
|
||||
{
|
||||
}
|
||||
|
|
@ -388,22 +510,6 @@ namespace swig {
|
|||
{
|
||||
return new self_type(*this);
|
||||
}
|
||||
|
||||
ConstIterator *incr(size_t n = 1)
|
||||
{
|
||||
while (n--) {
|
||||
++base::current;
|
||||
}
|
||||
return this;
|
||||
}
|
||||
|
||||
ConstIterator *decr(size_t n = 1)
|
||||
{
|
||||
while (n--) {
|
||||
--base::current;
|
||||
}
|
||||
return this;
|
||||
}
|
||||
};
|
||||
|
||||
/**
|
||||
|
|
@ -419,12 +525,13 @@ namespace swig {
|
|||
public:
|
||||
FromOper from;
|
||||
AsvalOper asval;
|
||||
typedef InOutIterator inout_iterator;
|
||||
typedef InOutIterator nonconst_iter;
|
||||
typedef ValueType value_type;
|
||||
typedef Iterator_T<inout_iterator> base;
|
||||
typedef Iterator_T<nonconst_iter> base;
|
||||
typedef IteratorOpen_T<InOutIterator, ValueType, FromOper, AsvalOper> self_type;
|
||||
|
||||
IteratorOpen_T(inout_iterator curr, VALUE seq = Qnil)
|
||||
|
||||
public:
|
||||
IteratorOpen_T(nonconst_iter curr, VALUE seq = Qnil)
|
||||
: Iterator_T<InOutIterator>(curr, seq)
|
||||
{
|
||||
}
|
||||
|
|
@ -433,32 +540,17 @@ namespace swig {
|
|||
return from(static_cast<const value_type&>(*(base::current)));
|
||||
}
|
||||
|
||||
virtual bool set( const VALUE& v )
|
||||
virtual VALUE setValue( const VALUE& v )
|
||||
{
|
||||
value_type& dst = *base::current;
|
||||
return asval(v, dst);
|
||||
if ( asval(v, dst) ) return v;
|
||||
return Qnil;
|
||||
}
|
||||
|
||||
Iterator *dup() const
|
||||
{
|
||||
return new self_type(*this);
|
||||
}
|
||||
|
||||
Iterator *incr(size_t n = 1)
|
||||
{
|
||||
while (n--) {
|
||||
++base::current;
|
||||
}
|
||||
return this;
|
||||
}
|
||||
|
||||
Iterator *decr(size_t n = 1)
|
||||
{
|
||||
while (n--) {
|
||||
--base::current;
|
||||
}
|
||||
return this;
|
||||
}
|
||||
};
|
||||
|
||||
/**
|
||||
|
|
@ -472,13 +564,23 @@ namespace swig {
|
|||
{
|
||||
public:
|
||||
FromOper from;
|
||||
typedef OutConstIterator out_iterator;
|
||||
typedef OutConstIterator const_iter;
|
||||
typedef ValueType value_type;
|
||||
typedef ConstIterator_T<out_iterator> base;
|
||||
typedef ConstIterator_T<const_iter> base;
|
||||
typedef ConstIteratorClosed_T<OutConstIterator, ValueType, FromOper> self_type;
|
||||
|
||||
ConstIteratorClosed_T(out_iterator curr, out_iterator first,
|
||||
out_iterator last, VALUE seq = Qnil)
|
||||
protected:
|
||||
virtual ConstIterator* advance(ptrdiff_t n)
|
||||
{
|
||||
std::advance( base::current, n );
|
||||
if ( base::current == end )
|
||||
throw stop_iteration();
|
||||
return this;
|
||||
}
|
||||
|
||||
public:
|
||||
ConstIteratorClosed_T(const_iter curr, const_iter first,
|
||||
const_iter last, VALUE seq = Qnil)
|
||||
: ConstIterator_T<OutConstIterator>(curr, seq), begin(first), end(last)
|
||||
{
|
||||
}
|
||||
|
|
@ -491,39 +593,15 @@ namespace swig {
|
|||
}
|
||||
}
|
||||
|
||||
|
||||
ConstIterator *dup() const
|
||||
{
|
||||
return new self_type(*this);
|
||||
}
|
||||
|
||||
ConstIterator *incr(size_t n = 1)
|
||||
{
|
||||
while (n--) {
|
||||
if (base::current == end) {
|
||||
throw stop_iteration();
|
||||
} else {
|
||||
++base::current;
|
||||
}
|
||||
}
|
||||
return this;
|
||||
}
|
||||
|
||||
ConstIterator *decr(size_t n = 1)
|
||||
{
|
||||
while (n--) {
|
||||
if (base::current == begin) {
|
||||
throw stop_iteration();
|
||||
} else {
|
||||
--base::current;
|
||||
}
|
||||
}
|
||||
return this;
|
||||
}
|
||||
|
||||
private:
|
||||
out_iterator begin;
|
||||
out_iterator end;
|
||||
const_iter begin;
|
||||
const_iter end;
|
||||
};
|
||||
|
||||
/**
|
||||
|
|
@ -539,13 +617,23 @@ namespace swig {
|
|||
public:
|
||||
FromOper from;
|
||||
AsvalOper asval;
|
||||
typedef InOutIterator inout_iterator;
|
||||
typedef InOutIterator nonconst_iter;
|
||||
typedef ValueType value_type;
|
||||
typedef Iterator_T<inout_iterator> base;
|
||||
typedef Iterator_T<nonconst_iter> base;
|
||||
typedef IteratorClosed_T<InOutIterator, ValueType, FromOper, AsvalOper> self_type;
|
||||
|
||||
IteratorClosed_T(inout_iterator curr, inout_iterator first,
|
||||
inout_iterator last, VALUE seq = Qnil)
|
||||
protected:
|
||||
virtual Iterator* advance(ptrdiff_t n)
|
||||
{
|
||||
std::advance( base::current, n );
|
||||
if ( base::current == end )
|
||||
throw stop_iteration();
|
||||
return this;
|
||||
}
|
||||
|
||||
public:
|
||||
IteratorClosed_T(nonconst_iter curr, nonconst_iter first,
|
||||
nonconst_iter last, VALUE seq = Qnil)
|
||||
: Iterator_T<InOutIterator>(curr, seq), begin(first), end(last)
|
||||
{
|
||||
}
|
||||
|
|
@ -559,14 +647,14 @@ namespace swig {
|
|||
}
|
||||
|
||||
// Iterator setter method, required by Ruby
|
||||
virtual bool set( const VALUE& v )
|
||||
virtual VALUE setValue( const VALUE& v )
|
||||
{
|
||||
if (base::current == end) {
|
||||
if (base::current == end)
|
||||
throw stop_iteration();
|
||||
} else {
|
||||
value_type& dst = *base::current;
|
||||
return asval( v, dst );
|
||||
}
|
||||
|
||||
value_type& dst = *base::current;
|
||||
if ( asval( v, dst ) ) return v;
|
||||
return Qnil;
|
||||
}
|
||||
|
||||
Iterator *dup() const
|
||||
|
|
@ -574,33 +662,9 @@ namespace swig {
|
|||
return new self_type(*this);
|
||||
}
|
||||
|
||||
Iterator *incr(size_t n = 1)
|
||||
{
|
||||
while (n--) {
|
||||
if (base::current == end) {
|
||||
throw stop_iteration();
|
||||
} else {
|
||||
++base::current;
|
||||
}
|
||||
}
|
||||
return this;
|
||||
}
|
||||
|
||||
Iterator *decr(size_t n = 1)
|
||||
{
|
||||
while (n--) {
|
||||
if (base::current == begin) {
|
||||
throw stop_iteration();
|
||||
} else {
|
||||
--base::current;
|
||||
}
|
||||
}
|
||||
return this;
|
||||
}
|
||||
|
||||
private:
|
||||
inout_iterator begin;
|
||||
inout_iterator end;
|
||||
nonconst_iter begin;
|
||||
nonconst_iter end;
|
||||
};
|
||||
|
||||
/* Partial specialization for bools which don't allow de-referencing */
|
||||
|
|
@ -611,12 +675,12 @@ namespace swig {
|
|||
public:
|
||||
FromOper from;
|
||||
AsvalOper asval;
|
||||
typedef InOutIterator inout_iterator;
|
||||
typedef InOutIterator nonconst_iter;
|
||||
typedef bool value_type;
|
||||
typedef Iterator_T<inout_iterator> base;
|
||||
typedef Iterator_T<nonconst_iter> base;
|
||||
typedef IteratorOpen_T<InOutIterator, bool, FromOper, AsvalOper> self_type;
|
||||
|
||||
IteratorOpen_T(inout_iterator curr, VALUE seq = Qnil)
|
||||
IteratorOpen_T(nonconst_iter curr, VALUE seq = Qnil)
|
||||
: Iterator_T<InOutIterator>(curr, seq)
|
||||
{
|
||||
}
|
||||
|
|
@ -625,31 +689,21 @@ namespace swig {
|
|||
return from(static_cast<const value_type&>(*(base::current)));
|
||||
}
|
||||
|
||||
virtual bool set( const VALUE& v )
|
||||
virtual VALUE setValue( const VALUE& v )
|
||||
{
|
||||
return false;
|
||||
bool tmp = *base::current;
|
||||
if ( asval( v, tmp ) )
|
||||
{
|
||||
*base::current = tmp;
|
||||
return v;
|
||||
}
|
||||
return Qnil;
|
||||
}
|
||||
|
||||
Iterator *dup() const
|
||||
{
|
||||
return new self_type(*this);
|
||||
}
|
||||
|
||||
Iterator *incr(size_t n = 1)
|
||||
{
|
||||
while (n--) {
|
||||
++base::current;
|
||||
}
|
||||
return this;
|
||||
}
|
||||
|
||||
Iterator *decr(size_t n = 1)
|
||||
{
|
||||
while (n--) {
|
||||
--base::current;
|
||||
}
|
||||
return this;
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
|
|
@ -661,13 +715,23 @@ namespace swig {
|
|||
public:
|
||||
FromOper from;
|
||||
AsvalOper asval;
|
||||
typedef InOutIterator inout_iterator;
|
||||
typedef InOutIterator nonconst_iter;
|
||||
typedef bool value_type;
|
||||
typedef Iterator_T<inout_iterator> base;
|
||||
typedef Iterator_T<nonconst_iter> base;
|
||||
typedef IteratorClosed_T<InOutIterator, bool, FromOper, AsvalOper> self_type;
|
||||
|
||||
IteratorClosed_T(inout_iterator curr, inout_iterator first,
|
||||
inout_iterator last, VALUE seq = Qnil)
|
||||
protected:
|
||||
virtual Iterator* advance(ptrdiff_t n)
|
||||
{
|
||||
std::advance( base::current, n );
|
||||
if ( base::current == end )
|
||||
throw stop_iteration();
|
||||
return this;
|
||||
}
|
||||
|
||||
public:
|
||||
IteratorClosed_T(nonconst_iter curr, nonconst_iter first,
|
||||
nonconst_iter last, VALUE seq = Qnil)
|
||||
: Iterator_T<InOutIterator>(curr, seq), begin(first), end(last)
|
||||
{
|
||||
}
|
||||
|
|
@ -680,9 +744,18 @@ namespace swig {
|
|||
}
|
||||
}
|
||||
|
||||
virtual bool set( const VALUE& v )
|
||||
virtual VALUE setValue( const VALUE& v )
|
||||
{
|
||||
return false;
|
||||
if (base::current == end)
|
||||
throw stop_iteration();
|
||||
|
||||
bool tmp = *base::current;
|
||||
if ( asval( v, tmp ) )
|
||||
{
|
||||
*base::current = tmp;
|
||||
return v;
|
||||
}
|
||||
return Qnil;
|
||||
}
|
||||
|
||||
Iterator *dup() const
|
||||
|
|
@ -690,34 +763,9 @@ namespace swig {
|
|||
return new self_type(*this);
|
||||
}
|
||||
|
||||
Iterator *incr(size_t n = 1)
|
||||
{
|
||||
while (n--) {
|
||||
if (base::current == end) {
|
||||
throw stop_iteration();
|
||||
} else {
|
||||
++base::current;
|
||||
}
|
||||
}
|
||||
return this;
|
||||
}
|
||||
|
||||
Iterator *decr(size_t n = 1)
|
||||
{
|
||||
while (n--) {
|
||||
if (base::current == begin) {
|
||||
throw stop_iteration();
|
||||
} else {
|
||||
--base::current;
|
||||
}
|
||||
}
|
||||
return this;
|
||||
}
|
||||
|
||||
private:
|
||||
inout_iterator begin;
|
||||
inout_iterator end;
|
||||
|
||||
nonconst_iter begin;
|
||||
nonconst_iter end;
|
||||
};
|
||||
|
||||
|
||||
|
|
@ -728,8 +776,8 @@ namespace swig {
|
|||
*/
|
||||
template<typename InOutIter>
|
||||
inline Iterator*
|
||||
make_inout_iterator(const InOutIter& current, const InOutIter& begin,
|
||||
const InOutIter& end, VALUE seq = Qnil)
|
||||
make_nonconst_iterator(const InOutIter& current, const InOutIter& begin,
|
||||
const InOutIter& end, VALUE seq = Qnil)
|
||||
{
|
||||
return new IteratorClosed_T<InOutIter>(current, begin, end, seq);
|
||||
}
|
||||
|
|
@ -741,7 +789,7 @@ namespace swig {
|
|||
*/
|
||||
template<typename InOutIter>
|
||||
inline Iterator*
|
||||
make_inout_iterator(const InOutIter& current, VALUE seq = Qnil)
|
||||
make_nonconst_iterator(const InOutIter& current, VALUE seq = Qnil)
|
||||
{
|
||||
return new IteratorOpen_T<InOutIter>(current, seq);
|
||||
}
|
||||
|
|
@ -753,7 +801,7 @@ namespace swig {
|
|||
*/
|
||||
template<typename OutIter>
|
||||
inline ConstIterator*
|
||||
make_output_iterator(const OutIter& current, const OutIter& begin,
|
||||
make_const_iterator(const OutIter& current, const OutIter& begin,
|
||||
const OutIter& end, VALUE seq = Qnil)
|
||||
{
|
||||
return new ConstIteratorClosed_T<OutIter>(current, begin, end, seq);
|
||||
|
|
@ -766,7 +814,7 @@ namespace swig {
|
|||
*/
|
||||
template<typename OutIter>
|
||||
inline ConstIterator*
|
||||
make_output_iterator(const OutIter& current, VALUE seq = Qnil)
|
||||
make_const_iterator(const OutIter& current, VALUE seq = Qnil)
|
||||
{
|
||||
return new ConstIteratorOpen_T<OutIter>(current, seq);
|
||||
}
|
||||
|
|
@ -826,28 +874,16 @@ namespace swig
|
|||
virtual ~ConstIterator();
|
||||
|
||||
// Access iterator method, required by Ruby
|
||||
virtual VALUE value() const = 0;
|
||||
|
||||
// Forward iterator method, required by Ruby
|
||||
virtual ConstIterator *incr(size_t n = 1) = 0;
|
||||
|
||||
// Backward iterator method, very common in C++, but not required in Ruby
|
||||
virtual ConstIterator *decr(size_t n = 1);
|
||||
|
||||
// Random access iterator methods, but not required in Ruby
|
||||
virtual ptrdiff_t distance(const ConstIterator &x) const;
|
||||
|
||||
virtual bool equal (const ConstIterator &x) const;
|
||||
virtual VALUE value() const;
|
||||
|
||||
// C++ common/needed methods
|
||||
virtual ConstIterator *dup() const = 0;
|
||||
virtual ConstIterator *dup() const;
|
||||
|
||||
virtual VALUE inspect() const = 0;
|
||||
virtual VALUE to_s() const = 0;
|
||||
virtual VALUE inspect() const;
|
||||
virtual VALUE to_s() const;
|
||||
|
||||
VALUE next();
|
||||
VALUE previous();
|
||||
ConstIterator *advance(ptrdiff_t n);
|
||||
virtual ConstIterator* next(size_t n = 1);
|
||||
virtual ConstIterator* previous(size_t n = 1);
|
||||
|
||||
bool operator == (const ConstIterator& x) const;
|
||||
ConstIterator* operator + (ptrdiff_t n) const;
|
||||
|
|
@ -857,14 +893,16 @@ namespace swig
|
|||
|
||||
struct Iterator : public ConstIterator
|
||||
{
|
||||
virtual bool set( const VALUE& v ) = 0;
|
||||
%rename("value=") setValue( const VALUE& v );
|
||||
virtual VALUE setValue( const VALUE& v );
|
||||
|
||||
// Random access iterator methods, but not required in Ruby
|
||||
virtual ptrdiff_t distance(const Iterator &x) const;
|
||||
virtual bool equal (const Iterator &x) const;
|
||||
virtual Iterator *dup() const;
|
||||
|
||||
virtual Iterator *dup() const = 0;
|
||||
Iterator *advance(ptrdiff_t n);
|
||||
virtual Iterator* next(size_t n = 1);
|
||||
virtual Iterator* previous(size_t n = 1);
|
||||
|
||||
virtual VALUE inspect() const;
|
||||
virtual VALUE to_s() const;
|
||||
|
||||
bool operator == (const Iterator& x) const;
|
||||
Iterator* operator + (ptrdiff_t n) const;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue