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
e7e79a43
Commit
e7e79a43
authored
Feb 03, 2015
by
Chris Fallin
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #190 from isaiah/to_ary
add #to_ary to RepeatedField
parents
a22bc812
ee5f6e9a
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
30 additions
and
32 deletions
+30
-32
repeated_field.c
ruby/ext/google/protobuf_c/repeated_field.c
+28
-31
basic.rb
ruby/tests/basic.rb
+2
-1
No files found.
ruby/ext/google/protobuf_c/repeated_field.c
View file @
e7e79a43
...
@@ -316,6 +316,29 @@ VALUE RepeatedField_deep_copy(VALUE _self) {
...
@@ -316,6 +316,29 @@ VALUE RepeatedField_deep_copy(VALUE _self) {
return
new_rptfield
;
return
new_rptfield
;
}
}
/*
* call-seq:
* RepeatedField.to_ary => array
*
* Used when converted implicitly into array, e.g. compared to an Array.
* Also called as a fallback of Object#to_a
*/
VALUE
RepeatedField_to_ary
(
VALUE
_self
)
{
RepeatedField
*
self
=
ruby_to_RepeatedField
(
_self
);
upb_fieldtype_t
field_type
=
self
->
field_type
;
size_t
elem_size
=
native_slot_size
(
field_type
);
size_t
off
=
0
;
VALUE
ary
=
rb_ary_new2
(
self
->
size
);
for
(
int
i
=
0
;
i
<
self
->
size
;
i
++
,
off
+=
elem_size
)
{
void
*
mem
=
((
uint8_t
*
)
self
->
elements
)
+
off
;
VALUE
elem
=
native_slot_get
(
field_type
,
self
->
field_type_class
,
mem
);
rb_ary_push
(
ary
,
elem
);
}
return
ary
;
}
/*
/*
* call-seq:
* call-seq:
* RepeatedField.==(other) => boolean
* RepeatedField.==(other) => boolean
...
@@ -335,15 +358,9 @@ VALUE RepeatedField_eq(VALUE _self, VALUE _other) {
...
@@ -335,15 +358,9 @@ VALUE RepeatedField_eq(VALUE _self, VALUE _other) {
}
}
RepeatedField
*
self
=
ruby_to_RepeatedField
(
_self
);
RepeatedField
*
self
=
ruby_to_RepeatedField
(
_self
);
// Inefficient but workable: to support comparison to a generic array, we
// build a temporary RepeatedField of our type.
if
(
TYPE
(
_other
)
==
T_ARRAY
)
{
if
(
TYPE
(
_other
)
==
T_ARRAY
)
{
VALUE
new_rptfield
=
RepeatedField_new_this_type
(
_self
);
VALUE
self_ary
=
RepeatedField_to_ary
(
_self
);
for
(
int
i
=
0
;
i
<
RARRAY_LEN
(
_other
);
i
++
)
{
return
rb_equal
(
self_ary
,
_other
);
VALUE
elem
=
rb_ary_entry
(
_other
,
i
);
RepeatedField_push
(
new_rptfield
,
elem
);
}
_other
=
new_rptfield
;
}
}
RepeatedField
*
other
=
ruby_to_RepeatedField
(
_other
);
RepeatedField
*
other
=
ruby_to_RepeatedField
(
_other
);
...
@@ -401,29 +418,8 @@ VALUE RepeatedField_hash(VALUE _self) {
...
@@ -401,29 +418,8 @@ VALUE RepeatedField_hash(VALUE _self) {
* representation computed by its own #inspect method.
* representation computed by its own #inspect method.
*/
*/
VALUE
RepeatedField_inspect
(
VALUE
_self
)
{
VALUE
RepeatedField_inspect
(
VALUE
_self
)
{
RepeatedField
*
self
=
ruby_to_RepeatedField
(
_self
);
VALUE
self_ary
=
RepeatedField_to_ary
(
_self
);
return
rb_funcall
(
self_ary
,
rb_intern
(
"inspect"
),
0
);
VALUE
str
=
rb_str_new2
(
"["
);
bool
first
=
true
;
upb_fieldtype_t
field_type
=
self
->
field_type
;
VALUE
field_type_class
=
self
->
field_type_class
;
size_t
elem_size
=
native_slot_size
(
field_type
);
size_t
off
=
0
;
for
(
int
i
=
0
;
i
<
self
->
size
;
i
++
,
off
+=
elem_size
)
{
void
*
mem
=
((
uint8_t
*
)
self
->
elements
)
+
off
;
VALUE
elem
=
native_slot_get
(
field_type
,
field_type_class
,
mem
);
if
(
!
first
)
{
str
=
rb_str_cat2
(
str
,
", "
);
}
else
{
first
=
false
;
}
str
=
rb_str_append
(
str
,
rb_funcall
(
elem
,
rb_intern
(
"inspect"
),
0
));
}
str
=
rb_str_cat2
(
str
,
"]"
);
return
str
;
}
}
/*
/*
...
@@ -594,6 +590,7 @@ void RepeatedField_register(VALUE module) {
...
@@ -594,6 +590,7 @@ void RepeatedField_register(VALUE module) {
// Also define #clone so that we don't inherit Object#clone.
// Also define #clone so that we don't inherit Object#clone.
rb_define_method
(
klass
,
"clone"
,
RepeatedField_dup
,
0
);
rb_define_method
(
klass
,
"clone"
,
RepeatedField_dup
,
0
);
rb_define_method
(
klass
,
"=="
,
RepeatedField_eq
,
1
);
rb_define_method
(
klass
,
"=="
,
RepeatedField_eq
,
1
);
rb_define_method
(
klass
,
"to_ary"
,
RepeatedField_to_ary
,
0
);
rb_define_method
(
klass
,
"hash"
,
RepeatedField_hash
,
0
);
rb_define_method
(
klass
,
"hash"
,
RepeatedField_hash
,
0
);
rb_define_method
(
klass
,
"inspect"
,
RepeatedField_inspect
,
0
);
rb_define_method
(
klass
,
"inspect"
,
RepeatedField_inspect
,
0
);
rb_define_method
(
klass
,
"+"
,
RepeatedField_plus
,
1
);
rb_define_method
(
klass
,
"+"
,
RepeatedField_plus
,
1
);
...
...
ruby/tests/basic.rb
View file @
e7e79a43
...
@@ -236,7 +236,8 @@ module BasicTest
...
@@ -236,7 +236,8 @@ module BasicTest
assert
l
.
count
==
0
assert
l
.
count
==
0
l
=
Google
::
Protobuf
::
RepeatedField
.
new
(
:int32
,
[
1
,
2
,
3
])
l
=
Google
::
Protobuf
::
RepeatedField
.
new
(
:int32
,
[
1
,
2
,
3
])
assert
l
.
count
==
3
assert
l
.
count
==
3
assert
l
==
[
1
,
2
,
3
]
assert_equal
[
1
,
2
,
3
],
l
assert_equal
l
,
[
1
,
2
,
3
]
l
.
push
4
l
.
push
4
assert
l
==
[
1
,
2
,
3
,
4
]
assert
l
==
[
1
,
2
,
3
,
4
]
dst_list
=
[]
dst_list
=
[]
...
...
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