Update upb, fixes some bugs (including a hash table problem). (#2611)
* Update upb, fixes some bugs (including a hash table problem). * Ruby: added a test for the previous hash table corruption. Verified that this triggers the bug in the currently released version. * Ruby: bugfix for SEGV. * Ruby: removed old code for dup'ing defs.
This commit is contained in:
parent
be83f46b67
commit
d9668797a2
5 changed files with 2811 additions and 1382 deletions
|
@ -101,7 +101,7 @@ void DescriptorPool_mark(void* _self) {
|
|||
|
||||
void DescriptorPool_free(void* _self) {
|
||||
DescriptorPool* self = _self;
|
||||
upb_symtab_unref(self->symtab, &self->symtab);
|
||||
upb_symtab_free(self->symtab);
|
||||
xfree(self);
|
||||
}
|
||||
|
||||
|
@ -113,7 +113,7 @@ void DescriptorPool_free(void* _self) {
|
|||
*/
|
||||
VALUE DescriptorPool_alloc(VALUE klass) {
|
||||
DescriptorPool* self = ALLOC(DescriptorPool);
|
||||
self->symtab = upb_symtab_new(&self->symtab);
|
||||
self->symtab = upb_symtab_new();
|
||||
return TypedData_Wrap_Struct(klass, &_DescriptorPool_type, self);
|
||||
}
|
||||
|
||||
|
|
|
@ -514,7 +514,7 @@ static void add_handlers_for_singular_field(upb_handlers *h,
|
|||
case UPB_TYPE_INT64:
|
||||
case UPB_TYPE_UINT64:
|
||||
case UPB_TYPE_DOUBLE:
|
||||
upb_shim_set(h, f, offset, -1);
|
||||
upb_msg_setscalarhandler(h, f, offset, -1);
|
||||
break;
|
||||
case UPB_TYPE_STRING:
|
||||
case UPB_TYPE_BYTES: {
|
||||
|
@ -925,7 +925,7 @@ static void putmsg(VALUE msg, const Descriptor* desc,
|
|||
static upb_selector_t getsel(const upb_fielddef *f, upb_handlertype_t type) {
|
||||
upb_selector_t ret;
|
||||
bool ok = upb_handlers_getselector(f, type, &ret);
|
||||
UPB_ASSERT_VAR(ok, ok);
|
||||
UPB_ASSERT(ok);
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
@ -939,9 +939,9 @@ static void putstr(VALUE str, const upb_fielddef *f, upb_sink *sink) {
|
|||
// We should be guaranteed that the string has the correct encoding because
|
||||
// we ensured this at assignment time and then froze the string.
|
||||
if (upb_fielddef_type(f) == UPB_TYPE_STRING) {
|
||||
assert(rb_enc_from_index(ENCODING_GET(value)) == kRubyStringUtf8Encoding);
|
||||
assert(rb_enc_from_index(ENCODING_GET(str)) == kRubyStringUtf8Encoding);
|
||||
} else {
|
||||
assert(rb_enc_from_index(ENCODING_GET(value)) == kRubyString8bitEncoding);
|
||||
assert(rb_enc_from_index(ENCODING_GET(str)) == kRubyString8bitEncoding);
|
||||
}
|
||||
|
||||
upb_sink_startstr(sink, getsel(f, UPB_HANDLER_STARTSTR), RSTRING_LEN(str),
|
||||
|
|
File diff suppressed because it is too large
Load diff
File diff suppressed because it is too large
Load diff
|
@ -667,6 +667,13 @@ module BasicTest
|
|||
end
|
||||
end
|
||||
|
||||
def test_map_corruption
|
||||
# This pattern led to a crash in a previous version of upb/protobuf.
|
||||
m = MapMessage.new(map_string_int32: { "aaa" => 1 })
|
||||
m.map_string_int32['podid'] = 2
|
||||
m.map_string_int32['aaa'] = 3
|
||||
end
|
||||
|
||||
def test_map_encode_decode
|
||||
m = MapMessage.new(
|
||||
:map_string_int32 => {"a" => 1, "b" => 2},
|
||||
|
|
Loading…
Add table
Reference in a new issue