wurlinc-rice 1.4.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (186) hide show
  1. data/COPYING +23 -0
  2. data/Doxyfile +1253 -0
  3. data/Makefile.am +26 -0
  4. data/README +1119 -0
  5. data/README.mingw +8 -0
  6. data/Rakefile +33 -0
  7. data/bootstrap +9 -0
  8. data/configure.ac +52 -0
  9. data/doxygen.ac +314 -0
  10. data/doxygen.am +186 -0
  11. data/extconf.rb +41 -0
  12. data/post-autoconf.rb +22 -0
  13. data/post-automake.rb +28 -0
  14. data/rice/Address_Registration_Guard.hpp +7 -0
  15. data/rice/Address_Registration_Guard.ipp +34 -0
  16. data/rice/Address_Registration_Guard_defn.hpp +65 -0
  17. data/rice/Allocation_Strategies.hpp +37 -0
  18. data/rice/Arg.hpp +8 -0
  19. data/rice/Arg_impl.hpp +127 -0
  20. data/rice/Arg_operators.cpp +21 -0
  21. data/rice/Arg_operators.hpp +19 -0
  22. data/rice/Array.hpp +220 -0
  23. data/rice/Array.ipp +263 -0
  24. data/rice/Builtin_Object.hpp +8 -0
  25. data/rice/Builtin_Object.ipp +50 -0
  26. data/rice/Builtin_Object_defn.hpp +51 -0
  27. data/rice/Class.cpp +57 -0
  28. data/rice/Class.hpp +8 -0
  29. data/rice/Class.ipp +6 -0
  30. data/rice/Class_defn.hpp +83 -0
  31. data/rice/Constructor.hpp +367 -0
  32. data/rice/Critical_Guard.hpp +40 -0
  33. data/rice/Critical_Guard.ipp +26 -0
  34. data/rice/Data_Object.hpp +8 -0
  35. data/rice/Data_Object.ipp +133 -0
  36. data/rice/Data_Object_defn.hpp +132 -0
  37. data/rice/Data_Type.cpp +54 -0
  38. data/rice/Data_Type.hpp +8 -0
  39. data/rice/Data_Type.ipp +365 -0
  40. data/rice/Data_Type_defn.hpp +261 -0
  41. data/rice/Data_Type_fwd.hpp +12 -0
  42. data/rice/Director.cpp +13 -0
  43. data/rice/Director.hpp +39 -0
  44. data/rice/Enum.hpp +117 -0
  45. data/rice/Enum.ipp +246 -0
  46. data/rice/Exception.cpp +59 -0
  47. data/rice/Exception.hpp +9 -0
  48. data/rice/Exception_Base.hpp +8 -0
  49. data/rice/Exception_Base.ipp +13 -0
  50. data/rice/Exception_Base_defn.hpp +27 -0
  51. data/rice/Exception_defn.hpp +69 -0
  52. data/rice/Hash.hpp +210 -0
  53. data/rice/Hash.ipp +338 -0
  54. data/rice/Identifier.cpp +8 -0
  55. data/rice/Identifier.hpp +50 -0
  56. data/rice/Identifier.ipp +33 -0
  57. data/rice/Jump_Tag.hpp +24 -0
  58. data/rice/Makefile.am +129 -0
  59. data/rice/Module.cpp +84 -0
  60. data/rice/Module.hpp +8 -0
  61. data/rice/Module.ipp +6 -0
  62. data/rice/Module_defn.hpp +88 -0
  63. data/rice/Module_impl.hpp +281 -0
  64. data/rice/Module_impl.ipp +348 -0
  65. data/rice/Object.cpp +160 -0
  66. data/rice/Object.hpp +8 -0
  67. data/rice/Object.ipp +19 -0
  68. data/rice/Object_defn.hpp +191 -0
  69. data/rice/Require_Guard.hpp +21 -0
  70. data/rice/String.cpp +94 -0
  71. data/rice/String.hpp +89 -0
  72. data/rice/Struct.cpp +117 -0
  73. data/rice/Struct.hpp +162 -0
  74. data/rice/Struct.ipp +26 -0
  75. data/rice/Symbol.cpp +25 -0
  76. data/rice/Symbol.hpp +66 -0
  77. data/rice/Symbol.ipp +44 -0
  78. data/rice/VM.cpp +92 -0
  79. data/rice/VM.hpp +32 -0
  80. data/rice/config.hpp.in +40 -0
  81. data/rice/detail/Arguments.hpp +118 -0
  82. data/rice/detail/Auto_Function_Wrapper.hpp +829 -0
  83. data/rice/detail/Auto_Function_Wrapper.ipp +3391 -0
  84. data/rice/detail/Auto_Member_Function_Wrapper.hpp +828 -0
  85. data/rice/detail/Auto_Member_Function_Wrapper.ipp +2503 -0
  86. data/rice/detail/Caster.hpp +103 -0
  87. data/rice/detail/Exception_Handler.hpp +8 -0
  88. data/rice/detail/Exception_Handler.ipp +68 -0
  89. data/rice/detail/Exception_Handler_defn.hpp +96 -0
  90. data/rice/detail/Iterator.hpp +93 -0
  91. data/rice/detail/Not_Copyable.hpp +25 -0
  92. data/rice/detail/Wrapped_Function.hpp +33 -0
  93. data/rice/detail/cfp.hpp +24 -0
  94. data/rice/detail/cfp.ipp +51 -0
  95. data/rice/detail/check_ruby_type.cpp +27 -0
  96. data/rice/detail/check_ruby_type.hpp +23 -0
  97. data/rice/detail/creation_funcs.hpp +37 -0
  98. data/rice/detail/creation_funcs.ipp +36 -0
  99. data/rice/detail/default_allocation_func.hpp +23 -0
  100. data/rice/detail/default_allocation_func.ipp +11 -0
  101. data/rice/detail/define_method_and_auto_wrap.hpp +31 -0
  102. data/rice/detail/define_method_and_auto_wrap.ipp +30 -0
  103. data/rice/detail/demangle.cpp +56 -0
  104. data/rice/detail/demangle.hpp +19 -0
  105. data/rice/detail/env.hpp +19 -0
  106. data/rice/detail/from_ruby.hpp +43 -0
  107. data/rice/detail/from_ruby.ipp +60 -0
  108. data/rice/detail/method_data.cpp +159 -0
  109. data/rice/detail/method_data.hpp +21 -0
  110. data/rice/detail/mininode.cpp +1220 -0
  111. data/rice/detail/mininode.hpp +320 -0
  112. data/rice/detail/node.hpp +13 -0
  113. data/rice/detail/object_call.hpp +68 -0
  114. data/rice/detail/object_call.ipp +131 -0
  115. data/rice/detail/protect.cpp +29 -0
  116. data/rice/detail/protect.hpp +34 -0
  117. data/rice/detail/ruby.hpp +93 -0
  118. data/rice/detail/ruby_version_code.hpp.in +6 -0
  119. data/rice/detail/rubysig.hpp +19 -0
  120. data/rice/detail/st.hpp +60 -0
  121. data/rice/detail/to_ruby.hpp +22 -0
  122. data/rice/detail/to_ruby.ipp +36 -0
  123. data/rice/detail/traits.hpp +43 -0
  124. data/rice/detail/win32.hpp +16 -0
  125. data/rice/detail/wrap_function.hpp +341 -0
  126. data/rice/detail/wrap_function.ipp +514 -0
  127. data/rice/global_function.hpp +33 -0
  128. data/rice/global_function.ipp +22 -0
  129. data/rice/protect.hpp +91 -0
  130. data/rice/protect.ipp +1133 -0
  131. data/rice/ruby_mark.hpp +13 -0
  132. data/rice/ruby_try_catch.hpp +86 -0
  133. data/rice/rubypp.rb +97 -0
  134. data/rice/to_from_ruby.hpp +8 -0
  135. data/rice/to_from_ruby.ipp +297 -0
  136. data/rice/to_from_ruby_defn.hpp +71 -0
  137. data/ruby/Makefile.am +1 -0
  138. data/ruby/lib/Makefile.am +3 -0
  139. data/ruby/lib/mkmf-rice.rb.in +216 -0
  140. data/ruby/lib/version.rb +3 -0
  141. data/ruby.ac +136 -0
  142. data/sample/Makefile.am +47 -0
  143. data/sample/enum/extconf.rb +3 -0
  144. data/sample/enum/sample_enum.cpp +54 -0
  145. data/sample/enum/test.rb +8 -0
  146. data/sample/inheritance/animals.cpp +98 -0
  147. data/sample/inheritance/extconf.rb +3 -0
  148. data/sample/inheritance/test.rb +7 -0
  149. data/sample/map/extconf.rb +3 -0
  150. data/sample/map/map.cpp +81 -0
  151. data/sample/map/test.rb +7 -0
  152. data/test/Makefile.am +78 -0
  153. data/test/ext/Makefile.am +43 -0
  154. data/test/ext/t1/Foo.hpp +10 -0
  155. data/test/ext/t1/extconf.rb +2 -0
  156. data/test/ext/t1/t1.cpp +15 -0
  157. data/test/ext/t2/extconf.rb +2 -0
  158. data/test/ext/t2/t2.cpp +11 -0
  159. data/test/test_Address_Registration_Guard.cpp +43 -0
  160. data/test/test_Allocation_Strategies.cpp +77 -0
  161. data/test/test_Array.cpp +241 -0
  162. data/test/test_Builtin_Object.cpp +72 -0
  163. data/test/test_Class.cpp +498 -0
  164. data/test/test_Constructor.cpp +128 -0
  165. data/test/test_Critical_Guard.cpp +51 -0
  166. data/test/test_Data_Object.cpp +275 -0
  167. data/test/test_Data_Type.cpp +348 -0
  168. data/test/test_Director.cpp +301 -0
  169. data/test/test_Enum.cpp +195 -0
  170. data/test/test_Exception.cpp +46 -0
  171. data/test/test_Hash.cpp +195 -0
  172. data/test/test_Identifier.cpp +70 -0
  173. data/test/test_Jump_Tag.cpp +17 -0
  174. data/test/test_Memory_Management.cpp +50 -0
  175. data/test/test_Module.cpp +481 -0
  176. data/test/test_Object.cpp +148 -0
  177. data/test/test_String.cpp +94 -0
  178. data/test/test_Struct.cpp +192 -0
  179. data/test/test_Symbol.cpp +63 -0
  180. data/test/test_To_From_Ruby.cpp +263 -0
  181. data/test/test_VM.cpp +26 -0
  182. data/test/test_global_functions.cpp +114 -0
  183. data/test/test_rice.rb +43 -0
  184. data/test/unittest.cpp +136 -0
  185. data/test/unittest.hpp +292 -0
  186. metadata +276 -0
