Commit c1ba7c64 authored by Alan Wu's avatar Alan Wu

Remove unused argument to avoid UB

`OneOfDescriptor_each` is registered as a Ruby method which takes zero
parameters, which means it should take one argument.

When Ruby invokes `OneOfDescriptor_each`, it calls it with one parameter
only, which is one less than what `OneOfDescriptor_each` takes before
this commit. Calling a function with the wrong number of argument is
technically undefined behavior.

See also: §6.5.2.2, N1256
parent d8e678aa
...@@ -1232,7 +1232,7 @@ VALUE OneofDescriptor_name(VALUE _self) { ...@@ -1232,7 +1232,7 @@ VALUE OneofDescriptor_name(VALUE _self) {
* *
* Iterates through fields in this oneof, yielding to the block on each one. * Iterates through fields in this oneof, yielding to the block on each one.
*/ */
VALUE OneofDescriptor_each(VALUE _self, VALUE field) { VALUE OneofDescriptor_each(VALUE _self) {
DEFINE_SELF(OneofDescriptor, self, _self); DEFINE_SELF(OneofDescriptor, self, _self);
upb_oneof_iter it; upb_oneof_iter it;
for (upb_oneof_begin(&it, self->oneofdef); for (upb_oneof_begin(&it, self->oneofdef);
......
...@@ -259,7 +259,7 @@ OneofDescriptor* ruby_to_OneofDescriptor(VALUE value); ...@@ -259,7 +259,7 @@ OneofDescriptor* ruby_to_OneofDescriptor(VALUE value);
VALUE OneofDescriptor_initialize(VALUE _self, VALUE cookie, VALUE OneofDescriptor_initialize(VALUE _self, VALUE cookie,
VALUE descriptor_pool, VALUE ptr); VALUE descriptor_pool, VALUE ptr);
VALUE OneofDescriptor_name(VALUE _self); VALUE OneofDescriptor_name(VALUE _self);
VALUE OneofDescriptor_each(VALUE _self, VALUE field); VALUE OneofDescriptor_each(VALUE _self);
void EnumDescriptor_mark(void* _self); void EnumDescriptor_mark(void* _self);
void EnumDescriptor_free(void* _self); void EnumDescriptor_free(void* _self);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment