Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
P
protobuf
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
protobuf
Commits
3bdaaa5d
Commit
3bdaaa5d
authored
Nov 03, 2016
by
Marcin Wyszynski
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
More Ruby-eqsue interface
parent
93a4fa23
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
54 additions
and
0 deletions
+54
-0
message.c
ruby/ext/google/protobuf_c/message.c
+44
-0
basic.rb
ruby/tests/basic.rb
+10
-0
No files found.
ruby/ext/google/protobuf_c/message.c
View file @
3bdaaa5d
...
...
@@ -178,6 +178,45 @@ VALUE Message_method_missing(int argc, VALUE* argv, VALUE _self) {
}
}
VALUE
Message_respond_to_missing
(
int
argc
,
VALUE
*
argv
,
VALUE
_self
)
{
MessageHeader
*
self
;
VALUE
method_name
,
method_str
;
char
*
name
;
size_t
name_len
;
bool
setter
;
const
upb_oneofdef
*
o
;
const
upb_fielddef
*
f
;
TypedData_Get_Struct
(
_self
,
MessageHeader
,
&
Message_type
,
self
);
if
(
argc
<
1
)
{
rb_raise
(
rb_eArgError
,
"Expected method name as first argument."
);
}
method_name
=
argv
[
0
];
if
(
!
SYMBOL_P
(
method_name
))
{
rb_raise
(
rb_eArgError
,
"Expected symbol as method name."
);
}
method_str
=
rb_id2str
(
SYM2ID
(
method_name
));
name
=
RSTRING_PTR
(
method_str
);
name_len
=
RSTRING_LEN
(
method_str
);
setter
=
false
;
// Setters have names that end in '='.
if
(
name
[
name_len
-
1
]
==
'='
)
{
setter
=
true
;
name_len
--
;
}
// See if this name corresponds to either a oneof or field in this message.
if
(
!
upb_msgdef_lookupname
(
self
->
descriptor
->
msgdef
,
name
,
name_len
,
&
f
,
&
o
))
{
return
rb_call_super
(
argc
,
argv
);
}
if
(
o
!=
NULL
)
{
return
setter
?
Qfalse
:
Qtrue
;
}
return
Qtrue
;
}
int
Message_initialize_kwarg
(
VALUE
key
,
VALUE
val
,
VALUE
_self
)
{
MessageHeader
*
self
;
VALUE
method_str
;
...
...
@@ -303,6 +342,9 @@ VALUE Message_deep_copy(VALUE _self) {
* field is of a primitive type).
*/
VALUE
Message_eq
(
VALUE
_self
,
VALUE
_other
)
{
if
(
TYPE
(
_self
)
!=
TYPE
(
_other
))
{
return
Qfalse
;
}
MessageHeader
*
self
;
MessageHeader
*
other
;
TypedData_Get_Struct
(
_self
,
MessageHeader
,
&
Message_type
,
self
);
...
...
@@ -459,6 +501,8 @@ VALUE build_class_from_descriptor(Descriptor* desc) {
rb_define_method
(
klass
,
"method_missing"
,
Message_method_missing
,
-
1
);
rb_define_method
(
klass
,
"respond_to_missing?"
,
Message_respond_to_missing
,
-
1
);
rb_define_method
(
klass
,
"initialize"
,
Message_initialize
,
-
1
);
rb_define_method
(
klass
,
"dup"
,
Message_dup
,
0
);
// Also define #clone so that we don't inherit Object#clone.
...
...
ruby/tests/basic.rb
View file @
3bdaaa5d
...
...
@@ -1181,5 +1181,15 @@ module BasicTest
m2
=
MapMessage
.
decode_json
(
MapMessage
.
encode_json
(
m
))
assert
m
==
m2
end
def
test_comparison_with_arbitrary_object
assert_false
MapMessage
.
new
==
nil
end
def
test_respond_to
msg
=
MapMessage
.
new
assert
msg
.
respond_to?
(
:map_string_int32
)
assert_false
msg
.
respond_to?
(
:map_string_int32
)
end
end
end
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment