jameskilton-rice 1.2.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (196) hide show
  1. data/COPYING +23 -0
  2. data/Doxyfile +1253 -0
  3. data/Makefile.am +26 -0
  4. data/Makefile.in +749 -0
  5. data/README +879 -0
  6. data/README.mingw +8 -0
  7. data/Rakefile +72 -0
  8. data/aclocal.m4 +891 -0
  9. data/bootstrap +8 -0
  10. data/config.guess +1526 -0
  11. data/config.sub +1658 -0
  12. data/configure +7668 -0
  13. data/configure.ac +52 -0
  14. data/depcomp +589 -0
  15. data/doxygen.ac +314 -0
  16. data/doxygen.am +186 -0
  17. data/extconf.rb +22 -0
  18. data/install-sh +519 -0
  19. data/missing +367 -0
  20. data/post-autoconf.rb +22 -0
  21. data/post-automake.rb +28 -0
  22. data/rice/Address_Registration_Guard.hpp +7 -0
  23. data/rice/Address_Registration_Guard.ipp +34 -0
  24. data/rice/Address_Registration_Guard_defn.hpp +65 -0
  25. data/rice/Allocation_Strategies.hpp +37 -0
  26. data/rice/Arg.hpp +8 -0
  27. data/rice/Arg_impl.hpp +116 -0
  28. data/rice/Arg_operators.cpp +21 -0
  29. data/rice/Arg_operators.hpp +18 -0
  30. data/rice/Array.hpp +220 -0
  31. data/rice/Array.ipp +263 -0
  32. data/rice/Builtin_Object.hpp +8 -0
  33. data/rice/Builtin_Object.ipp +50 -0
  34. data/rice/Builtin_Object_defn.hpp +51 -0
  35. data/rice/Class.cpp +57 -0
  36. data/rice/Class.hpp +8 -0
  37. data/rice/Class.ipp +6 -0
  38. data/rice/Class_defn.hpp +83 -0
  39. data/rice/Constructor.hpp +339 -0
  40. data/rice/Critical_Guard.hpp +40 -0
  41. data/rice/Critical_Guard.ipp +26 -0
  42. data/rice/Data_Object.hpp +8 -0
  43. data/rice/Data_Object.ipp +133 -0
  44. data/rice/Data_Object_defn.hpp +132 -0
  45. data/rice/Data_Type.cpp +21 -0
  46. data/rice/Data_Type.hpp +8 -0
  47. data/rice/Data_Type.ipp +306 -0
  48. data/rice/Data_Type_defn.hpp +219 -0
  49. data/rice/Data_Type_fwd.hpp +12 -0
  50. data/rice/Director.cpp +19 -0
  51. data/rice/Director.hpp +47 -0
  52. data/rice/Enum.hpp +118 -0
  53. data/rice/Enum.ipp +246 -0
  54. data/rice/Exception.cpp +59 -0
  55. data/rice/Exception.hpp +9 -0
  56. data/rice/Exception_Base.hpp +8 -0
  57. data/rice/Exception_Base.ipp +13 -0
  58. data/rice/Exception_Base_defn.hpp +27 -0
  59. data/rice/Exception_defn.hpp +69 -0
  60. data/rice/Hash.hpp +210 -0
  61. data/rice/Hash.ipp +338 -0
  62. data/rice/Identifier.cpp +8 -0
  63. data/rice/Identifier.hpp +50 -0
  64. data/rice/Identifier.ipp +33 -0
  65. data/rice/Jump_Tag.hpp +24 -0
  66. data/rice/Makefile.am +140 -0
  67. data/rice/Makefile.in +740 -0
  68. data/rice/Module.cpp +84 -0
  69. data/rice/Module.hpp +8 -0
  70. data/rice/Module.ipp +6 -0
  71. data/rice/Module_defn.hpp +88 -0
  72. data/rice/Module_impl.hpp +281 -0
  73. data/rice/Module_impl.ipp +348 -0
  74. data/rice/Object.cpp +153 -0
  75. data/rice/Object.hpp +8 -0
  76. data/rice/Object.ipp +19 -0
  77. data/rice/Object_defn.hpp +183 -0
  78. data/rice/Require_Guard.hpp +21 -0
  79. data/rice/String.cpp +94 -0
  80. data/rice/String.hpp +89 -0
  81. data/rice/Struct.cpp +117 -0
  82. data/rice/Struct.hpp +162 -0
  83. data/rice/Struct.ipp +26 -0
  84. data/rice/Symbol.cpp +25 -0
  85. data/rice/Symbol.hpp +66 -0
  86. data/rice/Symbol.ipp +44 -0
  87. data/rice/VM.cpp +92 -0
  88. data/rice/VM.hpp +32 -0
  89. data/rice/config.hpp +44 -0
  90. data/rice/config.hpp.in +43 -0
  91. data/rice/detail/Arguments.hpp +126 -0
  92. data/rice/detail/Auto_Function_Wrapper.hpp +861 -0
  93. data/rice/detail/Auto_Function_Wrapper.ipp +2929 -0
  94. data/rice/detail/Auto_Member_Function_Wrapper.hpp +828 -0
  95. data/rice/detail/Auto_Member_Function_Wrapper.ipp +2326 -0
  96. data/rice/detail/Caster.hpp +63 -0
  97. data/rice/detail/Exception_Handler.hpp +8 -0
  98. data/rice/detail/Exception_Handler.ipp +68 -0
  99. data/rice/detail/Exception_Handler_defn.hpp +96 -0
  100. data/rice/detail/Iterator.hpp +93 -0
  101. data/rice/detail/Not_Copyable.hpp +25 -0
  102. data/rice/detail/Wrapped_Function.hpp +33 -0
  103. data/rice/detail/check_ruby_type.cpp +27 -0
  104. data/rice/detail/check_ruby_type.hpp +23 -0
  105. data/rice/detail/creation_funcs.hpp +37 -0
  106. data/rice/detail/creation_funcs.ipp +36 -0
  107. data/rice/detail/default_allocation_func.hpp +23 -0
  108. data/rice/detail/default_allocation_func.ipp +11 -0
  109. data/rice/detail/define_method_and_auto_wrap.hpp +31 -0
  110. data/rice/detail/define_method_and_auto_wrap.ipp +30 -0
  111. data/rice/detail/demangle.cpp +56 -0
  112. data/rice/detail/demangle.hpp +19 -0
  113. data/rice/detail/env.hpp +19 -0
  114. data/rice/detail/from_ruby.hpp +43 -0
  115. data/rice/detail/from_ruby.ipp +60 -0
  116. data/rice/detail/method_data.cpp +392 -0
  117. data/rice/detail/method_data.cpp.rpp +301 -0
  118. data/rice/detail/method_data.hpp +21 -0
  119. data/rice/detail/mininode.cpp +1220 -0
  120. data/rice/detail/mininode.cpp.rpp +62 -0
  121. data/rice/detail/mininode.hpp +320 -0
  122. data/rice/detail/mininode.hpp.rpp +119 -0
  123. data/rice/detail/node.hpp +13 -0
  124. data/rice/detail/object_call.hpp +85 -0
  125. data/rice/detail/object_call.ipp +147 -0
  126. data/rice/detail/protect.cpp +29 -0
  127. data/rice/detail/protect.hpp +34 -0
  128. data/rice/detail/remove_const.hpp +21 -0
  129. data/rice/detail/ruby.hpp +89 -0
  130. data/rice/detail/ruby_version_code.hpp +6 -0
  131. data/rice/detail/ruby_version_code.hpp.in +6 -0
  132. data/rice/detail/rubysig.hpp +19 -0
  133. data/rice/detail/st.hpp +60 -0
  134. data/rice/detail/to_ruby.hpp +22 -0
  135. data/rice/detail/to_ruby.ipp +37 -0
  136. data/rice/detail/win32.hpp +16 -0
  137. data/rice/detail/wrap_function.hpp +345 -0
  138. data/rice/detail/wrap_function.ipp +531 -0
  139. data/rice/generate_code.rb +1311 -0
  140. data/rice/global_function.hpp +33 -0
  141. data/rice/global_function.ipp +22 -0
  142. data/rice/protect.hpp +91 -0
  143. data/rice/protect.ipp +803 -0
  144. data/rice/ruby_mark.hpp +13 -0
  145. data/rice/ruby_try_catch.hpp +86 -0
  146. data/rice/rubypp.rb +97 -0
  147. data/rice/to_from_ruby.hpp +8 -0
  148. data/rice/to_from_ruby.ipp +299 -0
  149. data/rice/to_from_ruby_defn.hpp +71 -0
  150. data/ruby.ac +150 -0
  151. data/ruby/Makefile.am +1 -0
  152. data/ruby/Makefile.in +497 -0
  153. data/ruby/lib/Makefile.am +3 -0
  154. data/ruby/lib/Makefile.in +374 -0
  155. data/ruby/lib/mkmf-rice.rb.in +209 -0
  156. data/ruby/lib/version.rb +3 -0
  157. data/sample/Makefile.am +47 -0
  158. data/sample/Makefile.in +380 -0
  159. data/sample/enum/extconf.rb +3 -0
  160. data/sample/enum/sample_enum.cpp +54 -0
  161. data/sample/enum/test.rb +8 -0
  162. data/sample/inheritance/animals.cpp +98 -0
  163. data/sample/inheritance/extconf.rb +3 -0
  164. data/sample/inheritance/test.rb +7 -0
  165. data/sample/map/extconf.rb +3 -0
  166. data/sample/map/map.cpp +81 -0
  167. data/sample/map/test.rb +7 -0
  168. data/test/Makefile.am +49 -0
  169. data/test/Makefile.in +603 -0
  170. data/test/test_Address_Registration_Guard.cpp +43 -0
  171. data/test/test_Allocation_Strategies.cpp +77 -0
  172. data/test/test_Array.cpp +241 -0
  173. data/test/test_Builtin_Object.cpp +72 -0
  174. data/test/test_Class.cpp +398 -0
  175. data/test/test_Constructor.cpp +238 -0
  176. data/test/test_Critical_Guard.cpp +51 -0
  177. data/test/test_Data_Object.cpp +275 -0
  178. data/test/test_Data_Type.cpp +121 -0
  179. data/test/test_Director.cpp +225 -0
  180. data/test/test_Enum.cpp +162 -0
  181. data/test/test_Exception.cpp +46 -0
  182. data/test/test_Hash.cpp +195 -0
  183. data/test/test_Identifier.cpp +70 -0
  184. data/test/test_Jump_Tag.cpp +17 -0
  185. data/test/test_Module.cpp +428 -0
  186. data/test/test_Object.cpp +148 -0
  187. data/test/test_String.cpp +94 -0
  188. data/test/test_Struct.cpp +192 -0
  189. data/test/test_Symbol.cpp +63 -0
  190. data/test/test_To_From_Ruby.cpp +263 -0
  191. data/test/test_VM.cpp +26 -0
  192. data/test/test_global_functions.cpp +97 -0
  193. data/test/test_rice.rb +35 -0
  194. data/test/unittest.cpp +136 -0
  195. data/test/unittest.hpp +292 -0
  196. metadata +247 -0
