google-protobuf 3.25.5-x86-linux → 4.30.1-x86-linux

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (68) hide show
  1. checksums.yaml +4 -4
  2. data/ext/google/protobuf_c/convert.c +39 -18
  3. data/ext/google/protobuf_c/defs.c +529 -32
  4. data/ext/google/protobuf_c/extconf.rb +13 -1
  5. data/ext/google/protobuf_c/glue.c +79 -0
  6. data/ext/google/protobuf_c/map.c +74 -29
  7. data/ext/google/protobuf_c/map.h +7 -3
  8. data/ext/google/protobuf_c/message.c +119 -119
  9. data/ext/google/protobuf_c/message.h +2 -6
  10. data/ext/google/protobuf_c/protobuf.c +32 -18
  11. data/ext/google/protobuf_c/protobuf.h +3 -7
  12. data/ext/google/protobuf_c/repeated_field.c +58 -23
  13. data/ext/google/protobuf_c/repeated_field.h +6 -2
  14. data/ext/google/protobuf_c/ruby-upb.c +14931 -11575
  15. data/ext/google/protobuf_c/ruby-upb.h +8701 -5832
  16. data/ext/google/protobuf_c/shared_convert.c +10 -5
  17. data/ext/google/protobuf_c/shared_convert.h +2 -2
  18. data/ext/google/protobuf_c/shared_message.c +3 -31
  19. data/ext/google/protobuf_c/shared_message.h +0 -4
  20. data/ext/google/protobuf_c/third_party/utf8_range/utf8_range.c +207 -0
  21. data/ext/google/protobuf_c/third_party/utf8_range/utf8_range.h +9 -8
  22. data/ext/google/protobuf_c/third_party/utf8_range/utf8_range_neon.inc +117 -0
  23. data/ext/google/protobuf_c/third_party/utf8_range/utf8_range_sse.inc +272 -0
  24. data/lib/google/3.0/protobuf_c.so +0 -0
  25. data/lib/google/3.1/protobuf_c.so +0 -0
  26. data/lib/google/3.2/protobuf_c.so +0 -0
  27. data/lib/google/3.3/protobuf_c.so +0 -0
  28. data/lib/google/3.4/protobuf_c.so +0 -0
  29. data/lib/google/protobuf/any_pb.rb +1 -22
  30. data/lib/google/protobuf/api_pb.rb +1 -24
  31. data/lib/google/protobuf/descriptor_pb.rb +4 -23
  32. data/lib/google/protobuf/duration_pb.rb +1 -22
  33. data/lib/google/protobuf/empty_pb.rb +1 -22
  34. data/lib/google/protobuf/ffi/descriptor.rb +14 -4
  35. data/lib/google/protobuf/ffi/descriptor_pool.rb +3 -1
  36. data/lib/google/protobuf/ffi/enum_descriptor.rb +13 -1
  37. data/lib/google/protobuf/ffi/ffi.rb +7 -6
  38. data/lib/google/protobuf/ffi/field_descriptor.rb +23 -2
  39. data/lib/google/protobuf/ffi/file_descriptor.rb +13 -13
  40. data/lib/google/protobuf/ffi/internal/arena.rb +0 -6
  41. data/lib/google/protobuf/ffi/internal/convert.rb +17 -30
  42. data/lib/google/protobuf/ffi/map.rb +50 -24
  43. data/lib/google/protobuf/ffi/message.rb +188 -67
  44. data/lib/google/protobuf/ffi/method_descriptor.rb +124 -0
  45. data/lib/google/protobuf/ffi/object_cache.rb +3 -3
  46. data/lib/google/protobuf/ffi/oneof_descriptor.rb +13 -1
  47. data/lib/google/protobuf/ffi/repeated_field.rb +47 -19
  48. data/lib/google/protobuf/ffi/service_descriptor.rb +117 -0
  49. data/lib/google/protobuf/field_mask_pb.rb +1 -22
  50. data/lib/google/protobuf/internal/object_cache.rb +99 -0
  51. data/lib/google/protobuf/plugin_pb.rb +2 -24
  52. data/lib/google/protobuf/repeated_field.rb +4 -5
  53. data/lib/google/protobuf/source_context_pb.rb +1 -22
  54. data/lib/google/protobuf/struct_pb.rb +1 -22
  55. data/lib/google/protobuf/timestamp_pb.rb +1 -22
  56. data/lib/google/protobuf/type_pb.rb +1 -24
  57. data/lib/google/protobuf/wrappers_pb.rb +1 -22
  58. data/lib/google/protobuf.rb +1 -1
  59. data/lib/google/protobuf_ffi.rb +5 -3
  60. data/lib/google/protobuf_native.rb +0 -1
  61. data/lib/google/tasks/ffi.rake +1 -3
  62. metadata +30 -15
  63. data/ext/google/protobuf_c/third_party/utf8_range/naive.c +0 -92
  64. data/ext/google/protobuf_c/third_party/utf8_range/range2-neon.c +0 -157
  65. data/ext/google/protobuf_c/third_party/utf8_range/range2-sse.c +0 -170
  66. data/lib/google/2.7/protobuf_c.so +0 -0
  67. data/lib/google/protobuf/descriptor_dsl.rb +0 -465
  68. data/lib/google/protobuf/object_cache.rb +0 -97
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 2ac081ad3cea69498cc62542d51bee76920e378824d78009f315ce7af6be9923
4
- data.tar.gz: 840ab046c1c67627268dd6bf56b2cd5be4aa7f80b4d66546181cf9f0ac97f9ab
3
+ metadata.gz: d70b855e5f014346753b8c1099de4fa51730585e0e14c6f679eb4978eca30c08
4
+ data.tar.gz: b89b86bef6be620f483baf19a90f42dafd3d7b40b407f00ac5eedc8fd8d56ed7
5
5
  SHA512:
