rice2 2.2.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (190) hide show
  1. checksums.yaml +7 -0
  2. data/COPYING +23 -0
  3. data/Doxyfile +2268 -0
  4. data/Makefile.am +26 -0
  5. data/Makefile.in +929 -0
  6. data/README.md +1054 -0
  7. data/README.mingw +8 -0
  8. data/Rakefile +24 -0
  9. data/aclocal.m4 +1090 -0
  10. data/bootstrap +8 -0
  11. data/config.guess +1667 -0
  12. data/config.sub +1793 -0
  13. data/configure +8209 -0
  14. data/configure.ac +55 -0
  15. data/depcomp +791 -0
  16. data/doxygen.ac +314 -0
  17. data/doxygen.am +186 -0
  18. data/extconf.rb +66 -0
  19. data/install-sh +529 -0
  20. data/missing +215 -0
  21. data/post-autoconf.rb +22 -0
  22. data/post-automake.rb +28 -0
  23. data/rice/Address_Registration_Guard.cpp +22 -0
  24. data/rice/Address_Registration_Guard.hpp +7 -0
  25. data/rice/Address_Registration_Guard.ipp +37 -0
  26. data/rice/Address_Registration_Guard_defn.hpp +75 -0
  27. data/rice/Arg.hpp +8 -0
  28. data/rice/Arg_impl.hpp +129 -0
  29. data/rice/Arg_operators.cpp +21 -0
  30. data/rice/Arg_operators.hpp +19 -0
  31. data/rice/Array.hpp +214 -0
  32. data/rice/Array.ipp +256 -0
  33. data/rice/Builtin_Object.hpp +8 -0
  34. data/rice/Builtin_Object.ipp +50 -0
  35. data/rice/Builtin_Object_defn.hpp +50 -0
  36. data/rice/Class.cpp +57 -0
  37. data/rice/Class.hpp +8 -0
  38. data/rice/Class.ipp +6 -0
  39. data/rice/Class_defn.hpp +83 -0
  40. data/rice/Constructor.hpp +47 -0
  41. data/rice/Data_Object.hpp +8 -0
  42. data/rice/Data_Object.ipp +133 -0
  43. data/rice/Data_Object_defn.hpp +138 -0
  44. data/rice/Data_Type.cpp +54 -0
  45. data/rice/Data_Type.hpp +8 -0
  46. data/rice/Data_Type.ipp +365 -0
  47. data/rice/Data_Type_defn.hpp +261 -0
  48. data/rice/Data_Type_fwd.hpp +12 -0
  49. data/rice/Director.cpp +13 -0
  50. data/rice/Director.hpp +39 -0
  51. data/rice/Enum.hpp +117 -0
  52. data/rice/Enum.ipp +246 -0
  53. data/rice/Exception.cpp +59 -0
  54. data/rice/Exception.hpp +13 -0
  55. data/rice/Exception_Base.hpp +8 -0
  56. data/rice/Exception_Base.ipp +13 -0
  57. data/rice/Exception_Base_defn.hpp +27 -0
  58. data/rice/Exception_defn.hpp +69 -0
  59. data/rice/Hash.hpp +227 -0
  60. data/rice/Hash.ipp +329 -0
  61. data/rice/Identifier.cpp +8 -0
  62. data/rice/Identifier.hpp +50 -0
  63. data/rice/Identifier.ipp +33 -0
  64. data/rice/Jump_Tag.hpp +24 -0
  65. data/rice/Makefile.am +122 -0
  66. data/rice/Makefile.in +885 -0
  67. data/rice/Module.cpp +84 -0
  68. data/rice/Module.hpp +8 -0
  69. data/rice/Module.ipp +6 -0
  70. data/rice/Module_defn.hpp +88 -0
  71. data/rice/Module_impl.hpp +281 -0
  72. data/rice/Module_impl.ipp +345 -0
  73. data/rice/Object.cpp +169 -0
  74. data/rice/Object.hpp +8 -0
  75. data/rice/Object.ipp +33 -0
  76. data/rice/Object_defn.hpp +214 -0
  77. data/rice/Require_Guard.hpp +21 -0
  78. data/rice/String.cpp +94 -0
  79. data/rice/String.hpp +91 -0
  80. data/rice/Struct.cpp +117 -0
  81. data/rice/Struct.hpp +162 -0
  82. data/rice/Struct.ipp +26 -0
  83. data/rice/Symbol.cpp +25 -0
  84. data/rice/Symbol.hpp +66 -0
  85. data/rice/Symbol.ipp +44 -0
  86. data/rice/config.hpp +47 -0
  87. data/rice/config.hpp.in +46 -0
  88. data/rice/detail/Arguments.hpp +118 -0
  89. data/rice/detail/Auto_Function_Wrapper.hpp +898 -0
  90. data/rice/detail/Auto_Function_Wrapper.ipp +3694 -0
  91. data/rice/detail/Auto_Member_Function_Wrapper.hpp +897 -0
  92. data/rice/detail/Auto_Member_Function_Wrapper.ipp +2774 -0
  93. data/rice/detail/Caster.hpp +103 -0
  94. data/rice/detail/Exception_Handler.hpp +8 -0
  95. data/rice/detail/Exception_Handler.ipp +68 -0
  96. data/rice/detail/Exception_Handler_defn.hpp +96 -0
  97. data/rice/detail/Iterator.hpp +93 -0
  98. data/rice/detail/Not_Copyable.hpp +25 -0
  99. data/rice/detail/Wrapped_Function.hpp +33 -0
  100. data/rice/detail/cfp.hpp +24 -0
  101. data/rice/detail/cfp.ipp +51 -0
  102. data/rice/detail/check_ruby_type.cpp +27 -0
  103. data/rice/detail/check_ruby_type.hpp +23 -0
  104. data/rice/detail/creation_funcs.hpp +37 -0
  105. data/rice/detail/creation_funcs.ipp +36 -0
  106. data/rice/detail/default_allocation_func.hpp +23 -0
  107. data/rice/detail/default_allocation_func.ipp +11 -0
  108. data/rice/detail/define_method_and_auto_wrap.hpp +31 -0
  109. data/rice/detail/define_method_and_auto_wrap.ipp +30 -0
  110. data/rice/detail/demangle.cpp +56 -0
  111. data/rice/detail/demangle.hpp +19 -0
  112. data/rice/detail/env.hpp +11 -0
  113. data/rice/detail/from_ruby.hpp +43 -0
  114. data/rice/detail/from_ruby.ipp +60 -0
  115. data/rice/detail/method_data.cpp +92 -0
  116. data/rice/detail/method_data.hpp +21 -0
  117. data/rice/detail/node.hpp +13 -0
  118. data/rice/detail/protect.cpp +29 -0
  119. data/rice/detail/protect.hpp +34 -0
  120. data/rice/detail/ruby.hpp +74 -0
  121. data/rice/detail/ruby_version_code.hpp +6 -0
  122. data/rice/detail/ruby_version_code.hpp.in +6 -0
  123. data/rice/detail/st.hpp +22 -0
  124. data/rice/detail/to_ruby.hpp +22 -0
  125. data/rice/detail/to_ruby.ipp +36 -0
  126. data/rice/detail/traits.hpp +43 -0
  127. data/rice/detail/win32.hpp +16 -0
  128. data/rice/detail/wrap_function.hpp +66 -0
  129. data/rice/global_function.hpp +33 -0
  130. data/rice/global_function.ipp +22 -0
  131. data/rice/protect.hpp +38 -0
  132. data/rice/protect.ipp +1134 -0
  133. data/rice/ruby_mark.hpp +13 -0
  134. data/rice/ruby_try_catch.hpp +86 -0
  135. data/rice/rubypp.rb +97 -0
  136. data/rice/to_from_ruby.hpp +8 -0
  137. data/rice/to_from_ruby.ipp +418 -0
  138. data/rice/to_from_ruby_defn.hpp +70 -0
  139. data/ruby.ac +135 -0
  140. data/ruby/Makefile.am +1 -0
  141. data/ruby/Makefile.in +628 -0
  142. data/ruby/lib/Makefile.am +3 -0
  143. data/ruby/lib/Makefile.in +506 -0
  144. data/ruby/lib/mkmf-rice.rb.in +217 -0
  145. data/ruby/lib/version.rb +3 -0
  146. data/sample/Makefile.am +47 -0
  147. data/sample/Makefile.in +489 -0
  148. data/sample/enum/extconf.rb +3 -0
  149. data/sample/enum/sample_enum.cpp +54 -0
  150. data/sample/enum/test.rb +8 -0
  151. data/sample/inheritance/animals.cpp +98 -0
  152. data/sample/inheritance/extconf.rb +3 -0
  153. data/sample/inheritance/test.rb +7 -0
  154. data/sample/map/extconf.rb +3 -0
  155. data/sample/map/map.cpp +81 -0
  156. data/sample/map/test.rb +7 -0
  157. data/test/Makefile.am +72 -0
  158. data/test/Makefile.in +1213 -0
  159. data/test/ext/Makefile.am +41 -0
  160. data/test/ext/Makefile.in +483 -0
  161. data/test/ext/t1/Foo.hpp +10 -0
  162. data/test/ext/t1/extconf.rb +2 -0
  163. data/test/ext/t1/t1.cpp +15 -0
  164. data/test/ext/t2/extconf.rb +2 -0
  165. data/test/ext/t2/t2.cpp +11 -0
  166. data/test/test_Address_Registration_Guard.cpp +43 -0
  167. data/test/test_Array.cpp +248 -0
  168. data/test/test_Builtin_Object.cpp +71 -0
  169. data/test/test_Class.cpp +496 -0
  170. data/test/test_Constructor.cpp +128 -0
  171. data/test/test_Data_Object.cpp +275 -0
  172. data/test/test_Data_Type.cpp +348 -0
  173. data/test/test_Director.cpp +308 -0
  174. data/test/test_Enum.cpp +215 -0
  175. data/test/test_Exception.cpp +47 -0
  176. data/test/test_Hash.cpp +212 -0
  177. data/test/test_Identifier.cpp +70 -0
  178. data/test/test_Jump_Tag.cpp +17 -0
  179. data/test/test_Memory_Management.cpp +50 -0
  180. data/test/test_Module.cpp +497 -0
  181. data/test/test_Object.cpp +159 -0
  182. data/test/test_String.cpp +107 -0
  183. data/test/test_Struct.cpp +205 -0
  184. data/test/test_Symbol.cpp +63 -0
  185. data/test/test_To_From_Ruby.cpp +428 -0
  186. data/test/test_global_functions.cpp +114 -0
  187. data/test/test_rice.rb +41 -0
  188. data/test/unittest.cpp +136 -0
  189. data/test/unittest.hpp +294 -0
  190. metadata +297 -0