@@ -0,0 +1,238 @@
1
+ #include "unittest.hpp"
2
+ #include "rice/Constructor.hpp"
3
+ #include "rice/Data_Type.hpp"
4
+
5
+ #include "rice/detail/env.hpp"
6
+
7
+ #include <iostream>
8
+ using namespace std;
9
+
10
+ using namespace Rice;
11
+
12
+ TESTSUITE(Constructor);
13
+
14
+ namespace
15
+ {
16
+ class Default_Constructible
17
+ {
18
+ public:
19
+ Default_Constructible()
20
+ {
21
+ }
22
+ };
23
+ }
24
+
25
+ TESTCASE(default_constructor)
26
+ {
27
+ Data_Type<Default_Constructible> rb_cDefault_Constructible(
28
+ anonymous_class());
29
+ rb_cDefault_Constructible
30
+ .define_constructor(Constructor<Default_Constructible>());
31
+ Object o = rb_cDefault_Constructible.call("new");
32
+ ASSERT_EQUAL(rb_cDefault_Constructible, o.class_of());
33
+ }
34
+
35
+
36
+ namespace
37
+ {
38
+ class Non_Default_Constructible
39
+ {
40
+ public:
41
+ Non_Default_Constructible(int i)
42
+ : i_(i)
43
+ {
44
+ }
45
+
46
+ int i() const
47
+ {
48
+ return i_;
49
+ }
50
+
51
+ private:
52
+ int i_;
53
+ };
54
+ }
55
+
56
+ TESTCASE(non_default_constructor)
57
+ {
58
+ Data_Type<Non_Default_Constructible> rb_cNon_Default_Constructible(
59
+ anonymous_class());
60
+ rb_cNon_Default_Constructible
61
+ .define_constructor(Constructor<Non_Default_Constructible, int>());
62
+ Data_Object<Non_Default_Constructible> o =
63
+ rb_cNon_Default_Constructible.call("new", 42);
64
+ ASSERT_EQUAL(rb_cNon_Default_Constructible, o.class_of());
65
+ ASSERT_EQUAL(42, o->i());
66
+ }
67
+ /*
68
+ namespace {
69
+
70
+ class AbstractClass
71
+ {
72
+ public:
73
+
74
+ int doSomething()
75
+ {
76
+ return doSomethingImpl();
77
+ }
78
+
79
+ int doSomethingParam(int a, int b)
80
+ {
81
+ return doSomethingParamImpl(a, b);
82
+ }
83
+
84
+ virtual int doSomethingImpl() = 0;
85
+
86
+ virtual int doSomethingParamImpl(int a, int b) = 0;
87
+ };
88
+
89
+ class Director : public AbstractClass
90
+ {
91
+ Rice::Object m_rbSelf;
92
+
93
+ public:
94
+ Director(Rice::Object self) : m_rbSelf(self) { }
95
+
96
+ virtual int doSomethingImpl()
97
+ {
98
+ cout << endl << "In Impl, frame's last_func is " << rb_id2name(ruby_frame->last_func) << endl;
99
+ cout << endl << "In Impl, frame's orig_func is " << rb_id2name(ruby_frame->orig_func) << endl;
100
+ cout << endl << "In Impl, frame's last_class is " << Class(ruby_frame->last_class).name().str() << endl;
101
+
102
+ cout << endl << "In Impl, frame's prev's last_func is " << rb_id2name(ruby_frame->prev->last_func) << endl;
103
+ cout << endl << "In Impl, frame's prev's orig_func is " << rb_id2name(ruby_frame->prev->orig_func) << endl;
104
+
105
+ cout << endl << "We've got classname (frame) " << rb_obj_classname(ruby_frame->self) << " vs (self) " << rb_obj_classname(m_rbSelf.value()) << endl;
106
+ cout << endl << "We've got classname (frame prev) " << rb_obj_classname(ruby_frame->prev->self) << " vs (self) " << rb_obj_classname(m_rbSelf.value()) << endl;
107
+
108
+ // Need to get the Ruby callee, compare that to m_rbSelf, and
109
+ // if they're equal, go UP the chain, otherwise go DOWN
110
+ if(ruby_frame->self == m_rbSelf.value()) {
111
+ // As doSomethingImpl is pure virtual, we need to implement a default here so
112
+ // that super calls don't blow things up
113
+ return 100;
114
+ } else {
115
+ return from_ruby<int>( m_rbSelf.call("do_something_impl") );
116
+ }
117
+
118
+ }
119
+
120
+ virtual int doSomethingParamImpl(int a, int b)
121
+ {
122
+ return from_ruby<int>( m_rbSelf.call("do_something_param_impl", a, b) );
123
+ }
124
+ };
125
+ }
126
+
127
+ TESTCASE(director_system_polymorphic_calls)
128
+ {
129
+ Data_Type<AbstractClass> a = define_class<AbstractClass>("__AbstractClass__");
130
+
131
+ Data_Type<Director> d = define_class<Director, AbstractClass>("AbstractClass");
132
+ d.define_constructor(Constructor<Director, Rice::Object>());
133
+ d.define_method("do_something", &AbstractClass::doSomething);
134
+ d.define_method("do_something_impl", &Director::doSomethingImpl);
135
+
136
+ Module m = define_module("Testing");
137
+ m.instance_eval(
138
+ "class MyWorker < AbstractClass;"
139
+ "def do_something_impl; 8; end;"
140
+ "end"
141
+ );
142
+
143
+ Object result = m.instance_eval("worker = MyWorker.new; worker.do_something");
144
+
145
+ ASSERT_EQUAL(
146
+ 8, from_ruby<int>(result.value())
147
+ );
148
+ }
149
+
150
+ TESTCASE(director_system_polymorphic_calls_with_parameters)
151
+ {
152
+ Data_Type<AbstractClass> a = define_class<AbstractClass>("__AbstractClass__");
153
+
154
+ Data_Type<Director> d = define_class<Director, AbstractClass>("AbstractClass");
155
+ d.define_constructor(Constructor<Director, Rice::Object>());
156
+ d.define_method("do_something_param", &AbstractClass::doSomethingParam);
157
+ d.define_method("do_something_param_impl", &Director::doSomethingParamImpl);
158
+
159
+ Module m = define_module("Testing");
160
+ m.instance_eval(
161
+ "class MyWorker < AbstractClass;"
162
+ "def do_something_param_impl(a, b); a * b; end;"
163
+ "end"
164
+ );
165
+
166
+ Object result = m.instance_eval("worker = MyWorker.new; worker.do_something_param(2, 10)");
167
+
168
+ ASSERT_EQUAL(
169
+ 20, from_ruby<int>(result.value())
170
+ );
171
+ }
172
+
173
+ TESTCASE(director_system_polymorphic_calls_very_deep)
174
+ {
175
+ Data_Type<AbstractClass> a = define_class<AbstractClass>("__AbstractClass__");
176
+
177
+ Data_Type<Director> d = define_class<Director, AbstractClass>("AbstractClass");
178
+ d.define_constructor(Constructor<Director, Rice::Object>());
179
+ d.define_method("do_something", &AbstractClass::doSomething);
180
+ d.define_method("do_something_impl", &Director::doSomethingImpl);
181
+
182
+ Module m = define_module("Testing");
183
+ m.instance_eval(
184
+ "class MyWorker < AbstractClass;"
185
+ "def do_something_impl; 4; end;"
186
+ "end;"
187
+ "class MyWorker2 < MyWorker;"
188
+ "def do_something_impl; 6; end;"
189
+ "end;"
190
+ "class MyWorker3 < MyWorker2;"
191
+ "def do_something_impl; 8; end;"
192
+ "end;"
193
+ "class MyWorker4 < MyWorker3;"
194
+ "def do_something_impl; 10; end;"
195
+ "end;"
196
+ );
197
+
198
+ Object result = m.instance_eval("worker = MyWorker4.new; worker.do_something");
199
+
200
+ ASSERT_EQUAL(
201
+ 10, from_ruby<int>(result.value())
202
+ );
203
+ }
204
+
205
+ TESTCASE(director_system_super_calls_dont_infinite_loop)
206
+ {
207
+ Data_Type<AbstractClass> a = define_class<AbstractClass>("__AbstractClass__");
208
+
209
+ Data_Type<Director> d = define_class<Director, AbstractClass>("AbstractClass");
210
+ d.define_constructor(Constructor<Director, Rice::Object>());
211
+ d.define_method("do_something", &AbstractClass::doSomething);
212
+ d.define_method("do_something_impl", &Director::doSomethingImpl);
213
+
214
+ Module m = define_module("Testing");
215
+ m.instance_eval(
216
+ "class MyWorker < AbstractClass;"
217
+ "@@call_count = 0;"
218
+ "def do_something_impl;"
219
+ "@@call_count += 1;"
220
+ "if @@call_count == 1; super; else; -1; end;"
221
+ "end; end;"
222
+ );
223
+
224
+ Object result = m.instance_eval("worker = MyWorker.new; worker.do_something");
225
+
226
+ // -1 means that the do_something_impl got called twice, aka we were in an infinite loop
227
+ // had the class var check not been there
228
+ ASSERT_NOT_EQUAL(
229
+ -1,
230
+ from_ruby<int>(result.value())
231
+ );
232
+
233
+ ASSERT_EQUAL(
234
+ 100,
235
+ from_ruby<int>(result.value())
236
+ );
237
+ }
238
+ */
@@ -0,0 +1,51 @@
1
+ #include "unittest.hpp"
2
+ #include "rice/Critical_Guard.hpp"
3
+ #include <stdexcept>
4
+
5
+ #if RICE__RUBY_VERSION_CODE < 190
6
+
7
+ using namespace Rice;
8
+
9
+ TESTSUITE(Critical_Guard);
10
+
11
+ SETUP(Critical_Guard)
12
+ {
13
+ ruby_init();
14
+ }
15
+
16
+ TESTCASE(normal_path)
17
+ {
18
+ rb_thread_critical = 1;
19
+ {
20
+ Critical_Guard g;
21
+ ASSERT(rb_thread_critical);
22
+ }
23
+ ASSERT(!rb_thread_critical);
24
+ }
25
+
26
+ TESTCASE(unset_thread_critical_on_destruction)
27
+ {
28
+ rb_thread_critical = 1;
29
+ {
30
+ Critical_Guard g;
31
+ ASSERT(rb_thread_critical);
32
+ }
33
+ ASSERT(!rb_thread_critical);
34
+ }
35
+
36
+ TESTCASE(exception)
37
+ {
38
+ rb_thread_critical = 1;
39
+ try
40
+ {
41
+ Critical_Guard g;
42
+ throw std::runtime_error("testing");
43
+ }
44
+ catch(...)
45
+ {
46
+ }
47
+ ASSERT(!rb_thread_critical);
48
+ }
49
+
50
+ #endif
51
+
@@ -0,0 +1,275 @@
1
+ #include "unittest.hpp"
2
+ #include "rice/Data_Object.hpp"
3
+ #include "rice/Data_Type.hpp"
4
+ #include "rice/Exception.hpp"
5
+
6
+ using namespace Rice;
7
+
8
+ TESTSUITE(Data_Object);
9
+
10
+ namespace
11
+ {
12
+ struct Foo { Foo() : x_(42) { } int x_; };
13
+
14
+ bool test_ruby_mark__marked = false;
15
+ }
16
+
17
+ template<>
18
+ void ruby_mark(Foo * foo)
19
+ {
20
+ test_ruby_mark__marked = true;
21
+ }
22
+
23
+ SETUP(Data_Object)
24
+ {
25
+ ruby_init();
26
+
27
+ if(!Data_Type<Foo>::is_bound())
28
+ {
29
+ Class object(rb_cObject);
30
+ if(object.const_defined("Foo"))
31
+ {
32
+ object.remove_const("Foo");
33
+ }
34
+
35
+ define_class<Foo>("Foo");
36
+ }
37
+ }
38
+
39
+ TESTCASE(construct_from_pointer_with_defaults)
40
+ {
41
+ Data_Type<Foo> rb_cFoo;
42
+ Foo * foo = new Foo;
43
+ Data_Object<Foo> wrapped_foo(foo);
44
+ ASSERT_EQUAL(foo, wrapped_foo.get());
45
+ ASSERT_EQUAL(Data_Type<Foo>::klass(), wrapped_foo.class_of());
46
+ typedef void (*Mark_Func)(void *);
47
+ typedef void (*Mark_Func_Foo)(Foo *);
48
+ Mark_Func expected_mark_func =
49
+ Mark_Func(Mark_Func_Foo(ruby_mark<Foo>));
50
+ ASSERT_EQUAL(
51
+ expected_mark_func,
52
+ RDATA(wrapped_foo.value())->dmark);
53
+ ASSERT_EQUAL(
54
+ RUBY_DATA_FUNC(Default_Allocation_Strategy<Foo>::free),
55
+ RUBY_DATA_FUNC(RDATA(wrapped_foo.value())->dfree));
56
+ ASSERT_EQUAL(foo, DATA_PTR(wrapped_foo.value()));
57
+ }
58
+
59
+ TESTCASE(construct_from_pointer_and_klass)
60
+ {
61
+ Data_Type<Foo> rb_cFoo;
62
+ Foo * foo = new Foo;
63
+ Data_Object<Foo> wrapped_foo(foo, Data_Type<Foo>::klass());
64
+ ASSERT_EQUAL(foo, wrapped_foo.get());
65
+ ASSERT_EQUAL(Data_Type<Foo>::klass(), wrapped_foo.class_of());
66
+ typedef void (*Mark_Func)(void *);
67
+ typedef void (*Mark_Func_Foo)(Foo *);
68
+ Mark_Func expected_mark_func =
69
+ Mark_Func(Mark_Func_Foo(ruby_mark<Foo>));
70
+ ASSERT_EQUAL(
71
+ expected_mark_func,
72
+ RDATA(wrapped_foo.value())->dmark);
73
+ ASSERT_EQUAL(
74
+ RUBY_DATA_FUNC(Default_Allocation_Strategy<Foo>::free),
75
+ RUBY_DATA_FUNC(RDATA(wrapped_foo.value())->dfree));
76
+ ASSERT_EQUAL(foo, DATA_PTR(wrapped_foo.value()));
77
+ }
78
+
79
+ TESTCASE(construct_from_pointer_and_alternate_klass)
80
+ {
81
+ Data_Type<Foo> rb_cFoo;
82
+ Foo * foo = new Foo;
83
+ Data_Object<Foo> wrapped_foo(foo, rb_cObject);
84
+ ASSERT_EQUAL(foo, wrapped_foo.get());
85
+ ASSERT_EQUAL(rb_cObject, CLASS_OF(wrapped_foo.value()));
86
+ typedef void (*Mark_Func)(void *);
87
+ typedef void (*Mark_Func_Foo)(Foo *);
88
+ Mark_Func expected_mark_func =
89
+ Mark_Func(Mark_Func_Foo(ruby_mark<Foo>));
90
+ ASSERT_EQUAL(
91
+ expected_mark_func,
92
+ RDATA(wrapped_foo.value())->dmark);
93
+ ASSERT_EQUAL(
94
+ RUBY_DATA_FUNC(Default_Allocation_Strategy<Foo>::free),
95
+ RUBY_DATA_FUNC(RDATA(wrapped_foo.value())->dfree));
96
+ ASSERT_EQUAL(foo, DATA_PTR(wrapped_foo.value()));
97
+ }
98
+
99
+ namespace
100
+ {
101
+ void dummy_mark(Foo *)
102
+ {
103
+ }
104
+ }
105
+
106
+ TESTCASE(construct_from_pointer_and_klass_and_mark_function)
107
+ {
108
+ Data_Type<Foo> rb_cFoo;
109
+ Foo * foo = new Foo;
110
+ Data_Object<Foo> wrapped_foo(foo, rb_cFoo, dummy_mark);
111
+ ASSERT_EQUAL(foo, wrapped_foo.get());
112
+ ASSERT_EQUAL(Data_Type<Foo>::klass(), wrapped_foo.class_of());
113
+ ASSERT_EQUAL((void *)dummy_mark, RDATA(wrapped_foo.value())->dmark);
114
+ ASSERT_EQUAL(
115
+ RUBY_DATA_FUNC(Default_Allocation_Strategy<Foo>::free),
116
+ RUBY_DATA_FUNC(RDATA(wrapped_foo.value())->dfree));
117
+ ASSERT_EQUAL(foo, DATA_PTR(wrapped_foo.value()));
118
+ }
119
+
120
+ namespace
121
+ {
122
+ void my_free(Foo * f)
123
+ {
124
+ delete f;
125
+ }
126
+ }
127
+
128
+ TESTCASE(construct_from_pointer_and_klass_and_mark_and_free)
129
+ {
130
+ Data_Type<Foo> rb_cFoo;
131
+ Foo * foo = new Foo;
132
+ Data_Object<Foo> wrapped_foo(foo, rb_cFoo, dummy_mark, my_free);
133
+ ASSERT_EQUAL(foo, wrapped_foo.get());
134
+ ASSERT_EQUAL(Data_Type<Foo>::klass(), wrapped_foo.class_of());
135
+ ASSERT_EQUAL((void *)dummy_mark, RDATA(wrapped_foo.value())->dmark);
136
+ ASSERT_EQUAL(
137
+ RUBY_DATA_FUNC(my_free),
138
+ RUBY_DATA_FUNC(RDATA(wrapped_foo.value())->dfree));
139
+ ASSERT_EQUAL(foo, DATA_PTR(wrapped_foo.value()));
140
+ }
141
+
142
+ TESTCASE(construct_from_ruby_object)
143
+ {
144
+ Foo * foo = new Foo;
145
+ VALUE wrapped_foo = Data_Wrap_Struct(Data_Type<Foo>::klass(), 0, Default_Allocation_Strategy<Foo>::free, foo);
146
+ Data_Object<Foo> data_object_foo(wrapped_foo);
147
+ ASSERT_EQUAL(foo, data_object_foo.get());
148
+ ASSERT_EQUAL(Data_Type<Foo>::klass(), data_object_foo.class_of());
149
+ ASSERT_EQUAL(RDATA(wrapped_foo), RDATA(data_object_foo.value()));
150
+ ASSERT_EQUAL(RUBY_DATA_FUNC(0), RDATA(data_object_foo.value())->dmark);
151
+ ASSERT_EQUAL(
152
+ RUBY_DATA_FUNC(Default_Allocation_Strategy<Foo>::free),
153
+ RUBY_DATA_FUNC(RDATA(data_object_foo.value())->dfree));
154
+ ASSERT_EQUAL(foo, DATA_PTR(data_object_foo.value()));
155
+ }
156
+
157
+ TESTCASE(construct_from_ruby_object_and_class)
158
+ {
159
+ Data_Type<Foo> rb_cFoo;
160
+ Foo * foo = new Foo;
161
+ VALUE wrapped_foo = Data_Wrap_Struct(Data_Type<Foo>::klass(), 0, Default_Allocation_Strategy<Foo>::free, foo);
162
+ Data_Object<Foo> data_object_foo(wrapped_foo, rb_cFoo);
163
+ ASSERT_EQUAL(foo, data_object_foo.get());
164
+ ASSERT_EQUAL(Data_Type<Foo>::klass(), data_object_foo.class_of());
165
+ ASSERT_EQUAL(RDATA(wrapped_foo), RDATA(data_object_foo.value()));
166
+ ASSERT_EQUAL(RUBY_DATA_FUNC(0), RDATA(data_object_foo.value())->dmark);
167
+ ASSERT_EQUAL(
168
+ RUBY_DATA_FUNC(Default_Allocation_Strategy<Foo>::free),
169
+ RUBY_DATA_FUNC(RDATA(data_object_foo.value())->dfree));
170
+ ASSERT_EQUAL(foo, DATA_PTR(data_object_foo.value()));
171
+ }
172
+
173
+ TESTCASE(construct_from_ruby_object_and_wrong_class)
174
+ {
175
+ Foo * foo = new Foo;
176
+ Data_Type<Foo> rb_cFoo;
177
+ VALUE wrapped_foo = Data_Wrap_Struct(rb_cObject, 0, Default_Allocation_Strategy<Foo>::free, foo);
178
+ ASSERT_EXCEPTION_CHECK(
179
+ Exception,
180
+ Data_Object<Foo> data_object_foo(wrapped_foo, rb_cFoo),
181
+ ASSERT_EQUAL(
182
+ Object(rb_eTypeError),
183
+ Object(CLASS_OF(ex.value()))
184
+ )
185
+ );
186
+ }
187
+
188
+ TESTCASE(copy_construct)
189
+ {
190
+ Data_Type<Foo> rb_cFoo;
191
+ Foo * foo = new Foo;
192
+ VALUE wrapped_foo = Data_Wrap_Struct(Data_Type<Foo>::klass(), 0, Default_Allocation_Strategy<Foo>::free, foo);
193
+ Data_Object<Foo> orig_data_object_foo(wrapped_foo, rb_cFoo);
194
+ Data_Object<Foo> data_object_foo(orig_data_object_foo);
195
+ ASSERT_EQUAL(foo, data_object_foo.get());
196
+ ASSERT_EQUAL(Data_Type<Foo>::klass(), data_object_foo.class_of());
197
+ ASSERT_EQUAL(RDATA(wrapped_foo), RDATA(data_object_foo.value()));
198
+ ASSERT_EQUAL(RUBY_DATA_FUNC(0), RDATA(data_object_foo.value())->dmark);
199
+ ASSERT_EQUAL(
200
+ RUBY_DATA_FUNC(Default_Allocation_Strategy<Foo>::free),
201
+ RUBY_DATA_FUNC(RDATA(data_object_foo.value())->dfree));
202
+ ASSERT_EQUAL(foo, DATA_PTR(data_object_foo.value()));
203
+ }
204
+
205
+ TESTCASE(dereference)
206
+ {
207
+ Data_Type<Foo> rb_cFoo;
208
+ Foo * foo = new Foo;
209
+ Data_Object<Foo> wrapped_foo(foo);
210
+ ASSERT_EQUAL(foo, &*wrapped_foo);
211
+ }
212
+
213
+ TESTCASE(arrow)
214
+ {
215
+ Data_Type<Foo> rb_cFoo;
216
+ Foo * foo = new Foo;
217
+ Data_Object<Foo> wrapped_foo(foo);
218
+ ASSERT_EQUAL(42, foo->x_);
219
+ }
220
+
221
+ TESTCASE(get)
222
+ {
223
+ Data_Type<Foo> rb_cFoo;
224
+ Foo * foo = new Foo;
225
+ Data_Object<Foo> wrapped_foo(foo);
226
+ ASSERT_EQUAL(foo, wrapped_foo.get());
227
+ }
228
+
229
+ // TODO: swap
230
+
231
+ TESTCASE(to_ruby)
232
+ {
233
+ Data_Type<Foo> rb_cFoo;
234
+ Foo * foo = new Foo;
235
+ Data_Object<Foo> wrapped_foo(foo);
236
+ ASSERT_EQUAL(wrapped_foo.value(), to_ruby(wrapped_foo).value());
237
+ }
238
+
239
+ TESTCASE(from_ruby)
240
+ {
241
+ Data_Type<Foo> rb_cFoo;
242
+ Foo * foo = new Foo;
243
+ Data_Object<Foo> wrapped_foo(foo);
244
+ ASSERT_EQUAL(foo, from_ruby<Foo *>(wrapped_foo));
245
+ }
246
+
247
+ TESTCASE(from_ruby_const_ref)
248
+ {
249
+ Data_Type<Foo> rb_cFoo;
250
+ Foo * foo = new Foo;
251
+ Data_Object<Foo> wrapped_foo(foo);
252
+ ASSERT_EQUAL(foo->x_, from_ruby<Foo const &>(wrapped_foo).x_);
253
+ }
254
+
255
+ TESTCASE(from_ruby_copy)
256
+ {
257
+ Data_Type<Foo> rb_cFoo;
258
+ Foo * foo = new Foo;
259
+ Data_Object<Foo> wrapped_foo(foo);
260
+ ASSERT_EQUAL(foo->x_, from_ruby<Foo>(wrapped_foo).x_);
261
+ }
262
+
263
+ TESTCASE(ruby_mark)
264
+ {
265
+ Data_Type<Foo> rb_cFoo;
266
+ Foo * foo = new Foo;
267
+ Data_Object<Foo> wrapped_foo(foo);
268
+
269
+ test_ruby_mark__marked = false;
270
+
271
+ rb_gc_start();
272
+
273
+ ASSERT_EQUAL(true, test_ruby_mark__marked);
274
+ }
275
+