6
- metadata.gz: b64fea6efa5c3a3ea446adbeb213aa6d47881867f65b63a54f6c277240c15074441db7c353078c51e5d47047fc1b0947bd8260c89865bfe397a7cd4ba66935d7
7
- data.tar.gz: 8ab8790db6d588c5b9d0a9166fe99153c80db0d1ce23e3fe641c834507ec58d224ebb62655ff2383939b6d0759fbae314287c93bdc4ef307ecb8b7ca1455bd60
6
+ metadata.gz: a75f305818c7a9bd55b13a27f909cee5f46694fed8d21a4e9a60ceb6e817a6bbdc17630e37e377ae3295d44d7adc61badc9f469b076e55cfd850a38b54100114
7
+ data.tar.gz: feffdc40d0bcec0328980fa558162d2fc9f8adccd18a9105999254036e6122f75b21646a543627a5abc4bdad9d0c7437f403b2530c66c604fcea04779ee28df0
@@ -104,6 +104,34 @@ unknownval:
104
104
  rb_raise(rb_eRangeError, "Unknown symbol value for enum field '%s'.", name);
105
105
  }
106
106
 
107
+ VALUE Convert_CheckStringUtf8(VALUE str) {
108
+ VALUE utf8 = rb_enc_from_encoding(rb_utf8_encoding());
109
+
110
+ if (rb_obj_encoding(str) == utf8) {
111
+ // Note: Just because a string is marked as having UTF-8 encoding does
112
+ // not mean that it is *valid* UTF-8. We have to check separately
113
+ // whether it is valid.
114
+ if (rb_enc_str_coderange(str) == ENC_CODERANGE_BROKEN) {
115
+ VALUE exc = rb_const_get_at(
116
+ rb_cEncoding, rb_intern("InvalidByteSequenceError"));
117
+ rb_raise(exc, "String is invalid UTF-8");
118
+ }
119
+ } else {
120
+ // Note: this will not duplicate underlying string data unless
121
+ // necessary.
122
+ //
123
+ // This will throw an exception if the conversion cannot be performed:
124
+ // - Encoding::UndefinedConversionError if certain characters cannot be
125
+ // converted to UTF-8.
126
+ // - Encoding::InvalidByteSequenceError if certain characters were invalid
127
+ // in the source encoding.
128
+ str = rb_str_encode(str, utf8, 0, Qnil);
129
+ PBRUBY_ASSERT(rb_enc_str_coderange(str) != ENC_CODERANGE_BROKEN);
130
+ }
131
+
132
+ return str;
133
+ }
134
+
107
135
  upb_MessageValue Convert_RubyToUpb(VALUE value, const char* name,
108
136
  TypeInfo type_info, upb_Arena* arena) {
109
137
  upb_MessageValue ret;
@@ -137,29 +165,18 @@ upb_MessageValue Convert_RubyToUpb(VALUE value, const char* name,
137
165
  }
138
166
  break;
139
167
  }