@@ -0,0 +1,88 @@
1
+ #ifndef Rice__Module_defn__hpp_
2
+ #define Rice__Module_defn__hpp_
3
+
4
+ #include "Object_defn.hpp"
5
+ #include "Module_impl.hpp"
6
+ #include "to_from_ruby_defn.hpp"
7
+ #include <memory>
8
+
9
+ namespace Rice
10
+ {
11
+
12
+ class Array;
13
+ class Class;
14
+ class String;
15
+
16
+ //! A helper for defining a Module and its methods.
17
+ /*! This class provides a C++-style interface to ruby's Module class and
18
+ * for defining methods on that module.
19
+ *
20
+ * Many of the methods are defined in Module_impl.hpp so that they can
21
+ * return a reference to the most derived type.
22
+ */
23
+ class Module
24
+ // TODO: we can't inherit from Builtin_Object, because Class needs
25
+ // type T_CLASS and Module needs type T_MODULE
26
+ : public Module_impl<Module_base, Module>
27
+ {
28
+ public:
29
+ //! Default construct a Module and initialize it to rb_cObject.
30
+ Module();
31
+
32
+ //! Construct a Module from an existing Module object.
33
+ Module(VALUE v);
34
+
35
+ //! Return the name of the module.
36
+ String name() const;
37
+
38
+ //! Swap with another Module.
39
+ void swap(Module & other);
40
+
41
+ //! Return an array containing the Module's ancestors.
42
+ /*! You will need to include Array.hpp to use this function.
43
+ */
44
+ Array ancestors() const;
45
+
46
+ //! Return the module's singleton class.
47
+ /*! You will need to include Class.hpp to use this function.
48
+ */
49
+ Class singleton_class() const;
50
+ };
51
+
52
+ //! Define a new module in the namespace given by module.
53
+ /*! \param module the module in which to define the new module.
54
+ * \param name the name of the new module.
55
+ */
56
+ Module define_module_under(
57
+ Object module,
58
+ char const * name);
59
+
60
+ //! Define a new module in the default namespace.
61
+ /*! \param name the name of the new module.
62
+ */
63
+ Module define_module(
64
+ char const * name);
65
+
66
+ //! Create a new anonymous module.
67
+ /*! \return the new module.
68
+ */
69
+ Module anonymous_module();
70
+
71
+ } // namespace Rice
72
+
73
+ template<>
74
+ inline
75
+ Rice::Module from_ruby<Rice::Module>(Rice::Object x)
76
+ {
77
+ return Rice::Module(x);
78
+ }
79
+
80
+ template<>
81
+ inline
82
+ Rice::Object to_ruby<Rice::Module>(Rice::Module const & x)
83
+ {
84
+ return x;
85
+ }
86
+
87
+ #endif // Rice__Module_defn__hpp_
88
+
@@ -0,0 +1,281 @@
1
+ #ifndef Rice__Module_impl__hpp_
2
+ #define Rice__Module_impl__hpp_
3
+
4
+ #include "detail/Exception_Handler_defn.hpp"
5
+ #include "detail/ruby.hpp"
6
+ #include "Object_defn.hpp"
7
+ #include "Address_Registration_Guard_defn.hpp"
8
+ #include "Arg.hpp"
9
+
10
+ namespace Rice
11
+ {
12
+
13
+ class Module;
14
+ class Class;
15
+ template<typename T> class Data_Type;
16
+
17
+ /*! Holds all member data of Module_impl so it only exists in one place
18
+ * in the hierarchy.
19
+ */
20
+ class Module_base
21
+ : public Object
22
+ {
23
+ public:
24
+ Module_base(VALUE v = rb_cObject);
25
+ Module_base(Module_base const & other);
26
+
27
+ Module_base & operator=(Module_base const & other);
28
+
29
+ void swap(Module_base & other);
30
+
31
+ protected:
32
+ template<typename Exception_T, typename Functor_T>
33
+ void add_handler(Functor_T functor);
34
+
35
+ Object handler() const;
36
+
37
+ private:
38
+ Object mutable handler_;
39
+ Address_Registration_Guard handler_guard_;
40
+ };
41
+
42
+ /*! An intermediate base class so we can always return the most-derived
43
+ * type (Module, Class, Data_Type, ...) without having to re-implement
44
+ * each function for each derived class.
45
+ */
46
+ template<typename Base_T, typename Derived_T>
47
+ class Module_impl
48
+ : public Base_T
49
+ {
50
+ public:
51
+ Module_impl();
52
+
53
+ template<typename T>
54
+ Module_impl(T const & arg);
55
+
56
+ //! Define an exception handler.
57
+ /*! Whenever an exception of type Exception_T is thrown from a
58
+ * function defined on this class, functor will be called to
59
+ * translate the exception into a ruby exception.
60
+ * \param Exception_T a template parameter indicating the type of
61
+ * exception to be translated.
62
+ * \param functor a functor to be called to translate the exception
63
+ * into a ruby exception. This functor should re-throw the exception
64
+ * as an Exception.
65
+ * Example:
66
+ * \code
67
+ * class MyException : public std::exception { };
68
+ * Data_Type<MyException> rb_cMyException;
69
+ * Class rb_cFoo;
70
+ *
71
+ * void translate_my_exception(MyException const & ex)
72
+ * {
73
+ * Data_Object<MyException> ex_(
74
+ * new MyException(ex),
75
+ * rb_cMyException);
76
+ * throw Exception(ex_);
77
+ * }
78
+ *
79
+ * extern "C"
80
+ * void Init_MyExtension()
81
+ * {
82
+ * rb_cMyException = define_class("MyException");
83
+ * rb_cFoo = define_class("Foo")
84
+ * .add_handler<MyException>(translate_my_exception);
85
+ * }
86
+ * \endcode
87
+ */
88
+ template<typename Exception_T, typename Functor_T>
89
+ Derived_T & add_handler(
90
+ Functor_T functor);
91
+
92
+ //! Define an instance method.
93
+ /*! The method's implementation can be any function or member
94
+ * function. A wrapper will be generated which will use from_ruby<>
95
+ * to convert the arguments from ruby types to C++ types before
96
+ * calling the function. The return value will be converted back to
97
+ * ruby by using to_ruby().
98
+ * \param name the name of the method
99
+ * \param func the implementation of the function, either a function
100
+ * pointer or a member function pointer.
101
+ * \param arguments the list of arguments of this function, used for
102
+ * defining default parameters (optional)
103
+ * \return *this
104
+ */
105
+ template<typename Func_T>
106
+ Derived_T & define_method(
107
+ Identifier name,
108
+ Func_T func,
109
+ Arguments* arguments = 0);
110
+
111
+ // FIXME There's GOT to be a better way to
112
+ // do this. Handles the case where there is a single
113
+ // argument defined for this method
114
+ template<typename Func_T>
115
+ Derived_T & define_method(
116
+ Identifier name,
117
+ Func_T func,
118
+ Arg const& arg);
119
+
120
+ //! Define a singleton method.
121
+ /*! The method's implementation can be any function or member
122
+ * function. A wrapper will be generated which will use from_ruby<>
123
+ * to convert the arguments from ruby types to C++ types before
124
+ * calling the function. The return value will be converted back to
125
+ * ruby by using to_ruby().
126
+ * \param name the name of the method
127
+ * \param func the implementation of the function, either a function
128
+ * pointer or a member function pointer.
129
+ * \param arguments the list of arguments of this function, used for
130
+ * defining default parameters (optional)
131
+ * \return *this
132
+ */
133
+ template<typename Func_T>
134
+ Derived_T & define_singleton_method(
135
+ Identifier name,
136
+ Func_T func,
137
+ Arguments* arguments = 0);
138
+
139
+ // FIXME: See define_method with Arg above
140
+ template<typename Func_T>
141
+ Derived_T & define_singleton_method(
142
+ Identifier name,
143
+ Func_T func,
144
+ Arg const& arg);
145
+
146
+ //! Define a module function.
147
+ /*! A module function is a function that can be accessed either as a
148
+ * singleton method or as an instance method.
149
+ * The method's implementation can be any function or member
150
+ * function. A wrapper will be generated which will use from_ruby<>
151
+ * to convert the arguments from ruby types to C++ types before
152
+ * calling the function. The return value will be converted back to
153
+ * ruby by using to_ruby().
154
+ * \param name the name of the method
155
+ * \param func the implementation of the function, either a function
156
+ * pointer or a member function pointer.
157
+ * \param arguments the list of arguments of this function, used for
158
+ * defining default parameters (optional)
159
+ * \return *this
160
+ */
161
+ template<typename Func_T>
162
+ Derived_T & define_module_function(
163
+ Identifier name,
164
+ Func_T func,
165
+ Arguments* arguments = 0);
166
+
167
+ // FIXME: See define_method with Arg above
168
+ template<typename Func_T>
169
+ Derived_T & define_module_function(
170
+ Identifier name,
171
+ Func_T func,
172
+ Arg const& arg);
173
+
174
+ //! Define an iterator.
175
+ /*! Essentially this is a conversion from a C++-style begin/end
176
+ * iterator to a Ruby-style \#each iterator.
177
+ * \param begin a member function pointer to a function that returns
178
+ * an iterator to the beginning of the sequence.
179
+ * \param end a member function pointer to a function that returns an
180
+ * iterator to the end of the sequence.
181
+ * \param name the name of the iterator.
182
+ * \return *this
183
+ */
184
+ template<typename T, typename Iterator_T>
185
+ Derived_T & define_iterator(
186
+ Iterator_T (T::*begin)(),
187
+ Iterator_T (T::*end)(),
188
+ Identifier name = "each");
189
+
190
+ //! Include a module.
191
+ /*! \param inc the module to be included.
192
+ * \return *this
193
+ */
194
+ Derived_T & include_module(
195
+ Module const & inc);
196
+
197
+ //! Set a constant.
198
+ /*! \param name the name of the constant to set.
199
+ * \param value the value of the constant.
200
+ * \return *this
201
+ */
202
+ Derived_T & const_set(
203
+ Identifier name,
204
+ Object value);
205
+
206
+ //! Get a constant.
207
+ /*! \param name the name of the constant to get.
208
+ * \return the value of the constant.
209
+ */
210
+ Object const_get(
211
+ Identifier name) const;
212
+
213
+ //! Determine whether a constant is defined.
214
+ /*! \param name the name of the constant to check.
215
+ * \return true if the constant is defined in this module or false
216
+ * otherwise.
217
+ */
218
+ bool const_defined(
219
+ Identifier name) const;
220
+
221
+ //! Remove a constant.
222
+ /*! \param name the name of the constant to remove.
223
+ */
224
+ void remove_const(
225
+ Identifier name);
226
+
227
+ //! Define a module under this module.
228
+ /*! \param name the name of the module.
229
+ * \return the new class.
230
+ */
231
+ Module define_module(
232
+ char const * name);
233
+
234
+ //! Define a class under this module.
235
+ /*! \param name the name of the class.
236
+ * \param superclass the base class to use.
237
+ * \return the new class.
238
+ */
239
+ Class define_class(
240
+ char const * name,
241
+ Object superclass = rb_cObject);
242
+
243
+ //! Define a new data class under this module.
244
+ /*! The class will have a base class of Object.
245
+ * \param T the C++ type of the wrapped class.
246
+ * \return the new class.
247
+ */
248
+ // This function needs to be defined inline to work around a bug in
249
+ // g++ 3.3.3.
250
+ template<typename T>
251
+ Data_Type<T>
252
+ define_class(
253
+ char const * name)
254
+ {
255
+ return this->define_class_with_object_as_base<T>(name);
256
+ }
257
+
258
+ //! Define a new data class under this module.
259
+ /*! The class with have a base class determined by Base_T (specifically,
260
+ * Data_Type<Base_T>::klass). Therefore, the type Base_T must already
261
+ * have been registered using define_class<> or define_class_under<>.
262
+ * \param T the C++ type of the wrapped class.
263
+ * \return the new class.
264
+ */
265
+ template<typename T, typename T_Base_T>
266
+ Data_Type<T>
267
+ define_class(
268
+ char const * name);
269
+
270
+ private:
271
+ // Workaround for g++ 3.3.3 (see above).
272
+ template<typename T>
273
+ Data_Type<T>
274
+ define_class_with_object_as_base(
275
+ char const * name);
276
+ };
277
+
278
+ } // namespace Rice
279
+
280
+ #endif // Rice__Module_impl__hpp_
281
+
@@ -0,0 +1,348 @@
1
+ #include "detail/define_method_and_auto_wrap.hpp"
2
+ #include "Object.hpp"
3
+ #include "Address_Registration_Guard.hpp"
4
+ #include "Data_Object.hpp"
5
+ #include "Data_Type.hpp"
6
+ #include "Symbol.hpp"
7
+ #include "Exception.hpp"
8
+ #include "protect.hpp"
9
+
10
+ #include "Module.hpp"
11
+ #include "Class.hpp"
12
+ #include "Data_Type.hpp"
13
+
14
+ #include "detail/ruby.hpp"
15
+ #include "detail/method_data.hpp"
16
+ #include "detail/Iterator.hpp"
17
+
18
+
19
+ inline
20
+ Rice::Module_base::
21
+ Module_base(VALUE v)
22
+ : Object(v)
23
+ , handler_(Qnil)
24
+ , handler_guard_(&handler_)
25
+ {
26
+ }
27
+
28
+ inline
29
+ Rice::Module_base::
30
+ Module_base(Module_base const & other)
31
+ : Object(other)
32
+ , handler_(other.handler_)
33
+ , handler_guard_(&handler_)
34
+ {
35
+ }
36
+
37
+ inline
38
+ Rice::Module_base &
39
+ Rice::Module_base::
40
+ operator=(Module_base const & other)
41
+ {
42
+ Module_base tmp(other);
43
+ swap(tmp);
44
+ return *this;
45
+ }
46
+
47
+ inline
48
+ void
49
+ Rice::Module_base::
50
+ swap(Module_base & other)
51
+ {
52
+ std::swap(handler_, other.handler_);
53
+ Object::swap(other);
54
+ }
55
+
56
+ template<typename Exception_T, typename Functor_T>
57
+ inline
58
+ void
59
+ Rice::Module_base::
60
+ add_handler(Functor_T functor)
61
+ {
62
+ Data_Object<detail::Exception_Handler> handler(
63
+ new detail::
64
+ Functor_Exception_Handler<Exception_T, Functor_T>(
65
+ functor,
66
+ this->handler()),
67
+ rb_cObject);
68
+ this->handler_.swap(handler);
69
+ }
70
+
71
+ inline
72
+ Rice::Object
73
+ Rice::Module_base::
74
+ handler() const
75
+ {
76
+ if(!handler_.test())
77
+ {
78
+ Data_Object<Rice::detail::Default_Exception_Handler> handler(
79
+ new Rice::detail::Default_Exception_Handler,
80
+ rb_cObject);
81
+ handler_.swap(handler);
82
+ }
83
+
84
+ return handler_;
85
+ }
86
+
87
+ template<typename Base_T, typename Derived_T>
88
+ inline
89
+ Rice::Module_impl<Base_T, Derived_T>::
90
+ Module_impl()
91
+ : Base_T()
92
+ {
93
+ }
94
+
95
+ template<typename Base_T, typename Derived_T>
96
+ template<typename T>
97
+ inline
98
+ Rice::Module_impl<Base_T, Derived_T>::
99
+ Module_impl(T const & arg)
100
+ : Base_T(arg)
101
+ {
102
+ }
103
+
104
+ template<typename Base_T, typename Derived_T>
105
+ template<typename Exception_T, typename Functor_T>
106
+ inline
107
+ Derived_T &
108
+ Rice::Module_impl<Base_T, Derived_T>::
109
+ add_handler(
110
+ Functor_T functor)
111
+ {
112
+ Module_base::add_handler<Exception_T>(functor);
113
+ return (Derived_T &)*this;
114
+ }
115
+
116
+ template<typename Base_T, typename Derived_T>
117
+ template<typename Func_T>
118
+ inline
119
+ Derived_T &
120
+ Rice::Module_impl<Base_T, Derived_T>::
121
+ define_method(
122
+ Identifier name,
123
+ Func_T func,
124
+ Arguments* arguments)
125
+ {
126
+ detail::define_method_and_auto_wrap(
127
+ *this, name, func, this->handler(), arguments);
128
+ return (Derived_T &)*this;
129
+ }
130
+
131
+ template<typename Base_T, typename Derived_T>
132
+ template<typename Func_T>
133
+ inline
134
+ Derived_T &
135
+ Rice::Module_impl<Base_T, Derived_T>::
136
+ define_method(
137
+ Identifier name,
138
+ Func_T func,
139
+ Arg const& arg)
140
+ {
141
+ Arguments* args = new Arguments();
142
+ args->add(arg);
143
+ return define_method(name, func, args);
144
+ }
145
+
146
+
147
+ template<typename Base_T, typename Derived_T>
148
+ template<typename Func_T>
149
+ inline
150
+ Derived_T &
151
+ Rice::Module_impl<Base_T, Derived_T>::
152
+ define_singleton_method(
153
+ Identifier name,
154
+ Func_T func,
155
+ Arguments* arguments)
156
+ {
157
+ detail::define_method_and_auto_wrap(
158
+ rb_class_of(*this), name, func, this->handler(), arguments);
159
+ return (Derived_T &)*this;
160
+ }
161
+
162
+ template<typename Base_T, typename Derived_T>
163
+ template<typename Func_T>
164
+ inline
165
+ Derived_T &
166
+ Rice::Module_impl<Base_T, Derived_T>::
167
+ define_singleton_method(
168
+ Identifier name,
169
+ Func_T func,
170
+ Arg const& arg)
171
+ {
172
+ Arguments* args = new Arguments();
173
+ args->add(arg);
174
+ return define_singleton_method(name, func, args);
175
+ }
176
+
177
+ template<typename Base_T, typename Derived_T>
178
+ template<typename Func_T>
179
+ inline
180
+ Derived_T &
181
+ Rice::Module_impl<Base_T, Derived_T>::
182
+ define_module_function(
183
+ Identifier name,
184
+ Func_T func,
185
+ Arguments* arguments)
186
+ {
187
+ if(this->rb_type() != T_MODULE)
188
+ {
189
+ throw Rice::Exception(
190
+ rb_eTypeError,
191
+ "can only define module functions for modules");
192
+ }
193
+
194
+ define_method(name, func, arguments);
195
+ define_singleton_method(name, func, arguments);
196
+ return (Derived_T &)*this;
197
+ }
198
+
199
+ template<typename Base_T, typename Derived_T>
200
+ template<typename Func_T>
201
+ inline
202
+ Derived_T &
203
+ Rice::Module_impl<Base_T, Derived_T>::
204
+ define_module_function(
205
+ Identifier name,
206
+ Func_T func,
207
+ Arg const& arg)
208
+ {
209
+ Arguments* args = new Arguments();
210
+ args->add(arg);
211
+ return define_module_function(name, func, args);
212
+ }
213
+
214
+ template<typename Base_T, typename Derived_T>
215
+ template<typename T, typename Iterator_T>
216
+ inline
217
+ Derived_T &
218
+ Rice::Module_impl<Base_T, Derived_T>::
219
+ define_iterator(
220
+ Iterator_T (T::*begin)(),
221
+ Iterator_T (T::*end)(),
222
+ Identifier name)
223
+ {
224
+ detail::define_iterator(*this, name, begin, end);
225
+ return (Derived_T &)*this;
226
+ }
227
+
228
+ namespace Rice
229
+ {
230
+
231
+ namespace detail
232
+ {
233
+
234
+ inline VALUE
235
+ include_module(VALUE mod, VALUE inc)
236
+ {
237
+ rb_include_module(mod, inc);
238
+ return Qnil;
239
+ }
240
+
241
+ inline VALUE
242
+ const_set(VALUE mod, ID name, VALUE value)
243
+ {
244
+ rb_const_set(mod, name, value);
245
+ return Qnil;
246
+ }
247
+
248
+ } // namespace detail
249
+
250
+ } // namespace Rice
251
+
252
+ template<typename Base_T, typename Derived_T>
253
+ inline
254
+ Derived_T &
255
+ Rice::Module_impl<Base_T, Derived_T>::
256
+ include_module(
257
+ Module const & inc)
258
+ {
259
+ protect(detail::include_module, *this, inc);
260
+ return (Derived_T &)*this;
261
+ }
262
+
263
+ template<typename Base_T, typename Derived_T>
264
+ inline
265
+ Derived_T &
266
+ Rice::Module_impl<Base_T, Derived_T>::
267
+ const_set(
268
+ Identifier name,
269
+ Object value)
270
+ {
271
+ protect(detail::const_set, *this, name, value);
272
+ return (Derived_T &)*this;
273
+ }
274
+
275
+ template<typename Base_T, typename Derived_T>
276
+ inline
277
+ Rice::Object
278
+ Rice::Module_impl<Base_T, Derived_T>::
279
+ const_get(
280
+ Identifier name) const
281
+ {
282
+ return protect(rb_const_get, *this, name);
283
+ }
284
+
285
+ template<typename Base_T, typename Derived_T>
286
+ inline
287
+ bool
288
+ Rice::Module_impl<Base_T, Derived_T>::
289
+ const_defined(Identifier name) const
290
+ {
291
+ int result = protect(rb_const_defined, *this, name);
292
+ return bool(result);
293
+ }
294
+
295
+ template<typename Base_T, typename Derived_T>
296
+ inline
297
+ void
298
+ Rice::Module_impl<Base_T, Derived_T>::
299
+ remove_const(Identifier name)
300
+ {
301
+ protect(rb_mod_remove_const, *this, Symbol(name));
302
+ }
303
+
304
+ template<typename Base_T, typename Derived_T>
305
+ inline
306
+ Rice::Module
307
+ Rice::Module_impl<Base_T, Derived_T>::
308
+ define_module(
309
+ char const * name)
310
+ {
311
+ return Rice::define_module_under(*this, name);
312
+ }
313
+
314
+ template<typename Base_T, typename Derived_T>
315
+ inline
316
+ Rice::Class
317
+ Rice::Module_impl<Base_T, Derived_T>::
318
+ define_class(
319
+ char const * name,
320
+ Object superclass)
321
+ {
322
+ return Rice::define_class_under(*this, name, superclass);
323
+ }
324
+
325
+ template<typename Base_T, typename Derived_T>
326
+ template<typename T>
327
+ inline
328
+ Rice::Data_Type<T>
329
+ Rice::Module_impl<Base_T, Derived_T>::
330
+ define_class_with_object_as_base(
331
+ char const * name)
332
+ {
333
+ return Rice::define_class_under<T>(*this, name);
334
+ }
335
+
336
+ template<typename Base_T, typename Derived_T>
337
+ template<typename T, typename T_Base_T>
338
+ inline
339
+ Rice::Data_Type<T>
340
+ Rice::Module_impl<Base_T, Derived_T>::
341
+ define_class(
342
+ char const * name)
343
+ {
344
+ return Rice::define_class_under<T, T_Base_T>(
345
+ *this,
346
+ name);
347
+ }
348
+