rice 3.0.0 → 4.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +121 -0
- data/CONTRIBUTORS.md +19 -0
- data/Gemfile +3 -0
- data/README.md +44 -1025
- data/Rakefile +95 -12
- data/include/rice/rice.hpp +7766 -0
- data/lib/mkmf-rice.rb +127 -0
- data/lib/version.rb +3 -0
- data/rice/Address_Registration_Guard.ipp +75 -32
- data/rice/Address_Registration_Guard_defn.hpp +60 -56
- data/rice/Arg.hpp +80 -4
- data/rice/Arg.ipp +51 -0
- data/rice/Constructor.hpp +12 -14
- data/rice/Data_Object.ipp +234 -107
- data/rice/Data_Object_defn.hpp +77 -117
- data/rice/Data_Type.hpp +1 -2
- data/rice/Data_Type.ipp +251 -295
- data/rice/Data_Type_defn.hpp +175 -243
- data/rice/Director.hpp +11 -6
- data/rice/Enum.hpp +54 -104
- data/rice/Enum.ipp +104 -230
- data/rice/Exception.hpp +2 -8
- data/rice/Exception.ipp +65 -0
- data/rice/Exception_defn.hpp +46 -47
- data/rice/Identifier.hpp +28 -28
- data/rice/Identifier.ipp +23 -27
- data/rice/Return.hpp +39 -0
- data/rice/Return.ipp +33 -0
- data/rice/detail/Exception_Handler.ipp +22 -62
- data/rice/detail/Exception_Handler_defn.hpp +76 -91
- data/rice/detail/Iterator.hpp +18 -88
- data/rice/detail/Iterator.ipp +47 -0
- data/rice/detail/Jump_Tag.hpp +21 -0
- data/rice/detail/MethodInfo.hpp +44 -0
- data/rice/detail/MethodInfo.ipp +78 -0
- data/rice/detail/NativeAttribute.hpp +53 -0
- data/rice/detail/NativeAttribute.ipp +83 -0
- data/rice/detail/NativeFunction.hpp +69 -0
- data/rice/detail/NativeFunction.ipp +248 -0
- data/rice/detail/RubyFunction.hpp +39 -0
- data/rice/detail/RubyFunction.ipp +92 -0
- data/rice/detail/Type.hpp +29 -0
- data/rice/detail/Type.ipp +138 -0
- data/rice/detail/TypeRegistry.hpp +50 -0
- data/rice/detail/TypeRegistry.ipp +106 -0
- data/rice/detail/Wrapper.hpp +51 -0
- data/rice/detail/Wrapper.ipp +151 -0
- data/rice/detail/default_allocation_func.hpp +8 -19
- data/rice/detail/default_allocation_func.ipp +9 -8
- data/rice/detail/from_ruby.hpp +2 -37
- data/rice/detail/from_ruby.ipp +1020 -46
- data/rice/detail/from_ruby_defn.hpp +38 -0
- data/rice/detail/function_traits.hpp +124 -0
- data/rice/detail/method_data.hpp +23 -15
- data/rice/detail/method_data.ipp +53 -0
- data/rice/detail/rice_traits.hpp +116 -0
- data/rice/detail/ruby.hpp +9 -46
- data/rice/detail/to_ruby.hpp +3 -17
- data/rice/detail/to_ruby.ipp +409 -31
- data/rice/detail/to_ruby_defn.hpp +48 -0
- data/rice/forward_declares.ipp +82 -0
- data/rice/global_function.hpp +16 -20
- data/rice/global_function.ipp +8 -17
- data/rice/rice.hpp +59 -0
- data/rice/ruby_mark.hpp +5 -3
- data/rice/ruby_try_catch.hpp +4 -4
- data/rice/stl.hpp +11 -0
- data/sample/callbacks/extconf.rb +3 -0
- data/sample/callbacks/sample_callbacks.cpp +10 -13
- data/sample/enum/extconf.rb +3 -0
- data/sample/enum/sample_enum.cpp +3 -17
- data/sample/enum/test.rb +2 -2
- data/sample/inheritance/animals.cpp +8 -24
- data/sample/inheritance/extconf.rb +3 -0
- data/sample/inheritance/test.rb +1 -1
- data/sample/map/extconf.rb +3 -0
- data/sample/map/map.cpp +10 -18
- data/sample/map/test.rb +1 -1
- data/test/embed_ruby.cpp +18 -5
- data/test/ext/t1/extconf.rb +3 -0
- data/test/ext/t1/t1.cpp +1 -3
- data/test/ext/t2/extconf.rb +3 -0
- data/test/ext/t2/t2.cpp +1 -1
- data/test/extconf.rb +23 -0
- data/test/ruby/test_callbacks_sample.rb +28 -0
- data/test/ruby/test_multiple_extensions.rb +18 -0
- data/test/ruby/test_multiple_extensions_same_class.rb +14 -0
- data/test/ruby/test_multiple_extensions_with_inheritance.rb +20 -0
- data/test/test_Address_Registration_Guard.cpp +23 -10
- data/test/test_Array.cpp +129 -73
- data/test/test_Attribute.cpp +147 -0
- data/test/test_Builtin_Object.cpp +34 -14
- data/test/test_Class.cpp +149 -275
- data/test/test_Constructor.cpp +10 -9
- data/test/test_Data_Object.cpp +133 -192
- data/test/test_Data_Type.cpp +322 -252
- data/test/test_Director.cpp +54 -41
- data/test/test_Enum.cpp +228 -103
- data/test/test_Exception.cpp +5 -6
- data/test/test_Hash.cpp +31 -30
- data/test/test_Identifier.cpp +4 -5
- data/test/test_Inheritance.cpp +221 -0
- data/test/test_Iterator.cpp +161 -0
- data/test/test_Jump_Tag.cpp +1 -1
- data/test/test_Keep_Alive.cpp +161 -0
- data/test/test_Memory_Management.cpp +2 -4
- data/test/test_Module.cpp +167 -110
- data/test/test_Object.cpp +41 -21
- data/test/test_Ownership.cpp +275 -0
- data/test/test_Self.cpp +205 -0
- data/test/test_Stl_Optional.cpp +90 -0
- data/test/test_Stl_Pair.cpp +144 -0
- data/test/test_Stl_SmartPointer.cpp +200 -0
- data/test/test_Stl_String.cpp +74 -0
- data/test/test_Stl_Vector.cpp +652 -0
- data/test/test_String.cpp +1 -2
- data/test/test_Struct.cpp +29 -39
- data/test/test_Symbol.cpp +1 -2
- data/test/test_To_From_Ruby.cpp +249 -285
- data/test/test_global_functions.cpp +39 -19
- data/test/unittest.hpp +0 -4
- metadata +63 -139
- data/Doxyfile +0 -2268
- data/Makefile.am +0 -26
- data/Makefile.in +0 -931
- data/README.mingw +0 -8
- data/aclocal.m4 +0 -1085
- data/ax_cxx_compile_stdcxx.m4 +0 -951
- data/bootstrap +0 -8
- data/config.guess +0 -1421
- data/config.sub +0 -1807
- data/configure +0 -7792
- data/configure.ac +0 -55
- data/depcomp +0 -791
- data/doxygen.ac +0 -314
- data/doxygen.am +0 -186
- data/extconf.rb +0 -70
- data/install-sh +0 -501
- data/missing +0 -215
- data/post-autoconf.rb +0 -22
- data/post-automake.rb +0 -28
- data/rice/Address_Registration_Guard.cpp +0 -22
- data/rice/Arg_impl.hpp +0 -129
- data/rice/Arg_operators.cpp +0 -21
- data/rice/Arg_operators.hpp +0 -19
- data/rice/Array.hpp +0 -214
- data/rice/Array.ipp +0 -256
- data/rice/Builtin_Object.hpp +0 -8
- data/rice/Builtin_Object.ipp +0 -50
- data/rice/Builtin_Object_defn.hpp +0 -50
- data/rice/Class.cpp +0 -57
- data/rice/Class.hpp +0 -8
- data/rice/Class.ipp +0 -6
- data/rice/Class_defn.hpp +0 -84
- data/rice/Data_Type.cpp +0 -54
- data/rice/Data_Type_fwd.hpp +0 -12
- data/rice/Director.cpp +0 -13
- data/rice/Exception.cpp +0 -54
- data/rice/Exception_Base.hpp +0 -8
- data/rice/Exception_Base.ipp +0 -13
- data/rice/Exception_Base_defn.hpp +0 -27
- data/rice/Hash.hpp +0 -230
- data/rice/Hash.ipp +0 -329
- data/rice/Identifier.cpp +0 -8
- data/rice/Jump_Tag.hpp +0 -24
- data/rice/Makefile.am +0 -121
- data/rice/Makefile.in +0 -884
- data/rice/Module.cpp +0 -84
- data/rice/Module.hpp +0 -8
- data/rice/Module.ipp +0 -6
- data/rice/Module_defn.hpp +0 -88
- data/rice/Module_impl.hpp +0 -281
- data/rice/Module_impl.ipp +0 -345
- data/rice/Object.cpp +0 -169
- data/rice/Object.hpp +0 -8
- data/rice/Object.ipp +0 -33
- data/rice/Object_defn.hpp +0 -214
- data/rice/Require_Guard.hpp +0 -21
- data/rice/String.cpp +0 -89
- data/rice/String.hpp +0 -91
- data/rice/Struct.cpp +0 -117
- data/rice/Struct.hpp +0 -162
- data/rice/Struct.ipp +0 -26
- data/rice/Symbol.cpp +0 -25
- data/rice/Symbol.hpp +0 -66
- data/rice/Symbol.ipp +0 -44
- data/rice/config.hpp +0 -47
- data/rice/config.hpp.in +0 -46
- data/rice/detail/Arguments.hpp +0 -118
- data/rice/detail/Auto_Function_Wrapper.hpp +0 -898
- data/rice/detail/Auto_Function_Wrapper.ipp +0 -3181
- data/rice/detail/Auto_Member_Function_Wrapper.hpp +0 -897
- data/rice/detail/Auto_Member_Function_Wrapper.ipp +0 -2501
- data/rice/detail/Caster.hpp +0 -103
- data/rice/detail/Not_Copyable.hpp +0 -25
- data/rice/detail/Wrapped_Function.hpp +0 -33
- data/rice/detail/cfp.hpp +0 -24
- data/rice/detail/cfp.ipp +0 -51
- data/rice/detail/check_ruby_type.cpp +0 -27
- data/rice/detail/check_ruby_type.hpp +0 -23
- data/rice/detail/creation_funcs.hpp +0 -37
- data/rice/detail/creation_funcs.ipp +0 -36
- data/rice/detail/define_method_and_auto_wrap.hpp +0 -31
- data/rice/detail/define_method_and_auto_wrap.ipp +0 -30
- data/rice/detail/demangle.cpp +0 -56
- data/rice/detail/demangle.hpp +0 -19
- data/rice/detail/env.hpp +0 -11
- data/rice/detail/method_data.cpp +0 -92
- data/rice/detail/node.hpp +0 -13
- data/rice/detail/protect.cpp +0 -29
- data/rice/detail/protect.hpp +0 -34
- data/rice/detail/ruby_version_code.hpp +0 -6
- data/rice/detail/ruby_version_code.hpp.in +0 -6
- data/rice/detail/st.hpp +0 -22
- data/rice/detail/win32.hpp +0 -16
- data/rice/detail/wrap_function.hpp +0 -66
- data/rice/protect.hpp +0 -38
- data/rice/protect.ipp +0 -1134
- data/rice/rubypp.rb +0 -97
- data/rice/to_from_ruby.hpp +0 -8
- data/rice/to_from_ruby.ipp +0 -418
- data/rice/to_from_ruby_defn.hpp +0 -70
- data/ruby.ac +0 -135
- data/ruby/Makefile.am +0 -1
- data/ruby/Makefile.in +0 -628
- data/ruby/lib/Makefile.am +0 -3
- data/ruby/lib/Makefile.in +0 -506
- data/ruby/lib/mkmf-rice.rb.in +0 -217
- data/ruby/lib/version.rb +0 -3
- data/sample/Makefile.am +0 -53
- data/sample/Makefile.in +0 -495
- data/test/Makefile.am +0 -73
- data/test/Makefile.in +0 -1219
- data/test/ext/Makefile.am +0 -41
- data/test/ext/Makefile.in +0 -483
- data/test/test_rice.rb +0 -45
data/test/test_Jump_Tag.cpp
CHANGED
@@ -0,0 +1,161 @@
|
|
1
|
+
#include "unittest.hpp"
|
2
|
+
#include "embed_ruby.hpp"
|
3
|
+
#include <rice/rice.hpp>
|
4
|
+
#include <rice/stl.hpp>
|
5
|
+
|
6
|
+
using namespace Rice;
|
7
|
+
|
8
|
+
TESTSUITE(Keep_Alive);
|
9
|
+
|
10
|
+
namespace
|
11
|
+
{
|
12
|
+
class Listener {
|
13
|
+
public:
|
14
|
+
virtual ~Listener() = default;
|
15
|
+
virtual int getValue() { return 4; }
|
16
|
+
};
|
17
|
+
|
18
|
+
/**
|
19
|
+
* This class will recieve a new Listener instance
|
20
|
+
* from Ruby
|
21
|
+
*/
|
22
|
+
class ListenerContainer
|
23
|
+
{
|
24
|
+
public:
|
25
|
+
void addListener(Listener* listener)
|
26
|
+
{
|
27
|
+
mListeners.push_back(listener);
|
28
|
+
}
|
29
|
+
|
30
|
+
void removeListener(Listener* listener)
|
31
|
+
{
|
32
|
+
auto iter = std::find(mListeners.begin(), mListeners.end(), listener);
|
33
|
+
mListeners.erase(iter);
|
34
|
+
}
|
35
|
+
|
36
|
+
int process()
|
37
|
+
{
|
38
|
+
std::vector<Listener*>::iterator i = mListeners.begin();
|
39
|
+
int accum = 0;
|
40
|
+
for(; i != mListeners.end(); i++)
|
41
|
+
{
|
42
|
+
accum += (*i)->getValue();
|
43
|
+
}
|
44
|
+
|
45
|
+
return accum;
|
46
|
+
}
|
47
|
+
|
48
|
+
size_t listenerCount()
|
49
|
+
{
|
50
|
+
return mListeners.size();
|
51
|
+
}
|
52
|
+
|
53
|
+
private:
|
54
|
+
std::vector<Listener*> mListeners;
|
55
|
+
};
|
56
|
+
}
|
57
|
+
|
58
|
+
SETUP(Keep_Alive)
|
59
|
+
{
|
60
|
+
embed_ruby();
|
61
|
+
}
|
62
|
+
|
63
|
+
TESTCASE(test_arg)
|
64
|
+
{
|
65
|
+
define_class<Listener>("Listener")
|
66
|
+
.define_constructor(Constructor<Listener>())
|
67
|
+
.define_method("get_value", &Listener::getValue);
|
68
|
+
|
69
|
+
define_class<ListenerContainer>("ListenerContainer")
|
70
|
+
.define_constructor(Constructor<ListenerContainer>())
|
71
|
+
.define_method("add_listener", &ListenerContainer::addListener, Arg("listener").keepAlive())
|
72
|
+
.define_method("process", &ListenerContainer::process)
|
73
|
+
.define_method("listener_count", &ListenerContainer::listenerCount);
|
74
|
+
|
75
|
+
Module m = define_module("TestingModule");
|
76
|
+
Object handler = m.instance_eval("@handler = ListenerContainer.new");
|
77
|
+
|
78
|
+
ASSERT_EQUAL(INT2NUM(0), handler.call("listener_count").value());
|
79
|
+
|
80
|
+
m.instance_eval(R"EOS(class MyListener < Listener
|
81
|
+
end)EOS");
|
82
|
+
|
83
|
+
m.instance_eval("@handler.add_listener(MyListener.new)");
|
84
|
+
|
85
|
+
// Without keep alive, this GC will crash the program because MyListener is no longer in scope
|
86
|
+
rb_gc_start();
|
87
|
+
|
88
|
+
ASSERT_EQUAL(INT2NUM(1), handler.call("listener_count").value());
|
89
|
+
ASSERT_EQUAL(INT2NUM(4), handler.call("process").value());
|
90
|
+
|
91
|
+
// Without keep alive, this GC will crash the program because MyListener is no longer in scope
|
92
|
+
rb_gc_start();
|
93
|
+
m.instance_eval("@handler.add_listener(Listener.new)");
|
94
|
+
|
95
|
+
ASSERT_EQUAL(INT2NUM(2), handler.call("listener_count").value());
|
96
|
+
ASSERT_EQUAL(INT2NUM(8), handler.call("process").value());
|
97
|
+
}
|
98
|
+
|
99
|
+
namespace
|
100
|
+
{
|
101
|
+
class Connection;
|
102
|
+
|
103
|
+
class Column
|
104
|
+
{
|
105
|
+
public:
|
106
|
+
Column(Connection& connection, uint32_t index) : connection_(connection), index_(index)
|
107
|
+
{
|
108
|
+
}
|
109
|
+
|
110
|
+
std::string name();
|
111
|
+
|
112
|
+
private:
|
113
|
+
Connection& connection_;
|
114
|
+
uint32_t index_;
|
115
|
+
};
|
116
|
+
|
117
|
+
class Connection
|
118
|
+
{
|
119
|
+
public:
|
120
|
+
Column getColumn(uint32_t index)
|
121
|
+
{
|
122
|
+
return Column(*this, index);
|
123
|
+
}
|
124
|
+
|
125
|
+
std::string getName(uint32_t index)
|
126
|
+
{
|
127
|
+
return this->prefix_ + std::to_string(index);
|
128
|
+
}
|
129
|
+
|
130
|
+
private:
|
131
|
+
std::string prefix_ = "column_";
|
132
|
+
};
|
133
|
+
|
134
|
+
std::string Column::name()
|
135
|
+
{
|
136
|
+
return this->connection_.getName(this->index_);
|
137
|
+
}
|
138
|
+
}
|
139
|
+
|
140
|
+
Object getColumn(Module& m, uint32_t index)
|
141
|
+
{
|
142
|
+
Object connection = m.instance_eval("Connection.new");
|
143
|
+
return connection.call("getColumn", 3);
|
144
|
+
}
|
145
|
+
|
146
|
+
TESTCASE(test_return)
|
147
|
+
{
|
148
|
+
define_class<Column>("Column")
|
149
|
+
.define_method("name", &Column::name);
|
150
|
+
|
151
|
+
define_class<Connection>("Connection")
|
152
|
+
.define_constructor(Constructor<Connection>())
|
153
|
+
.define_method("getColumn", &Connection::getColumn, Return().keepAlive());
|
154
|
+
|
155
|
+
Module m = define_module("TestingModule");
|
156
|
+
|
157
|
+
Object column = getColumn(m, 3);
|
158
|
+
rb_gc_start();
|
159
|
+
String name = column.call("name");
|
160
|
+
ASSERT_EQUAL("column_3", name.c_str());
|
161
|
+
}
|
@@ -1,8 +1,6 @@
|
|
1
1
|
#include "unittest.hpp"
|
2
2
|
#include "embed_ruby.hpp"
|
3
|
-
#include
|
4
|
-
#include "rice/Class.hpp"
|
5
|
-
#include "rice/global_function.hpp"
|
3
|
+
#include <rice/rice.hpp>
|
6
4
|
|
7
5
|
using namespace Rice;
|
8
6
|
|
@@ -47,5 +45,5 @@ TESTCASE(allows_copy_contructors_to_work)
|
|
47
45
|
Module m = define_module("TestingModule");
|
48
46
|
|
49
47
|
Object result = m.instance_eval("return_test_class.tmp");
|
50
|
-
ASSERT_EQUAL(8.0,
|
48
|
+
ASSERT_EQUAL(8.0, detail::From_Ruby<double>().convert(result.value()));
|
51
49
|
}
|
data/test/test_Module.cpp
CHANGED
@@ -1,11 +1,8 @@
|
|
1
1
|
#include "unittest.hpp"
|
2
2
|
#include "embed_ruby.hpp"
|
3
|
-
|
4
|
-
#include
|
5
|
-
#include
|
6
|
-
#include "rice/Arg.hpp"
|
7
|
-
#include "rice/global_function.hpp"
|
8
|
-
#include "rice/Constructor.hpp"
|
3
|
+
|
4
|
+
#include <rice/rice.hpp>
|
5
|
+
#include <rice/stl.hpp>
|
9
6
|
|
10
7
|
using namespace Rice;
|
11
8
|
|
@@ -50,55 +47,73 @@ TESTCASE(add_handler)
|
|
50
47
|
Object exc = m.instance_eval("begin; foo; rescue Exception; $!; end");
|
51
48
|
ASSERT_EQUAL(rb_eRuntimeError, CLASS_OF(exc));
|
52
49
|
Exception ex(exc);
|
53
|
-
ASSERT_EQUAL(String("SILLY"), String(ex.
|
50
|
+
ASSERT_EQUAL(String("SILLY"), String(ex.what()));
|
54
51
|
}
|
55
52
|
|
56
53
|
namespace
|
57
54
|
{
|
58
55
|
|
59
|
-
bool
|
56
|
+
bool some_function()
|
57
|
+
{
|
58
|
+
return true;
|
59
|
+
}
|
60
|
+
|
61
|
+
Object some_method(Object o)
|
62
|
+
{
|
63
|
+
return o;
|
64
|
+
}
|
65
|
+
|
66
|
+
int function_int(int i)
|
67
|
+
{
|
68
|
+
return i;
|
69
|
+
}
|
60
70
|
|
61
|
-
|
71
|
+
int method_int(Object object, int i)
|
62
72
|
{
|
63
|
-
|
73
|
+
return i;
|
64
74
|
}
|
65
75
|
|
66
76
|
} // namespace
|
67
77
|
|
68
|
-
TESTCASE(
|
78
|
+
TESTCASE(define_method)
|
69
79
|
{
|
70
80
|
Module m(anonymous_module());
|
71
|
-
m.define_method("
|
72
|
-
|
73
|
-
Object o = m.instance_eval("o = Object.new
|
74
|
-
|
81
|
+
m.define_method("some_method", some_method);
|
82
|
+
|
83
|
+
Object o = m.instance_eval("$o = Object.new");
|
84
|
+
Object result = m.instance_eval(R"EOS($o.extend(self)
|
85
|
+
$o.some_method)EOS");
|
86
|
+
ASSERT_EQUAL(o, result);
|
75
87
|
}
|
76
88
|
|
77
|
-
TESTCASE(
|
89
|
+
TESTCASE(define_singleton_method)
|
78
90
|
{
|
79
91
|
Module m(anonymous_module());
|
80
|
-
m.define_singleton_method("
|
81
|
-
|
82
|
-
|
83
|
-
ASSERT(define_method_simple_ok);
|
92
|
+
m.define_singleton_method("some_method", some_method);
|
93
|
+
Object result = m.call("some_method");
|
94
|
+
ASSERT_EQUAL(m, result);
|
84
95
|
}
|
85
96
|
|
86
|
-
TESTCASE(
|
97
|
+
TESTCASE(define_module_function)
|
87
98
|
{
|
88
99
|
Module m(anonymous_module());
|
89
|
-
m.define_module_function("
|
90
|
-
|
91
|
-
m.instance_eval("o = Object.new
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
100
|
+
m.define_module_function("some_function", some_function);
|
101
|
+
|
102
|
+
Object result = m.instance_eval(R"EOS(o = Object.new
|
103
|
+
o.extend(self)
|
104
|
+
o.instance_eval do
|
105
|
+
some_function
|
106
|
+
end)EOS");
|
107
|
+
|
108
|
+
ASSERT_EQUAL(Qtrue, result.value());
|
109
|
+
result = m.call("some_function");
|
110
|
+
ASSERT_EQUAL(Qtrue, result.value());
|
96
111
|
}
|
97
112
|
|
98
113
|
TESTCASE(define_module_does_not_leak_method_to_Object)
|
99
114
|
{
|
100
115
|
Module m = define_module("TestModule");
|
101
|
-
m.define_module_function("test_module_function", &
|
116
|
+
m.define_module_function("test_module_function", &some_method);
|
102
117
|
|
103
118
|
Module runner(anonymous_module());
|
104
119
|
ASSERT_EXCEPTION_CHECK(
|
@@ -111,52 +126,53 @@ TESTCASE(define_module_does_not_leak_method_to_Object)
|
|
111
126
|
);
|
112
127
|
}
|
113
128
|
|
114
|
-
|
115
|
-
{
|
116
|
-
|
117
|
-
int define_method_int_result;
|
118
|
-
|
119
|
-
void define_method_int_helper(Object o, int i)
|
129
|
+
TESTCASE(define_function_int)
|
120
130
|
{
|
121
|
-
|
131
|
+
Module m(anonymous_module());
|
132
|
+
m.define_function("foo", function_int);
|
133
|
+
Object result = m.instance_eval("o = Object.new; o.extend(self); o.foo(42)");
|
134
|
+
ASSERT_EQUAL(42, detail::From_Ruby<int>().convert(result));
|
122
135
|
}
|
123
136
|
|
124
|
-
} // namespace
|
125
|
-
|
126
137
|
TESTCASE(define_method_int)
|
127
138
|
{
|
128
139
|
Module m(anonymous_module());
|
129
|
-
m.define_method("foo",
|
130
|
-
|
131
|
-
|
132
|
-
ASSERT_EQUAL(42, define_method_int_result);
|
140
|
+
m.define_method("foo", method_int);
|
141
|
+
Object result = m.instance_eval("o = Object.new; o.extend(self); o.foo(42)");
|
142
|
+
ASSERT_EQUAL(42, detail::From_Ruby<int>().convert(result));
|
133
143
|
}
|
134
144
|
|
135
145
|
TESTCASE(define_singleton_method_int)
|
136
146
|
{
|
137
147
|
Module m(anonymous_module());
|
138
|
-
m.define_singleton_method("foo",
|
139
|
-
|
140
|
-
|
141
|
-
|
148
|
+
m.define_singleton_method("foo", method_int);
|
149
|
+
Object result = m.call("foo", 42);
|
150
|
+
ASSERT_EQUAL(42, detail::From_Ruby<int>().convert(result));
|
151
|
+
}
|
152
|
+
|
153
|
+
TESTCASE(define_singleton_function_int)
|
154
|
+
{
|
155
|
+
Module m(anonymous_module());
|
156
|
+
m.define_singleton_function("foo", function_int);
|
157
|
+
Object result = m.call("foo", 42);
|
158
|
+
ASSERT_EQUAL(42, detail::From_Ruby<int>().convert(result));
|
142
159
|
}
|
143
160
|
|
144
161
|
TESTCASE(define_module_function_int)
|
145
162
|
{
|
146
163
|
Module m(anonymous_module());
|
147
|
-
m.define_module_function("foo",
|
148
|
-
|
149
|
-
|
150
|
-
|
151
|
-
|
152
|
-
|
153
|
-
ASSERT_EQUAL(42, define_method_int_result);
|
164
|
+
m.define_module_function("foo", function_int);
|
165
|
+
Object result = m.instance_eval("o = Object.new; o.extend(self); o.instance_eval { foo(42) }");
|
166
|
+
ASSERT_EQUAL(42, detail::From_Ruby<int>().convert(result));
|
167
|
+
|
168
|
+
result = m.call("foo", 42);
|
169
|
+
ASSERT_EQUAL(42, detail::From_Ruby<int>().convert(result));
|
154
170
|
}
|
155
171
|
|
156
|
-
TESTCASE(
|
172
|
+
TESTCASE(method_int_passed_no_args)
|
157
173
|
{
|
158
174
|
Module m(anonymous_module());
|
159
|
-
m.define_method("foo",
|
175
|
+
m.define_method("foo", method_int);
|
160
176
|
ASSERT_EXCEPTION_CHECK(
|
161
177
|
Exception,
|
162
178
|
m.instance_eval("o = Object.new; o.extend(self); o.foo"),
|
@@ -167,47 +183,14 @@ TESTCASE(define_method_int_passed_no_args)
|
|
167
183
|
);
|
168
184
|
}
|
169
185
|
|
170
|
-
namespace
|
171
|
-
{
|
172
|
-
|
173
|
-
struct Foo
|
174
|
-
{
|
175
|
-
int x;
|
176
|
-
};
|
177
|
-
|
178
|
-
int define_method_int_foo_result_i;
|
179
|
-
Foo * define_method_int_foo_result_x;
|
180
|
-
|
181
|
-
void define_method_int_foo_helper(Object o, int i, Foo * x)
|
182
|
-
{
|
183
|
-
define_method_int_foo_result_i = i;
|
184
|
-
define_method_int_foo_result_x = x;
|
185
|
-
}
|
186
|
-
|
187
|
-
} // namespace
|
188
|
-
|
189
|
-
template<>
|
190
|
-
Foo * from_ruby<Foo *>(Object x)
|
191
|
-
{
|
192
|
-
Foo * retval;
|
193
|
-
Data_Get_Struct(x.value(), Foo, retval);
|
194
|
-
return retval;
|
195
|
-
}
|
196
|
-
|
197
186
|
TESTCASE(define_singleton_method_int_foo)
|
198
187
|
{
|
199
188
|
Module m(anonymous_module());
|
200
|
-
m.define_singleton_method("
|
201
|
-
define_method_int_result = 0;
|
202
|
-
Foo * foo = new Foo;
|
203
|
-
foo->x = 1024;
|
204
|
-
VALUE f = Data_Wrap_Struct(rb_cObject, 0, Default_Free_Function<Foo>::free, foo);
|
205
|
-
m.call("int_and_foo", 42, Object(f));
|
206
|
-
ASSERT_EQUAL(42, define_method_int_foo_result_i);
|
207
|
-
ASSERT_EQUAL(foo, define_method_int_foo_result_x);
|
208
|
-
}
|
189
|
+
m.define_singleton_method("method_int", method_int);
|
209
190
|
|
210
|
-
|
191
|
+
Object result = m.call("method_int", 42);
|
192
|
+
ASSERT_EQUAL(42, detail::From_Ruby<int>().convert(result));
|
193
|
+
}
|
211
194
|
|
212
195
|
TESTCASE(include_module)
|
213
196
|
{
|
@@ -224,7 +207,7 @@ TESTCASE(include_module)
|
|
224
207
|
TESTCASE(const_set_get_by_id)
|
225
208
|
{
|
226
209
|
Module m(anonymous_module());
|
227
|
-
Object v = to_ruby(42);
|
210
|
+
Object v = detail::to_ruby(42);
|
228
211
|
Module & m2(m.const_set(rb_intern("FOO"), v));
|
229
212
|
ASSERT_EQUAL(&m, &m2);
|
230
213
|
ASSERT_EQUAL(v, m.const_get(rb_intern("FOO")));
|
@@ -233,7 +216,7 @@ TESTCASE(const_set_get_by_id)
|
|
233
216
|
TESTCASE(const_set_get_by_identifier)
|
234
217
|
{
|
235
218
|
Module m(anonymous_module());
|
236
|
-
Object v = to_ruby(42);
|
219
|
+
Object v = detail::to_ruby(42);
|
237
220
|
Module & m2(m.const_set(Identifier("FOO"), v));
|
238
221
|
ASSERT_EQUAL(&m, &m2);
|
239
222
|
ASSERT_EQUAL(v, m.const_get(Identifier("FOO")));
|
@@ -242,7 +225,7 @@ TESTCASE(const_set_get_by_identifier)
|
|
242
225
|
TESTCASE(const_set_get_by_string)
|
243
226
|
{
|
244
227
|
Module m(anonymous_module());
|
245
|
-
Object v = to_ruby(42);
|
228
|
+
Object v = detail::to_ruby(42);
|
246
229
|
Module & m2(m.const_set("FOO", v));
|
247
230
|
ASSERT_EQUAL(&m, &m2);
|
248
231
|
ASSERT_EQUAL(v, m.const_get("FOO"));
|
@@ -251,7 +234,7 @@ TESTCASE(const_set_get_by_string)
|
|
251
234
|
TESTCASE(remove_const)
|
252
235
|
{
|
253
236
|
Module m(anonymous_module());
|
254
|
-
Object v = to_ruby(42);
|
237
|
+
Object v = detail::to_ruby(42);
|
255
238
|
m.const_set("FOO", v);
|
256
239
|
ASSERT_EQUAL(v, m.const_get("FOO"));
|
257
240
|
m.remove_const("FOO");
|
@@ -271,9 +254,7 @@ TESTCASE(mod_name_anonymous)
|
|
271
254
|
ASSERT_EQUAL(String(""), m.name());
|
272
255
|
}
|
273
256
|
|
274
|
-
|
275
|
-
* Tests for default arguments
|
276
|
-
*/
|
257
|
+
// Tests for default arguments
|
277
258
|
namespace
|
278
259
|
{
|
279
260
|
int defaults_method_one_arg1;
|
@@ -291,7 +272,7 @@ namespace
|
|
291
272
|
TESTCASE(define_method_default_arguments)
|
292
273
|
{
|
293
274
|
Module m(anonymous_module());
|
294
|
-
m.
|
275
|
+
m.define_function("foo", &defaults_method_one, Arg("arg1"), Arg("arg2") = 3, Arg("arg3") = true);
|
295
276
|
|
296
277
|
Object o = m.instance_eval("o = Object.new; o.extend(self); o");
|
297
278
|
o.call("foo", 2);
|
@@ -316,7 +297,7 @@ TESTCASE(define_method_default_arguments)
|
|
316
297
|
TESTCASE(default_arguments_still_throws_argument_error)
|
317
298
|
{
|
318
299
|
Module m(anonymous_module());
|
319
|
-
m.
|
300
|
+
m.define_function("foo", &defaults_method_one, Arg("arg1"), Arg("arg2") = 3, Arg("arg3") = true);
|
320
301
|
|
321
302
|
ASSERT_EXCEPTION_CHECK(
|
322
303
|
Exception,
|
@@ -348,7 +329,7 @@ TESTCASE(defining_methods_with_single_default_argument)
|
|
348
329
|
{
|
349
330
|
// define_method
|
350
331
|
Module m(anonymous_module());
|
351
|
-
m.
|
332
|
+
m.define_function("foo", &method_with_one_default_arg, (Arg("num") = 4));
|
352
333
|
m.instance_eval("o = Object.new; o.extend(self); o.foo()");
|
353
334
|
ASSERT_EQUAL(4, the_one_default_arg);
|
354
335
|
|
@@ -356,7 +337,7 @@ TESTCASE(defining_methods_with_single_default_argument)
|
|
356
337
|
|
357
338
|
// define_singleton_method
|
358
339
|
Class c(anonymous_class());
|
359
|
-
c.
|
340
|
+
c.define_singleton_function("foo", &method_with_one_default_arg, (Arg("num") = 4));
|
360
341
|
c.call("foo");
|
361
342
|
ASSERT_EQUAL(4, the_one_default_arg);
|
362
343
|
|
@@ -372,7 +353,7 @@ TESTCASE(defining_methods_with_single_default_argument)
|
|
372
353
|
TESTCASE(default_arguments_for_define_singleton_method)
|
373
354
|
{
|
374
355
|
Class c(anonymous_class());
|
375
|
-
c.
|
356
|
+
c.define_singleton_function("foo", &defaults_method_one, Arg("arg1"), Arg("arg2") = 3, Arg("arg3") = true);
|
376
357
|
|
377
358
|
c.call("foo", 2);
|
378
359
|
|
@@ -396,7 +377,7 @@ TESTCASE(default_arguments_for_define_singleton_method)
|
|
396
377
|
TESTCASE(default_arguments_for_define_module_function)
|
397
378
|
{
|
398
379
|
Module m(anonymous_module());
|
399
|
-
m.define_module_function("foo", &defaults_method_one,
|
380
|
+
m.define_module_function("foo", &defaults_method_one, Arg("arg1"), Arg("arg2") = 3, Arg("arg3") = true);
|
400
381
|
|
401
382
|
m.call("foo", 2);
|
402
383
|
|
@@ -432,7 +413,7 @@ TESTCASE(define_method_works_with_reference_arguments)
|
|
432
413
|
{
|
433
414
|
Module m(anonymous_module());
|
434
415
|
m.define_module_function("foo", &with_defaults_and_references,
|
435
|
-
|
416
|
+
Arg("x"), Arg("doIt") = false);
|
436
417
|
|
437
418
|
m.call("foo", "test");
|
438
419
|
|
@@ -472,8 +453,8 @@ TESTCASE(define_method_works_with_const_reference_return)
|
|
472
453
|
ASSERT_EQUAL("ReturnTest", result.class_of().name().c_str());
|
473
454
|
}
|
474
455
|
|
475
|
-
|
476
|
-
|
456
|
+
namespace
|
457
|
+
{
|
477
458
|
float with_reference_defaults_x;
|
478
459
|
std::string with_reference_defaults_str;
|
479
460
|
|
@@ -488,11 +469,87 @@ TESTCASE(define_method_works_with_reference_const_default_values)
|
|
488
469
|
{
|
489
470
|
Module m(anonymous_module());
|
490
471
|
m.define_module_function("bar", &with_reference_defaults,
|
491
|
-
|
472
|
+
Arg("x"), Arg("str") = std::string("testing"));
|
492
473
|
|
493
474
|
m.call("bar", 3);
|
494
475
|
|
495
476
|
ASSERT_EQUAL(3, with_reference_defaults_x);
|
496
477
|
ASSERT_EQUAL("testing", with_reference_defaults_str);
|
497
478
|
}
|
498
|
-
|
479
|
+
|
480
|
+
namespace
|
481
|
+
{
|
482
|
+
int with_pointers_x;
|
483
|
+
std::string with_pointers_str;
|
484
|
+
|
485
|
+
void with_pointers(int* x, std::string const* str)
|
486
|
+
{
|
487
|
+
with_pointers_x = *x;
|
488
|
+
with_pointers_str = *str;
|
489
|
+
}
|
490
|
+
}
|
491
|
+
|
492
|
+
TESTCASE(define_method_works_with_pointers)
|
493
|
+
{
|
494
|
+
Module m(anonymous_module());
|
495
|
+
m.define_module_function("bar", &with_pointers);
|
496
|
+
|
497
|
+
m.call("bar", 3, "testing");
|
498
|
+
|
499
|
+
ASSERT_EQUAL(3, with_pointers_x);
|
500
|
+
ASSERT_EQUAL("testing", with_pointers_str);
|
501
|
+
}
|
502
|
+
|
503
|
+
namespace
|
504
|
+
{
|
505
|
+
int intValue;
|
506
|
+
bool boolValue;
|
507
|
+
float floatValue;
|
508
|
+
double doubleValue;
|
509
|
+
|
510
|
+
void withPointers(const int* anInt, const bool* aBool, const float* aFloat, const double* aDouble)
|
511
|
+
{
|
512
|
+
intValue = *anInt;
|
513
|
+
boolValue = *aBool;
|
514
|
+
floatValue = *aFloat;
|
515
|
+
doubleValue = *aDouble;
|
516
|
+
}
|
517
|
+
|
518
|
+
void withReferences(const int& anInt, const bool& aBool, const float& aFloat, const double& aDouble)
|
519
|
+
{
|
520
|
+
intValue = anInt;
|
521
|
+
boolValue = aBool;
|
522
|
+
floatValue = aFloat;
|
523
|
+
doubleValue = aDouble;
|
524
|
+
}
|
525
|
+
}
|
526
|
+
|
527
|
+
TESTCASE(pointers)
|
528
|
+
{
|
529
|
+
define_global_function("with_pointers", &withPointers);
|
530
|
+
|
531
|
+
Module m = define_module("TestingModule");
|
532
|
+
|
533
|
+
std::string code = "with_pointers(32, true, 33.0, 34.0)";
|
534
|
+
m.instance_eval(code);
|
535
|
+
|
536
|
+
ASSERT_EQUAL(intValue, 32);
|
537
|
+
ASSERT_EQUAL(boolValue, true);
|
538
|
+
ASSERT_EQUAL(floatValue, 33.0);
|
539
|
+
ASSERT_EQUAL(doubleValue, 34.0);
|
540
|
+
}
|
541
|
+
|
542
|
+
TESTCASE(references)
|
543
|
+
{
|
544
|
+
define_global_function("with_references", &withReferences);
|
545
|
+
|
546
|
+
Module m = define_module("TestingModule");
|
547
|
+
|
548
|
+
std::string code = "with_references(42, true, 43.0, 44.0)";
|
549
|
+
m.instance_eval(code);
|
550
|
+
|
551
|
+
ASSERT_EQUAL(intValue, 42);
|
552
|
+
ASSERT_EQUAL(boolValue, true);
|
553
|
+
ASSERT_EQUAL(floatValue, 43.0);
|
554
|
+
ASSERT_EQUAL(doubleValue, 44.0);
|
555
|
+
}
|