140
- case kUpb_CType_String: {
141
- VALUE utf8 = rb_enc_from_encoding(rb_utf8_encoding());
168
+ case kUpb_CType_String:
142
169
  if (rb_obj_class(value) == rb_cSymbol) {
143
170
  value = rb_funcall(value, rb_intern("to_s"), 0);
144
- } else if (rb_obj_class(value) != rb_cString) {
171
+ } else if (!rb_obj_is_kind_of(value, rb_cString)) {
145
172
  rb_raise(cTypeError,
146
173
  "Invalid argument for string field '%s' (given %s).", name,
147
174
  rb_class2name(CLASS_OF(value)));
148
175
  }
149
176
 
150
- if (rb_obj_encoding(value) != utf8) {
151
- // Note: this will not duplicate underlying string data unless
152
- // necessary.
153
- value = rb_str_encode(value, utf8, 0, Qnil);
154
-
155
- if (rb_enc_str_coderange(value) == ENC_CODERANGE_BROKEN) {
156
- rb_raise(rb_eEncodingError, "String is invalid UTF-8");
157
- }
158
- }
159
-
177
+ value = Convert_CheckStringUtf8(value);
160
178
  ret.str_val = Convert_StringData(value, arena);
161
179
  break;
162
- }
163
180
  case kUpb_CType_Bytes: {
164
181
  VALUE bytes = rb_enc_from_encoding(rb_ascii8bit_encoding());
165
182
  if (rb_obj_class(value) != rb_cString) {
@@ -204,11 +221,13 @@ upb_MessageValue Convert_RubyToUpb(VALUE value, const char* name,
204
221
  ret.uint64_val = NUM2ULL(value);
205
222
  break;
206
223
  default:
207
- break;
224
+ rb_raise(cTypeError, "Convert_RubyToUpb(): Unexpected type %d",
225
+ (int)type_info.type);
208
226
  }
209
227
  break;
210
228
  default:
211
- break;
229
+ rb_raise(cTypeError,
230
+ "Convert_RubyToUpb(): Unexpected type %d", (int)type_info.type);
212
231
  }
213
232
 
214
233
  return ret;
@@ -296,7 +315,8 @@ bool Msgval_IsEqual(upb_MessageValue val1, upb_MessageValue val2,
296
315
  if (upb_Status_IsOk(&status)) {
297
316
  return return_value;
298
317
  } else {
299
- rb_raise(rb_eRuntimeError, upb_Status_ErrorMessage(&status));
318
+ rb_raise(rb_eRuntimeError, "Msgval_IsEqual(): %s",
319
+ upb_Status_ErrorMessage(&status));
300
320
  }
301
321
  }
302
322
 
@@ -309,6 +329,7 @@ uint64_t Msgval_GetHash(upb_MessageValue val, TypeInfo type_info,
309
329
  if (upb_Status_IsOk(&status)) {
310
330
  return return_value;
311
331
  } else {
312
- rb_raise(rb_eRuntimeError, upb_Status_ErrorMessage(&status));
332
+ rb_raise(rb_eRuntimeError, "Msgval_GetHash(): %s",
333
+ upb_Status_ErrorMessage(&status));
313
334
  }
314
335
  }