@@ -0,0 +1,21 @@
1
+ #include "Arg_impl.hpp"
2
+ #include "detail/Arguments.hpp"
3
+ #include "Arg_operators.hpp"
4
+
5
+ namespace Rice {
6
+
7
+ Arguments* operator,(Arg arg1, Arg arg2)
8
+ {
9
+ Arguments* a = new Arguments();
10
+ a->add(arg1);
11
+ a->add(arg2);
12
+ return a;
13
+ }
14
+
15
+ Arguments* operator,(Arguments* arguments, Arg arg)
16
+ {
17
+ arguments->add(arg);
18
+ return arguments;
19
+ }
20
+
21
+ }
@@ -0,0 +1,19 @@
1
+ #ifndef Rice__Arg_Operators_hpp_
2
+ #define Rice__Arg_Operators_hpp_
3
+
4
+ namespace Rice
5
+ {
6
+
7
+ //! Build the list of Arg objects into an Arguments object
8
+ /*! Take a list of Arg objects and build up a single Argument
9
+ * object used later in method dispatch
10
+ */
11
+ Arguments* operator,(Arg arg1, Arg arg2);
12
+
13
+ /*! @see operator,(Arg, Arg)
14
+ */
15
+ Arguments* operator,(Arguments* arguments, Arg arg);
16
+
17
+ }
18
+
19
+ #endif // Rice__Arg_Operators_hpp_
@@ -0,0 +1,214 @@
1
+ #ifndef Rice__Array__hpp_
2
+ #define Rice__Array__hpp_
3
+
4
+ #include "Builtin_Object.hpp"
5
+ #include "to_from_ruby_defn.hpp"
6
+ #include "detail/ruby.hpp"
7
+ #include <iterator>
8
+
9
+ namespace Rice
10
+ {
11
+
12
+ //! A wrapper for the ruby Array class.
13
+ /*! This class provides a C++-style interface to ruby's Array class and
14
+ * its associated rb_ary_* functions.
15
+ * Example:
16
+ * \code
17
+ * Array a;
18
+ * a.push(String("some string"));
19
+ * a.push(42);
20
+ * \endcode
21
+ */
22
+ class Array
23
+ : public Builtin_Object<T_ARRAY>
24
+ {
25
+ public:
26
+ //! Construct a new array
27
+ Array();
28
+
29
+ //! Wrap an existing array
30
+ /*! \param v a ruby object, which must be of type T_ARRAY.
31
+ */
32
+ Array(Object v);
33
+
34
+ //! Wrap an existing array
35
+ /*! \param v a ruby object, which must be of type T_ARRAY.
36
+ */
37
+ Array(VALUE v);
38
+
39
+ //! Construct an array from a sequence.
40
+ /*! \param begin an iterator to the beginning of the sequence.
41
+ * \param end an iterator to the end of the sequence.
42
+ */
43
+ template<typename Iter_T>
44
+ Array(Iter_T begin, Iter_T end);
45
+
46
+ //! Construct an Array from a C array.
47
+ /*! \param a a C array of type T and size n.
48
+ */
49
+ template<typename T, size_t n>
50
+ Array(T const (& a)[n]);
51
+
52
+ public:
53
+ //! Return the size of the array.
54
+ size_t size() const;
55
+
56
+ //! Return the element at the given index.
57
+ /*! \param index The index of the desired element. The index may be
58
+ * negative, to indicate an offset from the end of the array. If the
59
+ * index is out of bounds, this function has undefined behavior.
60
+ * \return the element at the given index.
61
+ */
62
+ Object operator[](ptrdiff_t index) const;
63
+
64
+ private:
65
+ //! A helper class so array[index]=value can work.
66
+ class Proxy;
67
+
68
+ public:
69
+ //! Return a reference to the element at the given index.
70
+ /*! \param index The index of the desired element. The index may be
71
+ * negative, to indicate an offset from the end of the array. If the
72
+ * index is out of bounds, this function has undefined behavior.
73
+ * \return the element at the given index.
74
+ */
75
+ Proxy operator[](ptrdiff_t index);
76
+
77
+ //! Push an element onto the end of the array
78
+ /*! \param v an object to push onto the array.
79
+ * \return the object which was pushed onto the array.
80
+ */
81
+ template<typename T>
82
+ Object push(T const & obj);
83
+
84
+ //! Pop an element from the end of the array
85
+ /*! \return the object which was popped from the array, or Qnil if
86
+ * the array was empty.
87
+ */
88
+ Object pop();
89
+
90
+ //! Unshift an element onto the beginning of the array
91
+ /*! \param v an object to unshift onto the array.
92
+ * \return the object which was unshifted onto the array.
93
+ */
94
+ template<typename T>
95
+ Object unshift(T const & obj);
96
+
97
+ //! Shift an element from the beginning of the array
98
+ /*! \return the object which was shifted from the array.
99
+ */
100
+ Object shift();
101
+
102
+ private:
103
+ template<typename Array_Ref_T, typename Value_T>
104
+ class Iterator;
105
+
106
+ size_t position_of(ptrdiff_t index) const;
107
+
108
+ public:
109
+ //! An iterator.
110
+ typedef Iterator<Array &, Proxy> iterator;
111
+
112
+ //! A const iterator.
113
+ typedef Iterator<Array const &, Object> const_iterator;
114
+
115
+ //! Return an iterator to the beginning of the array.
116
+ iterator begin();
117
+
118
+ //! Return a const iterator to the beginning of the array.
119
+ const_iterator begin() const;
120
+
121
+ //! Return an iterator to the end of the array.
122
+ iterator end();
123
+
124
+ //! Return a const iterator to the end of the array.
125
+ const_iterator end() const;
126
+ };
127
+
128
+ //! A helper class so array[index]=value can work.
129
+ class Array::Proxy
130
+ {
131
+ public:
132
+ //! Construct a new Proxy
133
+ Proxy(Array array, size_t index);
134
+
135
+ //! Implicit conversion to Object.
136
+ operator Object() const;
137
+
138
+ //! Explicit conversion to VALUE.
139
+ VALUE value() const;
140
+
141
+ //! Assignment operator.
142
+ template<typename T>
143
+ Object operator=(T const & value);
144
+
145
+ private:
146
+ Array array_;
147
+ size_t index_;
148
+ };
149
+
150
+ //! A helper class for implementing iterators for a Array.
151
+ // TODO: This really should be a random-access iterator.
152
+ template<typename Array_Ref_T, typename Value_T>
153
+ class Array::Iterator
154
+ : public std::iterator<
155
+ std::forward_iterator_tag,
156
+ Value_T, // Type
157
+ ptrdiff_t, // Distance type
158
+ Object *, // Pointer type
159
+ Value_T &> // Reference type
160
+ {
161
+ public:
162
+ Iterator(Array_Ref_T array, size_t index);
163
+
164
+ template<typename Array_Ref_T_, typename Value_T_>
165
+ Iterator(Iterator<Array_Ref_T_, Value_T_> const & rhs);
166
+
167
+ template<typename Array_Ref_T_, typename Value_T_>
168
+ Iterator & operator=(Iterator<Array_Ref_T_, Value_T_> const & rhs);
169
+
170
+ Iterator & operator++();
171
+ Iterator operator++(int);
172
+ Value_T operator*();
173
+ Object * operator->();
174
+
175
+ template<typename Array_Ref_T_, typename Value_T_>
176
+ bool operator==(Iterator<Array_Ref_T_, Value_T_> const & rhs) const;
177
+
178
+ template<typename Array_Ref_T_, typename Value_T_>
179
+ bool operator!=(Iterator<Array_Ref_T_, Value_T_> const & rhs) const;
180
+
181
+ // Causes ICE on g++ 3.3.3
182
+ // template<typename Array_Ref_T_, typename Value_T_>
183
+ // friend class Iterator;
184
+
185
+ Array_Ref_T array() const;
186
+ size_t index() const;
187
+
188
+ private:
189
+ Array_Ref_T array_;
190
+ size_t index_;
191
+
192
+ Object tmp_;
193
+ };
194
+
195
+ } // namespace Rice
196
+
197
+ template<>
198
+ inline
199
+ Rice::Array from_ruby<Rice::Array>(Rice::Object x)
200
+ {
201
+ return Rice::Array(x);
202
+ }
203
+
204
+ template<>
205
+ inline
206
+ Rice::Object to_ruby<Rice::Array>(Rice::Array const & x)
207
+ {
208
+ return x;
209
+ }
210
+
211
+ #include "Array.ipp"
212
+
213
+ #endif // Rice__Array__hpp_
214
+
@@ -0,0 +1,256 @@
1
+ #ifndef Rice__Array__ipp_
2
+ #define Rice__Array__ipp_
3
+
4
+ #include "protect.hpp"
5
+
6
+ inline Rice::Array::
7
+ Array()
8
+ : Builtin_Object<T_ARRAY>(protect(rb_ary_new))
9
+ {
10
+ }
11
+
12
+ inline Rice::Array::
13
+ Array(Object v)
14
+ : Builtin_Object<T_ARRAY>(v)
15
+ {
16
+ }
17
+
18
+ inline Rice::Array::
19
+ Array(VALUE v)
20
+ : Builtin_Object<T_ARRAY>(v)
21
+ {
22
+ }
23
+
24
+ template<typename Iter_T>
25
+ inline Rice::Array::
26
+ Array(Iter_T it, Iter_T end)
27
+ : Builtin_Object<T_ARRAY>(protect(rb_ary_new))
28
+ {
29
+ for(; it != end; ++it)
30
+ {
31
+ push(*it);
32
+ }
33
+ }
34
+
35
+ template<typename T, size_t n>
36
+ inline Rice::Array::
37
+ Array(T const (& a)[n])
38
+ : Builtin_Object<T_ARRAY>(protect(rb_ary_new))
39
+ {
40
+ for(size_t j = 0; j < n; ++j)
41
+ {
42
+ push(a[j]);
43
+ }
44
+ }
45
+
46
+ inline size_t Rice::Array::
47
+ size() const
48
+ {
49
+ return RARRAY_LEN(this->value());
50
+ }
51
+
52
+ inline Rice::Object Rice::Array::
53
+ operator[](ptrdiff_t index) const
54
+ {
55
+ return protect(rb_ary_entry, value(), position_of(index));
56
+ }
57
+
58
+ inline Rice::Array::Proxy Rice::Array::
59
+ operator[](ptrdiff_t index)
60
+ {
61
+ return Proxy(*this, position_of(index));
62
+ }
63
+
64
+ template<typename T>
65
+ inline Rice::Object Rice::Array::
66
+ push(T const & obj)
67
+ {
68
+ return protect(rb_ary_push, value(), to_ruby(obj));
69
+ }
70
+
71
+ inline Rice::Object Rice::Array::
72
+ pop()
73
+ {
74
+ return protect(rb_ary_pop, value());
75
+ }
76
+
77
+ template<typename T>
78
+ inline Rice::Object Rice::Array::
79
+ unshift(T const & obj)
80
+ {
81
+ return protect(rb_ary_unshift, value(), to_ruby(obj));
82
+ }
83
+
84
+ inline Rice::Object Rice::Array::
85
+ shift()
86
+ {
87
+ return protect(rb_ary_shift, value());
88
+ }
89
+
90
+ inline size_t Rice::Array::
91
+ position_of(ptrdiff_t index) const
92
+ {
93
+ if(index < 0)
94
+ {
95
+ return size() + index;
96
+ }
97
+ else
98
+ {
99
+ return static_cast<size_t>(index);
100
+ }
101
+ }
102
+
103
+ inline Rice::Array::Proxy::
104
+ Proxy(Array array, size_t index)
105
+ : array_(array)
106
+ , index_(index)
107
+ {
108
+ }
109
+
110
+ inline Rice::Array::Proxy::
111
+ operator Rice::Object() const
112
+ {
113
+ return protect(rb_ary_entry, array_.value(), index_);
114
+ }
115
+
116
+ inline VALUE Rice::Array::Proxy::
117
+ value() const
118
+ {
119
+ return protect(rb_ary_entry, array_.value(), index_);
120
+ }
121
+
122
+ template<typename T>
123
+ Rice::Object Rice::Array::Proxy::
124
+ operator=(T const & value)
125
+ {
126
+ Object o = to_ruby(value);
127
+ rb_ary_store(array_.value(), index_, o.value());
128
+ return o;
129
+ }
130
+
131
+ template<typename Array_Ref_T, typename Value_T>
132
+ inline Rice::Array::Iterator<Array_Ref_T, Value_T>::
133
+ Iterator(Array_Ref_T array, size_t index)
134
+ : array_(array)
135
+ , index_(index)
136
+ {
137
+ }
138
+
139
+ template<typename Array_Ref_T, typename Value_T>
140
+ template<typename Array_Ref_T_, typename Value_T_>
141
+ inline
142
+ Rice::Array::Iterator<Array_Ref_T, Value_T>::
143
+ Iterator(Iterator<Array_Ref_T_, Value_T_> const & rhs)
144
+ : array_(rhs.array())
145
+ , index_(rhs.index())
146
+ , tmp_()
147
+ {
148
+ }
149
+
150
+ template<typename Array_Ref_T, typename Value_T>
151
+ template<typename Array_Ref_T_, typename Value_T_>
152
+ inline Rice::Array::Iterator<Array_Ref_T, Value_T> &
153
+ Rice::Array::Iterator<Array_Ref_T, Value_T>::
154
+ operator=(Iterator<Array_Ref_T_, Value_T_> const & rhs)
155
+ {
156
+ array_ = rhs.array_;
157
+ index_ = rhs.index_;
158
+ return *this;
159
+ }
160
+
161
+ template<typename Array_Ref_T, typename Value_T>
162
+ inline Rice::Array::Iterator<Array_Ref_T, Value_T> &
163
+ Rice::Array::Iterator<Array_Ref_T, Value_T>::
164
+ operator++()
165
+ {
166
+ ++index_;
167
+ return *this;
168
+ }
169
+
170
+ template<typename Array_Ref_T, typename Value_T>
171
+ inline Rice::Array::Iterator<Array_Ref_T, Value_T>
172
+ Rice::Array::Iterator<Array_Ref_T, Value_T>::
173
+ operator++(int)
174
+ {
175
+ Array copy(*this);
176
+ ++(*this);
177
+ return *this;
178
+ }
179
+
180
+ template<typename Array_Ref_T, typename Value_T>
181
+ inline Value_T
182
+ Rice::Array::Iterator<Array_Ref_T, Value_T>::
183
+ operator*()
184
+ {
185
+ return array_[index_];
186
+ }
187
+
188
+ template<typename Array_Ref_T, typename Value_T>
189
+ inline Rice::Object *
190
+ Rice::Array::Iterator<Array_Ref_T, Value_T>::
191
+ operator->()
192
+ {
193
+ tmp_ = array_[index_];
194
+ return &tmp_;
195
+ }
196
+
197
+ template<typename Array_Ref_T, typename Value_T>
198
+ template<typename Array_Ref_T_, typename Value_T_>
199
+ inline bool
200
+ Rice::Array::Iterator<Array_Ref_T, Value_T>::
201
+ operator==(Iterator<Array_Ref_T_, Value_T_> const & rhs) const
202
+ {
203
+ return array_.value() == rhs.array_.value() && index_ == rhs.index_;
204
+ }
205
+
206
+ template<typename Array_Ref_T, typename Value_T>
207
+ template<typename Array_Ref_T_, typename Value_T_>
208
+ inline bool
209
+ Rice::Array::Iterator<Array_Ref_T, Value_T>::
210
+ operator!=(Iterator<Array_Ref_T_, Value_T_> const & rhs) const
211
+ {
212
+ return !(*this == rhs);
213
+ }
214
+
215
+ template<typename Array_Ref_T, typename Value_T>
216
+ Array_Ref_T
217
+ Rice::Array::Iterator<Array_Ref_T, Value_T>::
218
+ array() const
219
+ {
220
+ return array_;
221
+ }
222
+
223
+ template<typename Array_Ref_T, typename Value_T>
224
+ size_t
225
+ Rice::Array::Iterator<Array_Ref_T, Value_T>::
226
+ index() const
227
+ {
228
+ return index_;
229
+ }
230
+
231
+ inline Rice::Array::iterator Rice::Array::
232
+ begin()
233
+ {
234
+ return iterator(*this, 0);
235
+ }
236
+
237
+ inline Rice::Array::const_iterator Rice::Array::
238
+ begin() const
239
+ {
240
+ return const_iterator(*this, 0);
241
+ }
242
+
243
+ inline Rice::Array::iterator Rice::Array::
244
+ end()
245
+ {
246
+ return iterator(*this, size());
247
+ }
248
+
249
+ inline Rice::Array::const_iterator Rice::Array::
250
+ end() const
251
+ {
252
+ return const_iterator(*this, size());
253
+ }
254
+
255
+ #endif // Rice__Array__ipp_
256
+