google-protobuf 3.22.5-x86-linux → 3.23.0.rc.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.
Potentially problematic release.
This version of google-protobuf might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/ext/google/protobuf_c/defs.c +22 -12
- data/ext/google/protobuf_c/message.c +13 -5
- data/ext/google/protobuf_c/protobuf.c +4 -2
- data/ext/google/protobuf_c/ruby-upb.c +656 -608
- data/ext/google/protobuf_c/ruby-upb.h +1361 -254
- data/lib/google/2.6/protobuf_c.so +0 -0
- data/lib/google/2.7/protobuf_c.so +0 -0
- data/lib/google/3.0/protobuf_c.so +0 -0
- data/lib/google/3.1/protobuf_c.so +0 -0
- data/lib/google/3.2/protobuf_c.so +0 -0
- data/lib/google/protobuf/any_pb.rb +24 -5
- data/lib/google/protobuf/api_pb.rb +26 -23
- data/lib/google/protobuf/descriptor_pb.rb +29 -252
- data/lib/google/protobuf/duration_pb.rb +24 -5
- data/lib/google/protobuf/empty_pb.rb +24 -3
- data/lib/google/protobuf/field_mask_pb.rb +24 -4
- data/lib/google/protobuf/plugin_pb.rb +25 -28
- data/lib/google/protobuf/source_context_pb.rb +24 -4
- data/lib/google/protobuf/struct_pb.rb +24 -20
- data/lib/google/protobuf/timestamp_pb.rb +24 -5
- data/lib/google/protobuf/type_pb.rb +26 -68
- data/lib/google/protobuf/wrappers_pb.rb +24 -28
- metadata +5 -5
@@ -166,9 +166,18 @@
|
|
166
166
|
#define UPB_LONGJMP(buf, val) longjmp(buf, val)
|
167
167
|
#endif
|
168
168
|
|
169
|
+
#ifdef __GNUC__
|
170
|
+
#define UPB_USE_C11_ATOMICS
|
171
|
+
#define UPB_ATOMIC(T) _Atomic(T)
|
172
|
+
#else
|
173
|
+
#define UPB_ATOMIC(T) T
|
174
|
+
#endif
|
175
|
+
|
169
176
|
/* UPB_PTRADD(ptr, ofs): add pointer while avoiding "NULL + 0" UB */
|
170
177
|
#define UPB_PTRADD(ptr, ofs) ((ofs) ? (ptr) + (ofs) : (ptr))
|
171
178
|
|
179
|
+
#define UPB_PRIVATE(x) x##_dont_copy_me__upb_internal_use_only
|
180
|
+
|
172
181
|
/* Configure whether fasttable is switched on or not. *************************/
|
173
182
|
|
174
183
|
#ifdef __has_attribute
|
@@ -390,6 +399,7 @@ void upb_Array_Set(upb_Array* arr, size_t i, upb_MessageValue val) {
|
|
390
399
|
}
|
391
400
|
|
392
401
|
bool upb_Array_Append(upb_Array* arr, upb_MessageValue val, upb_Arena* arena) {
|
402
|
+
UPB_ASSERT(arena);
|
393
403
|
if (!upb_Array_Resize(arr, arr->size + 1, arena)) {
|
394
404
|
return false;
|
395
405
|
}
|
@@ -406,6 +416,7 @@ void upb_Array_Move(upb_Array* arr, size_t dst_idx, size_t src_idx,
|
|
406
416
|
|
407
417
|
bool upb_Array_Insert(upb_Array* arr, size_t i, size_t count,
|
408
418
|
upb_Arena* arena) {
|
419
|
+
UPB_ASSERT(arena);
|
409
420
|
UPB_ASSERT(i <= arr->size);
|
410
421
|
UPB_ASSERT(count + arr->size >= count);
|
411
422
|
const size_t oldsize = arr->size;
|
@@ -500,6 +511,7 @@ void upb_Map_Clear(upb_Map* map) { _upb_Map_Clear(map); }
|
|
500
511
|
|
501
512
|
upb_MapInsertStatus upb_Map_Insert(upb_Map* map, upb_MessageValue key,
|
502
513
|
upb_MessageValue val, upb_Arena* arena) {
|
514
|
+
UPB_ASSERT(arena);
|
503
515
|
return (upb_MapInsertStatus)_upb_Map_Insert(map, &key, map->key_size, &val,
|
504
516
|
map->val_size, arena);
|
505
517
|
}
|
@@ -764,9 +776,9 @@ const upb_MiniTable google_protobuf_FileDescriptorProto_msg_init = {
|
|
764
776
|
UPB_SIZE(72, 144), 13, kUpb_ExtMode_NonExtendable, 13, UPB_FASTTABLE_MASK(120), 0,
|
765
777
|
UPB_FASTTABLE_INIT({
|
766
778
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
767
|
-
{0x000800000100000a, &
|
768
|
-
{0x0018000002000012, &
|
769
|
-
{0x002800003f00001a, &
|
779
|
+
{0x000800000100000a, &upb_pss_1bt},
|
780
|
+
{0x0018000002000012, &upb_pss_1bt},
|
781
|
+
{0x002800003f00001a, &upb_prs_1bt},
|
770
782
|
{0x003000003f000022, &upb_prm_1bt_max128b},
|
771
783
|
{0x003800003f01002a, &upb_prm_1bt_max64b},
|
772
784
|
{0x004000003f020032, &upb_prm_1bt_max64b},
|
@@ -775,8 +787,8 @@ const upb_MiniTable google_protobuf_FileDescriptorProto_msg_init = {
|
|
775
787
|
{0x005800000405004a, &upb_psm_1bt_max64b},
|
776
788
|
{0x006000003f000050, &upb_prv4_1bt},
|
777
789
|
{0x006800003f000058, &upb_prv4_1bt},
|
778
|
-
{0x0070000005000062, &
|
779
|
-
{0x008000000600006a, &
|
790
|
+
{0x0070000005000062, &upb_pss_1bt},
|
791
|
+
{0x008000000600006a, &upb_pss_1bt},
|
780
792
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
781
793
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
782
794
|
})
|
@@ -812,7 +824,7 @@ const upb_MiniTable google_protobuf_DescriptorProto_msg_init = {
|
|
812
824
|
UPB_SIZE(48, 96), 10, kUpb_ExtMode_NonExtendable, 10, UPB_FASTTABLE_MASK(120), 0,
|
813
825
|
UPB_FASTTABLE_INIT({
|
814
826
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
815
|
-
{0x000800000100000a, &
|
827
|
+
{0x000800000100000a, &upb_pss_1bt},
|
816
828
|
{0x001800003f000012, &upb_prm_1bt_max128b},
|
817
829
|
{0x002000003f01001a, &upb_prm_1bt_max128b},
|
818
830
|
{0x002800003f020022, &upb_prm_1bt_max64b},
|
@@ -821,7 +833,7 @@ const upb_MiniTable google_protobuf_DescriptorProto_msg_init = {
|
|
821
833
|
{0x004000000205003a, &upb_psm_1bt_max64b},
|
822
834
|
{0x004800003f060042, &upb_prm_1bt_max64b},
|
823
835
|
{0x005000003f07004a, &upb_prm_1bt_max64b},
|
824
|
-
{0x005800003f000052, &
|
836
|
+
{0x005800003f000052, &upb_prs_1bt},
|
825
837
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
826
838
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
827
839
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
@@ -869,21 +881,26 @@ const upb_MiniTable google_protobuf_DescriptorProto_ReservedRange_msg_init = {
|
|
869
881
|
})
|
870
882
|
};
|
871
883
|
|
872
|
-
static const upb_MiniTableSub google_protobuf_ExtensionRangeOptions_submsgs[
|
884
|
+
static const upb_MiniTableSub google_protobuf_ExtensionRangeOptions_submsgs[3] = {
|
885
|
+
{.submsg = &google_protobuf_ExtensionRangeOptions_Declaration_msg_init},
|
886
|
+
{.subenum = &google_protobuf_ExtensionRangeOptions_VerificationState_enum_init},
|
873
887
|
{.submsg = &google_protobuf_UninterpretedOption_msg_init},
|
874
888
|
};
|
875
889
|
|
876
|
-
static const upb_MiniTableField google_protobuf_ExtensionRangeOptions__fields[
|
877
|
-
{
|
890
|
+
static const upb_MiniTableField google_protobuf_ExtensionRangeOptions__fields[3] = {
|
891
|
+
{2, UPB_SIZE(4, 8), 0, 0, 11, kUpb_FieldMode_Array | (UPB_SIZE(kUpb_FieldRep_4Byte, kUpb_FieldRep_8Byte) << kUpb_FieldRep_Shift)},
|
892
|
+
{3, UPB_SIZE(8, 4), 1, 1, 14, kUpb_FieldMode_Scalar | (kUpb_FieldRep_4Byte << kUpb_FieldRep_Shift)},
|
893
|
+
{999, UPB_SIZE(12, 16), 0, 2, 11, kUpb_FieldMode_Array | (UPB_SIZE(kUpb_FieldRep_4Byte, kUpb_FieldRep_8Byte) << kUpb_FieldRep_Shift)},
|
878
894
|
};
|
879
895
|
|
880
896
|
const upb_MiniTable google_protobuf_ExtensionRangeOptions_msg_init = {
|
881
897
|
&google_protobuf_ExtensionRangeOptions_submsgs[0],
|
882
898
|
&google_protobuf_ExtensionRangeOptions__fields[0],
|
883
|
-
|
899
|
+
UPB_SIZE(16, 24), 3, kUpb_ExtMode_Extendable, 0, UPB_FASTTABLE_MASK(248), 0,
|
884
900
|
UPB_FASTTABLE_INIT({
|
885
901
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
886
902
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
903
|
+
{0x000800003f000012, &upb_prm_1bt_max64b},
|
887
904
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
888
905
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
889
906
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
@@ -904,8 +921,8 @@ const upb_MiniTable google_protobuf_ExtensionRangeOptions_msg_init = {
|
|
904
921
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
905
922
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
906
923
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
924
|
+
{0x001000003f023eba, &upb_prm_2bt_max128b},
|
907
925
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
908
|
-
{0x000000003f003eba, &upb_prm_2bt_max128b},
|
909
926
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
910
927
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
911
928
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
@@ -913,6 +930,30 @@ const upb_MiniTable google_protobuf_ExtensionRangeOptions_msg_init = {
|
|
913
930
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
914
931
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
915
932
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
933
|
+
})
|
934
|
+
};
|
935
|
+
|
936
|
+
static const upb_MiniTableField google_protobuf_ExtensionRangeOptions_Declaration__fields[6] = {
|
937
|
+
{1, 4, 1, kUpb_NoSub, 5, kUpb_FieldMode_Scalar | (kUpb_FieldRep_4Byte << kUpb_FieldRep_Shift)},
|
938
|
+
{2, UPB_SIZE(12, 16), 2, kUpb_NoSub, 12, kUpb_FieldMode_Scalar | kUpb_LabelFlags_IsAlternate | (kUpb_FieldRep_StringView << kUpb_FieldRep_Shift)},
|
939
|
+
{3, UPB_SIZE(20, 32), 3, kUpb_NoSub, 12, kUpb_FieldMode_Scalar | kUpb_LabelFlags_IsAlternate | (kUpb_FieldRep_StringView << kUpb_FieldRep_Shift)},
|
940
|
+
{4, 8, 4, kUpb_NoSub, 8, kUpb_FieldMode_Scalar | (kUpb_FieldRep_1Byte << kUpb_FieldRep_Shift)},
|
941
|
+
{5, 9, 5, kUpb_NoSub, 8, kUpb_FieldMode_Scalar | (kUpb_FieldRep_1Byte << kUpb_FieldRep_Shift)},
|
942
|
+
{6, 10, 6, kUpb_NoSub, 8, kUpb_FieldMode_Scalar | (kUpb_FieldRep_1Byte << kUpb_FieldRep_Shift)},
|
943
|
+
};
|
944
|
+
|
945
|
+
const upb_MiniTable google_protobuf_ExtensionRangeOptions_Declaration_msg_init = {
|
946
|
+
NULL,
|
947
|
+
&google_protobuf_ExtensionRangeOptions_Declaration__fields[0],
|
948
|
+
UPB_SIZE(32, 48), 6, kUpb_ExtMode_NonExtendable, 6, UPB_FASTTABLE_MASK(56), 0,
|
949
|
+
UPB_FASTTABLE_INIT({
|
950
|
+
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
951
|
+
{0x0004000001000008, &upb_psv4_1bt},
|
952
|
+
{0x0010000002000012, &upb_pss_1bt},
|
953
|
+
{0x002000000300001a, &upb_pss_1bt},
|
954
|
+
{0x0008000004000020, &upb_psb1_1bt},
|
955
|
+
{0x0009000005000028, &upb_psb1_1bt},
|
956
|
+
{0x000a000006000030, &upb_psb1_1bt},
|
916
957
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
917
958
|
})
|
918
959
|
};
|
@@ -943,16 +984,16 @@ const upb_MiniTable google_protobuf_FieldDescriptorProto_msg_init = {
|
|
943
984
|
UPB_SIZE(72, 112), 11, kUpb_ExtMode_NonExtendable, 10, UPB_FASTTABLE_MASK(248), 0,
|
944
985
|
UPB_FASTTABLE_INIT({
|
945
986
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
946
|
-
{0x001800000100000a, &
|
947
|
-
{0x0028000002000012, &
|
987
|
+
{0x001800000100000a, &upb_pss_1bt},
|
988
|
+
{0x0028000002000012, &upb_pss_1bt},
|
948
989
|
{0x0004000003000018, &upb_psv4_1bt},
|
949
990
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
950
991
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
951
|
-
{0x0038000006000032, &
|
952
|
-
{0x004800000700003a, &
|
992
|
+
{0x0038000006000032, &upb_pss_1bt},
|
993
|
+
{0x004800000700003a, &upb_pss_1bt},
|
953
994
|
{0x0058000008020042, &upb_psm_1bt_max64b},
|
954
995
|
{0x0010000009000048, &upb_psv4_1bt},
|
955
|
-
{0x006000000a000052, &
|
996
|
+
{0x006000000a000052, &upb_pss_1bt},
|
956
997
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
957
998
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
958
999
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
@@ -992,7 +1033,7 @@ const upb_MiniTable google_protobuf_OneofDescriptorProto_msg_init = {
|
|
992
1033
|
UPB_SIZE(16, 32), 2, kUpb_ExtMode_NonExtendable, 2, UPB_FASTTABLE_MASK(24), 0,
|
993
1034
|
UPB_FASTTABLE_INIT({
|
994
1035
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
995
|
-
{0x000800000100000a, &
|
1036
|
+
{0x000800000100000a, &upb_pss_1bt},
|
996
1037
|
{0x0018000002000012, &upb_psm_1bt_max64b},
|
997
1038
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
998
1039
|
})
|
@@ -1018,11 +1059,11 @@ const upb_MiniTable google_protobuf_EnumDescriptorProto_msg_init = {
|
|
1018
1059
|
UPB_SIZE(32, 56), 5, kUpb_ExtMode_NonExtendable, 5, UPB_FASTTABLE_MASK(56), 0,
|
1019
1060
|
UPB_FASTTABLE_INIT({
|
1020
1061
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1021
|
-
{0x000800000100000a, &
|
1062
|
+
{0x000800000100000a, &upb_pss_1bt},
|
1022
1063
|
{0x001800003f000012, &upb_prm_1bt_max64b},
|
1023
1064
|
{0x002000000201001a, &upb_psm_1bt_max64b},
|
1024
1065
|
{0x002800003f020022, &upb_prm_1bt_max64b},
|
1025
|
-
{0x003000003f00002a, &
|
1066
|
+
{0x003000003f00002a, &upb_prs_1bt},
|
1026
1067
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1027
1068
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1028
1069
|
})
|
@@ -1061,7 +1102,7 @@ const upb_MiniTable google_protobuf_EnumValueDescriptorProto_msg_init = {
|
|
1061
1102
|
UPB_SIZE(24, 32), 3, kUpb_ExtMode_NonExtendable, 3, UPB_FASTTABLE_MASK(24), 0,
|
1062
1103
|
UPB_FASTTABLE_INIT({
|
1063
1104
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1064
|
-
{0x000800000100000a, &
|
1105
|
+
{0x000800000100000a, &upb_pss_1bt},
|
1065
1106
|
{0x0004000002000010, &upb_psv4_1bt},
|
1066
1107
|
{0x001800000300001a, &upb_psm_1bt_max64b},
|
1067
1108
|
})
|
@@ -1084,7 +1125,7 @@ const upb_MiniTable google_protobuf_ServiceDescriptorProto_msg_init = {
|
|
1084
1125
|
UPB_SIZE(24, 40), 3, kUpb_ExtMode_NonExtendable, 3, UPB_FASTTABLE_MASK(24), 0,
|
1085
1126
|
UPB_FASTTABLE_INIT({
|
1086
1127
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1087
|
-
{0x000800000100000a, &
|
1128
|
+
{0x000800000100000a, &upb_pss_1bt},
|
1088
1129
|
{0x001800003f000012, &upb_prm_1bt_max128b},
|
1089
1130
|
{0x002000000201001a, &upb_psm_1bt_max64b},
|
1090
1131
|
})
|
@@ -1109,9 +1150,9 @@ const upb_MiniTable google_protobuf_MethodDescriptorProto_msg_init = {
|
|
1109
1150
|
UPB_SIZE(40, 64), 6, kUpb_ExtMode_NonExtendable, 6, UPB_FASTTABLE_MASK(56), 0,
|
1110
1151
|
UPB_FASTTABLE_INIT({
|
1111
1152
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1112
|
-
{0x000800000100000a, &
|
1113
|
-
{0x0018000002000012, &
|
1114
|
-
{0x002800000300001a, &
|
1153
|
+
{0x000800000100000a, &upb_pss_1bt},
|
1154
|
+
{0x0018000002000012, &upb_pss_1bt},
|
1155
|
+
{0x002800000300001a, &upb_pss_1bt},
|
1115
1156
|
{0x0038000004000022, &upb_psm_1bt_max64b},
|
1116
1157
|
{0x0001000005000028, &upb_psb1_1bt},
|
1117
1158
|
{0x0002000006000030, &upb_psb1_1bt},
|
@@ -1154,17 +1195,17 @@ const upb_MiniTable google_protobuf_FileOptions_msg_init = {
|
|
1154
1195
|
UPB_SIZE(104, 192), 21, kUpb_ExtMode_Extendable, 1, UPB_FASTTABLE_MASK(248), 0,
|
1155
1196
|
UPB_FASTTABLE_INIT({
|
1156
1197
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1157
|
-
{0x001800000100000a, &
|
1198
|
+
{0x001800000100000a, &upb_pss_1bt},
|
1158
1199
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1159
1200
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1160
1201
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1161
1202
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1162
1203
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1163
1204
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1164
|
-
{0x0028000002000042, &
|
1205
|
+
{0x0028000002000042, &upb_pss_1bt},
|
1165
1206
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1166
1207
|
{0x0008000004000050, &upb_psb1_1bt},
|
1167
|
-
{0x003800000500005a, &
|
1208
|
+
{0x003800000500005a, &upb_pss_1bt},
|
1168
1209
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1169
1210
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1170
1211
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
@@ -1174,15 +1215,15 @@ const upb_MiniTable google_protobuf_FileOptions_msg_init = {
|
|
1174
1215
|
{0x000b000008000190, &upb_psb1_2bt},
|
1175
1216
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1176
1217
|
{0x000c0000090001a0, &upb_psb1_2bt},
|
1177
|
-
{0x005800000e0002aa, &
|
1218
|
+
{0x005800000e0002aa, &upb_pss_2bt},
|
1178
1219
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1179
1220
|
{0x000d00000a0001b8, &upb_psb1_2bt},
|
1180
|
-
{0x00780000100002c2, &
|
1181
|
-
{0x00880000110002ca, &
|
1221
|
+
{0x00780000100002c2, &upb_pss_2bt},
|
1222
|
+
{0x00880000110002ca, &upb_pss_2bt},
|
1182
1223
|
{0x00100000120002d0, &upb_psb1_2bt},
|
1183
1224
|
{0x000e00000b0001d8, &upb_psb1_2bt},
|
1184
|
-
{0x00980000130002e2, &
|
1185
|
-
{0x00a80000140002ea, &
|
1225
|
+
{0x00980000130002e2, &upb_pss_2bt},
|
1226
|
+
{0x00a80000140002ea, &upb_pss_2bt},
|
1186
1227
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1187
1228
|
{0x000f00000c0001f8, &upb_psb1_2bt},
|
1188
1229
|
})
|
@@ -1241,15 +1282,16 @@ const upb_MiniTable google_protobuf_MessageOptions_msg_init = {
|
|
1241
1282
|
})
|
1242
1283
|
};
|
1243
1284
|
|
1244
|
-
static const upb_MiniTableSub google_protobuf_FieldOptions_submsgs[
|
1285
|
+
static const upb_MiniTableSub google_protobuf_FieldOptions_submsgs[6] = {
|
1245
1286
|
{.subenum = &google_protobuf_FieldOptions_CType_enum_init},
|
1246
1287
|
{.subenum = &google_protobuf_FieldOptions_JSType_enum_init},
|
1247
1288
|
{.subenum = &google_protobuf_FieldOptions_OptionRetention_enum_init},
|
1248
1289
|
{.subenum = &google_protobuf_FieldOptions_OptionTargetType_enum_init},
|
1290
|
+
{.subenum = &google_protobuf_FieldOptions_OptionTargetType_enum_init},
|
1249
1291
|
{.submsg = &google_protobuf_UninterpretedOption_msg_init},
|
1250
1292
|
};
|
1251
1293
|
|
1252
|
-
static const upb_MiniTableField google_protobuf_FieldOptions__fields[
|
1294
|
+
static const upb_MiniTableField google_protobuf_FieldOptions__fields[12] = {
|
1253
1295
|
{1, 4, 1, 0, 14, kUpb_FieldMode_Scalar | (kUpb_FieldRep_4Byte << kUpb_FieldRep_Shift)},
|
1254
1296
|
{2, 8, 2, kUpb_NoSub, 8, kUpb_FieldMode_Scalar | (kUpb_FieldRep_1Byte << kUpb_FieldRep_Shift)},
|
1255
1297
|
{3, 9, 3, kUpb_NoSub, 8, kUpb_FieldMode_Scalar | (kUpb_FieldRep_1Byte << kUpb_FieldRep_Shift)},
|
@@ -1260,13 +1302,14 @@ static const upb_MiniTableField google_protobuf_FieldOptions__fields[11] = {
|
|
1260
1302
|
{16, 18, 8, kUpb_NoSub, 8, kUpb_FieldMode_Scalar | (kUpb_FieldRep_1Byte << kUpb_FieldRep_Shift)},
|
1261
1303
|
{17, 20, 9, 2, 14, kUpb_FieldMode_Scalar | (kUpb_FieldRep_4Byte << kUpb_FieldRep_Shift)},
|
1262
1304
|
{18, 24, 10, 3, 14, kUpb_FieldMode_Scalar | (kUpb_FieldRep_4Byte << kUpb_FieldRep_Shift)},
|
1263
|
-
{
|
1305
|
+
{19, UPB_SIZE(28, 32), 0, 4, 14, kUpb_FieldMode_Array | (UPB_SIZE(kUpb_FieldRep_4Byte, kUpb_FieldRep_8Byte) << kUpb_FieldRep_Shift)},
|
1306
|
+
{999, UPB_SIZE(32, 40), 0, 5, 11, kUpb_FieldMode_Array | (UPB_SIZE(kUpb_FieldRep_4Byte, kUpb_FieldRep_8Byte) << kUpb_FieldRep_Shift)},
|
1264
1307
|
};
|
1265
1308
|
|
1266
1309
|
const upb_MiniTable google_protobuf_FieldOptions_msg_init = {
|
1267
1310
|
&google_protobuf_FieldOptions_submsgs[0],
|
1268
1311
|
&google_protobuf_FieldOptions__fields[0],
|
1269
|
-
UPB_SIZE(
|
1312
|
+
UPB_SIZE(40, 48), 12, kUpb_ExtMode_Extendable, 3, UPB_FASTTABLE_MASK(248), 0,
|
1270
1313
|
UPB_FASTTABLE_INIT({
|
1271
1314
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1272
1315
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
@@ -1291,7 +1334,7 @@ const upb_MiniTable google_protobuf_FieldOptions_msg_init = {
|
|
1291
1334
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1292
1335
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1293
1336
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1294
|
-
{
|
1337
|
+
{0x002800003f053eba, &upb_prm_2bt_max128b},
|
1295
1338
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1296
1339
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1297
1340
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
@@ -1573,12 +1616,12 @@ const upb_MiniTable google_protobuf_UninterpretedOption_msg_init = {
|
|
1573
1616
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1574
1617
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1575
1618
|
{0x000800003f000012, &upb_prm_1bt_max64b},
|
1576
|
-
{0x001000000100001a, &
|
1619
|
+
{0x001000000100001a, &upb_pss_1bt},
|
1577
1620
|
{0x0020000002000020, &upb_psv8_1bt},
|
1578
1621
|
{0x0028000003000028, &upb_psv8_1bt},
|
1579
1622
|
{0x0030000004000031, &upb_psf8_1bt},
|
1580
1623
|
{0x003800000500003a, &upb_psb_1bt},
|
1581
|
-
{0x0048000006000042, &
|
1624
|
+
{0x0048000006000042, &upb_pss_1bt},
|
1582
1625
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1583
1626
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1584
1627
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
@@ -1600,7 +1643,7 @@ const upb_MiniTable google_protobuf_UninterpretedOption_NamePart_msg_init = {
|
|
1600
1643
|
UPB_SIZE(16, 24), 2, kUpb_ExtMode_NonExtendable, 2, UPB_FASTTABLE_MASK(24), 2,
|
1601
1644
|
UPB_FASTTABLE_INIT({
|
1602
1645
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1603
|
-
{0x000800000100000a, &
|
1646
|
+
{0x000800000100000a, &upb_pss_1bt},
|
1604
1647
|
{0x0001000002000010, &upb_psb1_1bt},
|
1605
1648
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1606
1649
|
})
|
@@ -1640,10 +1683,10 @@ const upb_MiniTable google_protobuf_SourceCodeInfo_Location_msg_init = {
|
|
1640
1683
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1641
1684
|
{0x000800003f00000a, &upb_ppv4_1bt},
|
1642
1685
|
{0x001000003f000012, &upb_ppv4_1bt},
|
1643
|
-
{0x001800000100001a, &
|
1644
|
-
{0x0028000002000022, &
|
1686
|
+
{0x001800000100001a, &upb_pss_1bt},
|
1687
|
+
{0x0028000002000022, &upb_pss_1bt},
|
1645
1688
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1646
|
-
{0x003800003f000032, &
|
1689
|
+
{0x003800003f000032, &upb_prs_1bt},
|
1647
1690
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1648
1691
|
})
|
1649
1692
|
};
|
@@ -1685,7 +1728,7 @@ const upb_MiniTable google_protobuf_GeneratedCodeInfo_Annotation_msg_init = {
|
|
1685
1728
|
UPB_FASTTABLE_INIT({
|
1686
1729
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
1687
1730
|
{0x001000003f00000a, &upb_ppv4_1bt},
|
1688
|
-
{0x0018000001000012, &
|
1731
|
+
{0x0018000001000012, &upb_pss_1bt},
|
1689
1732
|
{0x0004000002000018, &upb_psv4_1bt},
|
1690
1733
|
{0x0008000003000020, &upb_psv4_1bt},
|
1691
1734
|
{0x0000000000000000, &_upb_FastDecoder_DecodeGeneric},
|
@@ -1694,13 +1737,14 @@ const upb_MiniTable google_protobuf_GeneratedCodeInfo_Annotation_msg_init = {
|
|
1694
1737
|
})
|
1695
1738
|
};
|
1696
1739
|
|
1697
|
-
static const upb_MiniTable *messages_layout[
|
1740
|
+
static const upb_MiniTable *messages_layout[28] = {
|
1698
1741
|
&google_protobuf_FileDescriptorSet_msg_init,
|
1699
1742
|
&google_protobuf_FileDescriptorProto_msg_init,
|
1700
1743
|
&google_protobuf_DescriptorProto_msg_init,
|
1701
1744
|
&google_protobuf_DescriptorProto_ExtensionRange_msg_init,
|
1702
1745
|
&google_protobuf_DescriptorProto_ReservedRange_msg_init,
|
1703
1746
|
&google_protobuf_ExtensionRangeOptions_msg_init,
|
1747
|
+
&google_protobuf_ExtensionRangeOptions_Declaration_msg_init,
|
1704
1748
|
&google_protobuf_FieldDescriptorProto_msg_init,
|
1705
1749
|
&google_protobuf_OneofDescriptorProto_msg_init,
|
1706
1750
|
&google_protobuf_EnumDescriptorProto_msg_init,
|
@@ -1724,6 +1768,15 @@ static const upb_MiniTable *messages_layout[27] = {
|
|
1724
1768
|
&google_protobuf_GeneratedCodeInfo_Annotation_msg_init,
|
1725
1769
|
};
|
1726
1770
|
|
1771
|
+
const upb_MiniTableEnum google_protobuf_ExtensionRangeOptions_VerificationState_enum_init = {
|
1772
|
+
64,
|
1773
|
+
0,
|
1774
|
+
{
|
1775
|
+
0x3,
|
1776
|
+
0x0,
|
1777
|
+
},
|
1778
|
+
};
|
1779
|
+
|
1727
1780
|
const upb_MiniTableEnum google_protobuf_FieldDescriptorProto_Label_enum_init = {
|
1728
1781
|
64,
|
1729
1782
|
0,
|
@@ -1805,7 +1858,8 @@ const upb_MiniTableEnum google_protobuf_MethodOptions_IdempotencyLevel_enum_init
|
|
1805
1858
|
},
|
1806
1859
|
};
|
1807
1860
|
|
1808
|
-
static const upb_MiniTableEnum *enums_layout[
|
1861
|
+
static const upb_MiniTableEnum *enums_layout[10] = {
|
1862
|
+
&google_protobuf_ExtensionRangeOptions_VerificationState_enum_init,
|
1809
1863
|
&google_protobuf_FieldDescriptorProto_Label_enum_init,
|
1810
1864
|
&google_protobuf_FieldDescriptorProto_Type_enum_init,
|
1811
1865
|
&google_protobuf_FieldOptions_CType_enum_init,
|
@@ -1821,8 +1875,8 @@ const upb_MiniTableFile google_protobuf_descriptor_proto_upb_file_layout = {
|
|
1821
1875
|
messages_layout,
|
1822
1876
|
enums_layout,
|
1823
1877
|
NULL,
|
1824
|
-
|
1825
|
-
|
1878
|
+
28,
|
1879
|
+
10,
|
1826
1880
|
0,
|
1827
1881
|
};
|
1828
1882
|
|
@@ -2587,7 +2641,7 @@ bool upb_inttable_next(const upb_inttable* t, uintptr_t* key, upb_value* val,
|
|
2587
2641
|
intptr_t* iter) {
|
2588
2642
|
intptr_t i = *iter;
|
2589
2643
|
if ((size_t)(i + 1) <= t->array_size) {
|
2590
|
-
while (++i < t->array_size) {
|
2644
|
+
while ((size_t)++i < t->array_size) {
|
2591
2645
|
upb_tabval ent = t->array[i];
|
2592
2646
|
if (upb_arrhas(ent)) {
|
2593
2647
|
*key = i;
|
@@ -2613,7 +2667,7 @@ bool upb_inttable_next(const upb_inttable* t, uintptr_t* key, upb_value* val,
|
|
2613
2667
|
|
2614
2668
|
void upb_inttable_removeiter(upb_inttable* t, intptr_t* iter) {
|
2615
2669
|
intptr_t i = *iter;
|
2616
|
-
if (i < t->array_size) {
|
2670
|
+
if ((size_t)i < t->array_size) {
|
2617
2671
|
t->array_count--;
|
2618
2672
|
mutable_array(t)[i].val = -1;
|
2619
2673
|
} else {
|
@@ -5092,107 +5146,127 @@ upb_alloc upb_alloc_global = {&upb_global_allocfunc};
|
|
5092
5146
|
|
5093
5147
|
// Must be last.
|
5094
5148
|
|
5095
|
-
static uint32_t* upb_cleanup_pointer(uintptr_t cleanup_metadata) {
|
5096
|
-
return (uint32_t*)(cleanup_metadata & ~0x1);
|
5097
|
-
}
|
5098
|
-
|
5099
|
-
static bool upb_cleanup_has_initial_block(uintptr_t cleanup_metadata) {
|
5100
|
-
return cleanup_metadata & 0x1;
|
5101
|
-
}
|
5102
|
-
|
5103
|
-
static uintptr_t upb_cleanup_metadata(uint32_t* cleanup,
|
5104
|
-
bool has_initial_block) {
|
5105
|
-
return (uintptr_t)cleanup | has_initial_block;
|
5106
|
-
}
|
5107
|
-
|
5108
5149
|
struct _upb_MemBlock {
|
5109
|
-
|
5150
|
+
// Atomic only for the benefit of SpaceAllocated().
|
5151
|
+
UPB_ATOMIC(_upb_MemBlock*) next;
|
5110
5152
|
uint32_t size;
|
5111
|
-
uint32_t cleanups;
|
5112
5153
|
// Data follows.
|
5113
5154
|
};
|
5114
5155
|
|
5115
|
-
typedef struct cleanup_ent {
|
5116
|
-
upb_CleanupFunc* cleanup;
|
5117
|
-
void* ud;
|
5118
|
-
} cleanup_ent;
|
5119
|
-
|
5120
5156
|
static const size_t memblock_reserve =
|
5121
5157
|
UPB_ALIGN_UP(sizeof(_upb_MemBlock), UPB_MALLOC_ALIGN);
|
5122
5158
|
|
5123
|
-
|
5124
|
-
|
5125
|
-
|
5126
|
-
|
5127
|
-
|
5128
|
-
|
5159
|
+
typedef struct _upb_ArenaRoot {
|
5160
|
+
upb_Arena* root;
|
5161
|
+
uintptr_t tagged_count;
|
5162
|
+
} _upb_ArenaRoot;
|
5163
|
+
|
5164
|
+
static _upb_ArenaRoot _upb_Arena_FindRoot(upb_Arena* a) {
|
5165
|
+
uintptr_t poc = upb_Atomic_Load(&a->parent_or_count, memory_order_acquire);
|
5166
|
+
while (_upb_Arena_IsTaggedPointer(poc)) {
|
5167
|
+
upb_Arena* next = _upb_Arena_PointerFromTagged(poc);
|
5168
|
+
UPB_ASSERT(a != next);
|
5169
|
+
uintptr_t next_poc =
|
5170
|
+
upb_Atomic_Load(&next->parent_or_count, memory_order_acquire);
|
5171
|
+
|
5172
|
+
if (_upb_Arena_IsTaggedPointer(next_poc)) {
|
5173
|
+
// To keep complexity down, we lazily collapse levels of the tree. This
|
5174
|
+
// keeps it flat in the final case, but doesn't cost much incrementally.
|
5175
|
+
//
|
5176
|
+
// Path splitting keeps time complexity down, see:
|
5177
|
+
// https://en.wikipedia.org/wiki/Disjoint-set_data_structure
|
5178
|
+
//
|
5179
|
+
// We can safely use a relaxed atomic here because all threads doing this
|
5180
|
+
// will converge on the same value and we don't need memory orderings to
|
5181
|
+
// be visible.
|
5182
|
+
//
|
5183
|
+
// This is true because:
|
5184
|
+
// - If no fuses occur, this will eventually become the root.
|
5185
|
+
// - If fuses are actively occuring, the root may change, but the
|
5186
|
+
// invariant is that `parent_or_count` merely points to *a* parent.
|
5187
|
+
//
|
5188
|
+
// In other words, it is moving towards "the" root, and that root may move
|
5189
|
+
// further away over time, but the path towards that root will continue to
|
5190
|
+
// be valid and the creation of the path carries all the memory orderings
|
5191
|
+
// required.
|
5192
|
+
UPB_ASSERT(a != _upb_Arena_PointerFromTagged(next_poc));
|
5193
|
+
upb_Atomic_Store(&a->parent_or_count, next_poc, memory_order_relaxed);
|
5194
|
+
}
|
5129
5195
|
a = next;
|
5196
|
+
poc = next_poc;
|
5130
5197
|
}
|
5131
|
-
return a;
|
5198
|
+
return (_upb_ArenaRoot){.root = a, .tagged_count = poc};
|
5132
5199
|
}
|
5133
5200
|
|
5134
5201
|
size_t upb_Arena_SpaceAllocated(upb_Arena* arena) {
|
5135
|
-
arena =
|
5202
|
+
arena = _upb_Arena_FindRoot(arena).root;
|
5136
5203
|
size_t memsize = 0;
|
5137
5204
|
|
5138
|
-
|
5139
|
-
|
5140
|
-
|
5141
|
-
|
5142
|
-
|
5205
|
+
while (arena != NULL) {
|
5206
|
+
_upb_MemBlock* block =
|
5207
|
+
upb_Atomic_Load(&arena->blocks, memory_order_relaxed);
|
5208
|
+
while (block != NULL) {
|
5209
|
+
memsize += sizeof(_upb_MemBlock) + block->size;
|
5210
|
+
block = upb_Atomic_Load(&block->next, memory_order_relaxed);
|
5211
|
+
}
|
5212
|
+
arena = upb_Atomic_Load(&arena->next, memory_order_relaxed);
|
5143
5213
|
}
|
5144
5214
|
|
5145
5215
|
return memsize;
|
5146
5216
|
}
|
5147
5217
|
|
5148
|
-
uint32_t upb_Arena_DebugRefCount(upb_Arena*
|
5149
|
-
|
5218
|
+
uint32_t upb_Arena_DebugRefCount(upb_Arena* a) {
|
5219
|
+
// These loads could probably be relaxed, but given that this is debug-only,
|
5220
|
+
// it's not worth introducing a new variant for it.
|
5221
|
+
uintptr_t poc = upb_Atomic_Load(&a->parent_or_count, memory_order_acquire);
|
5222
|
+
while (_upb_Arena_IsTaggedPointer(poc)) {
|
5223
|
+
a = _upb_Arena_PointerFromTagged(poc);
|
5224
|
+
poc = upb_Atomic_Load(&a->parent_or_count, memory_order_acquire);
|
5225
|
+
}
|
5226
|
+
return _upb_Arena_RefCountFromTagged(poc);
|
5150
5227
|
}
|
5151
5228
|
|
5152
|
-
static void
|
5153
|
-
size_t size) {
|
5229
|
+
static void upb_Arena_AddBlock(upb_Arena* a, void* ptr, size_t size) {
|
5154
5230
|
_upb_MemBlock* block = ptr;
|
5155
5231
|
|
5156
|
-
|
5157
|
-
block->next = root->freelist;
|
5232
|
+
// Insert into linked list.
|
5158
5233
|
block->size = (uint32_t)size;
|
5159
|
-
block->
|
5160
|
-
|
5161
|
-
a->last_size = block->size;
|
5162
|
-
if (!root->freelist_tail) root->freelist_tail = block;
|
5234
|
+
upb_Atomic_Init(&block->next, a->blocks);
|
5235
|
+
upb_Atomic_Store(&a->blocks, block, memory_order_release);
|
5163
5236
|
|
5164
5237
|
a->head.ptr = UPB_PTR_AT(block, memblock_reserve, char);
|
5165
5238
|
a->head.end = UPB_PTR_AT(block, size, char);
|
5166
|
-
a->cleanup_metadata = upb_cleanup_metadata(
|
5167
|
-
&block->cleanups, upb_cleanup_has_initial_block(a->cleanup_metadata));
|
5168
5239
|
|
5169
5240
|
UPB_POISON_MEMORY_REGION(a->head.ptr, a->head.end - a->head.ptr);
|
5170
5241
|
}
|
5171
5242
|
|
5172
|
-
static bool
|
5173
|
-
|
5174
|
-
|
5175
|
-
|
5243
|
+
static bool upb_Arena_AllocBlock(upb_Arena* a, size_t size) {
|
5244
|
+
if (!a->block_alloc) return false;
|
5245
|
+
_upb_MemBlock* last_block = upb_Atomic_Load(&a->blocks, memory_order_acquire);
|
5246
|
+
size_t last_size = last_block != NULL ? last_block->size : 128;
|
5247
|
+
size_t block_size = UPB_MAX(size, last_size * 2) + memblock_reserve;
|
5248
|
+
_upb_MemBlock* block = upb_malloc(upb_Arena_BlockAlloc(a), block_size);
|
5176
5249
|
|
5177
5250
|
if (!block) return false;
|
5178
|
-
|
5251
|
+
upb_Arena_AddBlock(a, block, block_size);
|
5179
5252
|
return true;
|
5180
5253
|
}
|
5181
5254
|
|
5182
5255
|
void* _upb_Arena_SlowMalloc(upb_Arena* a, size_t size) {
|
5183
|
-
if (!
|
5256
|
+
if (!upb_Arena_AllocBlock(a, size)) return NULL; /* Out of memory. */
|
5184
5257
|
UPB_ASSERT(_upb_ArenaHas(a) >= size);
|
5185
5258
|
return upb_Arena_Malloc(a, size);
|
5186
5259
|
}
|
5187
5260
|
|
5188
5261
|
/* Public Arena API ***********************************************************/
|
5189
5262
|
|
5190
|
-
static upb_Arena*
|
5263
|
+
static upb_Arena* upb_Arena_InitSlow(upb_alloc* alloc) {
|
5191
5264
|
const size_t first_block_overhead = sizeof(upb_Arena) + memblock_reserve;
|
5192
5265
|
upb_Arena* a;
|
5193
5266
|
|
5194
5267
|
/* We need to malloc the initial block. */
|
5195
|
-
|
5268
|
+
char* mem;
|
5269
|
+
size_t n = first_block_overhead + 256;
|
5196
5270
|
if (!alloc || !(mem = upb_malloc(alloc, n))) {
|
5197
5271
|
return NULL;
|
5198
5272
|
}
|
@@ -5200,14 +5274,13 @@ static upb_Arena* arena_initslow(void* mem, size_t n, upb_alloc* alloc) {
|
|
5200
5274
|
a = UPB_PTR_AT(mem, n - sizeof(*a), upb_Arena);
|
5201
5275
|
n -= sizeof(*a);
|
5202
5276
|
|
5203
|
-
a->block_alloc = alloc;
|
5204
|
-
a->
|
5205
|
-
a->
|
5206
|
-
a->
|
5207
|
-
a->
|
5208
|
-
a->cleanup_metadata = upb_cleanup_metadata(NULL, false);
|
5277
|
+
a->block_alloc = upb_Arena_MakeBlockAlloc(alloc, 0);
|
5278
|
+
upb_Atomic_Init(&a->parent_or_count, _upb_Arena_TaggedFromRefcount(1));
|
5279
|
+
upb_Atomic_Init(&a->next, NULL);
|
5280
|
+
upb_Atomic_Init(&a->tail, a);
|
5281
|
+
upb_Atomic_Init(&a->blocks, NULL);
|
5209
5282
|
|
5210
|
-
|
5283
|
+
upb_Arena_AddBlock(a, mem, n);
|
5211
5284
|
|
5212
5285
|
return a;
|
5213
5286
|
}
|
@@ -5228,343 +5301,189 @@ upb_Arena* upb_Arena_Init(void* mem, size_t n, upb_alloc* alloc) {
|
|
5228
5301
|
n = UPB_ALIGN_DOWN(n, UPB_ALIGN_OF(upb_Arena));
|
5229
5302
|
|
5230
5303
|
if (UPB_UNLIKELY(n < sizeof(upb_Arena))) {
|
5231
|
-
return
|
5304
|
+
return upb_Arena_InitSlow(alloc);
|
5232
5305
|
}
|
5233
5306
|
|
5234
5307
|
a = UPB_PTR_AT(mem, n - sizeof(*a), upb_Arena);
|
5235
5308
|
|
5236
|
-
a->
|
5237
|
-
a->
|
5238
|
-
a->
|
5239
|
-
a->
|
5309
|
+
upb_Atomic_Init(&a->parent_or_count, _upb_Arena_TaggedFromRefcount(1));
|
5310
|
+
upb_Atomic_Init(&a->next, NULL);
|
5311
|
+
upb_Atomic_Init(&a->tail, a);
|
5312
|
+
upb_Atomic_Init(&a->blocks, NULL);
|
5313
|
+
a->block_alloc = upb_Arena_MakeBlockAlloc(alloc, 1);
|
5240
5314
|
a->head.ptr = mem;
|
5241
5315
|
a->head.end = UPB_PTR_AT(mem, n - sizeof(*a), char);
|
5242
|
-
a->freelist = NULL;
|
5243
|
-
a->freelist_tail = NULL;
|
5244
|
-
a->cleanup_metadata = upb_cleanup_metadata(NULL, true);
|
5245
5316
|
|
5246
5317
|
return a;
|
5247
5318
|
}
|
5248
5319
|
|
5249
5320
|
static void arena_dofree(upb_Arena* a) {
|
5250
|
-
|
5251
|
-
UPB_ASSERT(a->parent == a);
|
5252
|
-
UPB_ASSERT(a->refcount == 0);
|
5253
|
-
|
5254
|
-
while (block) {
|
5255
|
-
/* Load first since we are deleting block. */
|
5256
|
-
_upb_MemBlock* next = block->next;
|
5257
|
-
|
5258
|
-
if (block->cleanups > 0) {
|
5259
|
-
cleanup_ent* end = UPB_PTR_AT(block, block->size, void);
|
5260
|
-
cleanup_ent* ptr = end - block->cleanups;
|
5321
|
+
UPB_ASSERT(_upb_Arena_RefCountFromTagged(a->parent_or_count) == 1);
|
5261
5322
|
|
5262
|
-
|
5263
|
-
|
5264
|
-
|
5323
|
+
while (a != NULL) {
|
5324
|
+
// Load first since arena itself is likely from one of its blocks.
|
5325
|
+
upb_Arena* next_arena =
|
5326
|
+
(upb_Arena*)upb_Atomic_Load(&a->next, memory_order_acquire);
|
5327
|
+
upb_alloc* block_alloc = upb_Arena_BlockAlloc(a);
|
5328
|
+
_upb_MemBlock* block = upb_Atomic_Load(&a->blocks, memory_order_acquire);
|
5329
|
+
while (block != NULL) {
|
5330
|
+
// Load first since we are deleting block.
|
5331
|
+
_upb_MemBlock* next_block =
|
5332
|
+
upb_Atomic_Load(&block->next, memory_order_acquire);
|
5333
|
+
upb_free(block_alloc, block);
|
5334
|
+
block = next_block;
|
5265
5335
|
}
|
5266
|
-
|
5267
|
-
upb_free(a->block_alloc, block);
|
5268
|
-
block = next;
|
5336
|
+
a = next_arena;
|
5269
5337
|
}
|
5270
5338
|
}
|
5271
5339
|
|
5272
5340
|
void upb_Arena_Free(upb_Arena* a) {
|
5273
|
-
|
5274
|
-
|
5275
|
-
|
5276
|
-
|
5277
|
-
|
5278
|
-
|
5279
|
-
|
5341
|
+
uintptr_t poc = upb_Atomic_Load(&a->parent_or_count, memory_order_acquire);
|
5342
|
+
retry:
|
5343
|
+
while (_upb_Arena_IsTaggedPointer(poc)) {
|
5344
|
+
a = _upb_Arena_PointerFromTagged(poc);
|
5345
|
+
poc = upb_Atomic_Load(&a->parent_or_count, memory_order_acquire);
|
5346
|
+
}
|
5347
|
+
|
5348
|
+
// compare_exchange or fetch_sub are RMW operations, which are more
|
5349
|
+
// expensive then direct loads. As an optimization, we only do RMW ops
|
5350
|
+
// when we need to update things for other threads to see.
|
5351
|
+
if (poc == _upb_Arena_TaggedFromRefcount(1)) {
|
5352
|
+
arena_dofree(a);
|
5353
|
+
return;
|
5354
|
+
}
|
5280
5355
|
|
5281
|
-
if (
|
5282
|
-
|
5283
|
-
|
5284
|
-
|
5356
|
+
if (upb_Atomic_CompareExchangeWeak(
|
5357
|
+
&a->parent_or_count, &poc,
|
5358
|
+
_upb_Arena_TaggedFromRefcount(_upb_Arena_RefCountFromTagged(poc) - 1),
|
5359
|
+
memory_order_release, memory_order_acquire)) {
|
5360
|
+
// We were >1 and we decremented it successfully, so we are done.
|
5361
|
+
return;
|
5285
5362
|
}
|
5286
5363
|
|
5287
|
-
|
5288
|
-
|
5289
|
-
|
5290
|
-
|
5364
|
+
// We failed our update, so someone has done something, retry the whole
|
5365
|
+
// process, but the failed exchange reloaded `poc` for us.
|
5366
|
+
goto retry;
|
5367
|
+
}
|
5291
5368
|
|
5292
|
-
|
5293
|
-
|
5369
|
+
static void _upb_Arena_DoFuseArenaLists(upb_Arena* const parent,
|
5370
|
+
upb_Arena* child) {
|
5371
|
+
upb_Arena* parent_tail = upb_Atomic_Load(&parent->tail, memory_order_relaxed);
|
5372
|
+
do {
|
5373
|
+
// Our tail might be stale, but it will always converge to the true tail.
|
5374
|
+
upb_Arena* parent_tail_next =
|
5375
|
+
upb_Atomic_Load(&parent_tail->next, memory_order_relaxed);
|
5376
|
+
while (parent_tail_next != NULL) {
|
5377
|
+
parent_tail = parent_tail_next;
|
5378
|
+
parent_tail_next =
|
5379
|
+
upb_Atomic_Load(&parent_tail->next, memory_order_relaxed);
|
5380
|
+
}
|
5294
5381
|
|
5295
|
-
|
5296
|
-
|
5382
|
+
upb_Arena* displaced =
|
5383
|
+
upb_Atomic_Exchange(&parent_tail->next, child, memory_order_relaxed);
|
5384
|
+
parent_tail = upb_Atomic_Load(&child->tail, memory_order_relaxed);
|
5297
5385
|
|
5298
|
-
|
5299
|
-
|
5300
|
-
|
5386
|
+
// If we displaced something that got installed racily, we can simply
|
5387
|
+
// reinstall it on our new tail.
|
5388
|
+
child = displaced;
|
5389
|
+
} while (child != NULL);
|
5301
5390
|
|
5302
|
-
|
5391
|
+
upb_Atomic_Store(&parent->tail, parent_tail, memory_order_relaxed);
|
5392
|
+
}
|
5303
5393
|
|
5304
|
-
|
5305
|
-
|
5306
|
-
|
5394
|
+
static upb_Arena* _upb_Arena_DoFuse(upb_Arena* a1, upb_Arena* a2,
|
5395
|
+
uintptr_t* ref_delta) {
|
5396
|
+
// `parent_or_count` has two disctint modes
|
5397
|
+
// - parent pointer mode
|
5398
|
+
// - refcount mode
|
5399
|
+
//
|
5400
|
+
// In parent pointer mode, it may change what pointer it refers to in the
|
5401
|
+
// tree, but it will always approach a root. Any operation that walks the
|
5402
|
+
// tree to the root may collapse levels of the tree concurrently.
|
5403
|
+
_upb_ArenaRoot r1 = _upb_Arena_FindRoot(a1);
|
5404
|
+
_upb_ArenaRoot r2 = _upb_Arena_FindRoot(a2);
|
5307
5405
|
|
5308
|
-
|
5309
|
-
if (r1->block_alloc != r2->block_alloc) return false;
|
5406
|
+
if (r1.root == r2.root) return r1.root; // Already fused.
|
5310
5407
|
|
5311
|
-
|
5312
|
-
|
5313
|
-
|
5314
|
-
upb_Arena* tmp = r1;
|
5408
|
+
// Avoid cycles by always fusing into the root with the lower address.
|
5409
|
+
if ((uintptr_t)r1.root > (uintptr_t)r2.root) {
|
5410
|
+
_upb_ArenaRoot tmp = r1;
|
5315
5411
|
r1 = r2;
|
5316
5412
|
r2 = tmp;
|
5317
5413
|
}
|
5318
5414
|
|
5319
|
-
|
5320
|
-
r1
|
5321
|
-
|
5322
|
-
|
5323
|
-
|
5324
|
-
|
5325
|
-
|
5326
|
-
r2
|
5327
|
-
|
5328
|
-
|
5329
|
-
|
5330
|
-
|
5331
|
-
|
5332
|
-
|
5333
|
-
|
5334
|
-
|
5335
|
-
|
5336
|
-
|
5337
|
-
|
5338
|
-
const upb_MiniTable* mini_table, upb_Message* base_message,
|
5339
|
-
int decode_options, upb_Arena* arena) {
|
5340
|
-
upb_UnknownToMessageRet ret;
|
5341
|
-
ret.message =
|
5342
|
-
base_message ? base_message : _upb_Message_New(mini_table, arena);
|
5343
|
-
if (!ret.message) {
|
5344
|
-
ret.status = kUpb_UnknownToMessage_OutOfMemory;
|
5345
|
-
return ret;
|
5346
|
-
}
|
5347
|
-
// Decode sub message using unknown field contents.
|
5348
|
-
const char* data = unknown_data;
|
5349
|
-
uint32_t tag;
|
5350
|
-
uint64_t message_len = 0;
|
5351
|
-
data = upb_WireReader_ReadTag(data, &tag);
|
5352
|
-
data = upb_WireReader_ReadVarint(data, &message_len);
|
5353
|
-
upb_DecodeStatus status = upb_Decode(data, message_len, ret.message,
|
5354
|
-
mini_table, NULL, decode_options, arena);
|
5355
|
-
if (status == kUpb_DecodeStatus_OutOfMemory) {
|
5356
|
-
ret.status = kUpb_UnknownToMessage_OutOfMemory;
|
5357
|
-
} else if (status == kUpb_DecodeStatus_Ok) {
|
5358
|
-
ret.status = kUpb_UnknownToMessage_Ok;
|
5359
|
-
} else {
|
5360
|
-
ret.status = kUpb_UnknownToMessage_ParseError;
|
5415
|
+
// The moment we install `r1` as the parent for `r2` all racing frees may
|
5416
|
+
// immediately begin decrementing `r1`'s refcount (including pending
|
5417
|
+
// increments to that refcount and their frees!). We need to add `r2`'s refs
|
5418
|
+
// now, so that `r1` can withstand any unrefs that come from r2.
|
5419
|
+
//
|
5420
|
+
// Note that while it is possible for `r2`'s refcount to increase
|
5421
|
+
// asynchronously, we will not actually do the reparenting operation below
|
5422
|
+
// unless `r2`'s refcount is unchanged from when we read it.
|
5423
|
+
//
|
5424
|
+
// Note that we may have done this previously, either to this node or a
|
5425
|
+
// different node, during a previous and failed DoFuse() attempt. But we will
|
5426
|
+
// not lose track of these refs because we always add them to our overall
|
5427
|
+
// delta.
|
5428
|
+
uintptr_t r2_untagged_count = r2.tagged_count & ~1;
|
5429
|
+
uintptr_t with_r2_refs = r1.tagged_count + r2_untagged_count;
|
5430
|
+
if (!upb_Atomic_CompareExchangeStrong(
|
5431
|
+
&r1.root->parent_or_count, &r1.tagged_count, with_r2_refs,
|
5432
|
+
memory_order_release, memory_order_acquire)) {
|
5433
|
+
return NULL;
|
5361
5434
|
}
|
5362
|
-
return ret;
|
5363
|
-
}
|
5364
5435
|
|
5365
|
-
|
5366
|
-
|
5367
|
-
|
5368
|
-
|
5369
|
-
|
5370
|
-
|
5371
|
-
|
5372
|
-
|
5436
|
+
// Perform the actual fuse by removing the refs from `r2` and swapping in the
|
5437
|
+
// parent pointer.
|
5438
|
+
if (!upb_Atomic_CompareExchangeStrong(
|
5439
|
+
&r2.root->parent_or_count, &r2.tagged_count,
|
5440
|
+
_upb_Arena_TaggedFromPointer(r1.root), memory_order_release,
|
5441
|
+
memory_order_acquire)) {
|
5442
|
+
// We'll need to remove the excess refs we added to r1 previously.
|
5443
|
+
*ref_delta += r2_untagged_count;
|
5444
|
+
return NULL;
|
5373
5445
|
}
|
5374
5446
|
|
5375
|
-
//
|
5376
|
-
|
5377
|
-
|
5378
|
-
|
5379
|
-
return kUpb_GetExtension_NotPresent;
|
5380
|
-
}
|
5381
|
-
size_t len;
|
5382
|
-
size_t ofs = result.ptr - upb_Message_GetUnknown(msg, &len);
|
5383
|
-
// Decode and promote from unknown.
|
5384
|
-
const upb_MiniTable* extension_table = ext_table->sub.submsg;
|
5385
|
-
upb_UnknownToMessageRet parse_result = upb_MiniTable_ParseUnknownMessage(
|
5386
|
-
result.ptr, result.len, extension_table,
|
5387
|
-
/* base_message= */ NULL, decode_options, arena);
|
5388
|
-
switch (parse_result.status) {
|
5389
|
-
case kUpb_UnknownToMessage_OutOfMemory:
|
5390
|
-
return kUpb_GetExtension_OutOfMemory;
|
5391
|
-
case kUpb_UnknownToMessage_ParseError:
|
5392
|
-
return kUpb_GetExtension_ParseError;
|
5393
|
-
case kUpb_UnknownToMessage_NotFound:
|
5394
|
-
return kUpb_GetExtension_NotPresent;
|
5395
|
-
case kUpb_UnknownToMessage_Ok:
|
5396
|
-
break;
|
5397
|
-
}
|
5398
|
-
upb_Message* extension_msg = parse_result.message;
|
5399
|
-
// Add to extensions.
|
5400
|
-
upb_Message_Extension* ext =
|
5401
|
-
_upb_Message_GetOrCreateExtension(msg, ext_table, arena);
|
5402
|
-
if (!ext) {
|
5403
|
-
return kUpb_GetExtension_OutOfMemory;
|
5404
|
-
}
|
5405
|
-
memcpy(&ext->data, &extension_msg, sizeof(extension_msg));
|
5406
|
-
*extension = ext;
|
5407
|
-
const char* delete_ptr = upb_Message_GetUnknown(msg, &len) + ofs;
|
5408
|
-
upb_Message_DeleteUnknown(msg, delete_ptr, result.len);
|
5409
|
-
return kUpb_GetExtension_Ok;
|
5410
|
-
}
|
5411
|
-
|
5412
|
-
upb_GetExtensionAsBytes_Status upb_MiniTable_GetExtensionAsBytes(
|
5413
|
-
const upb_Message* msg, const upb_MiniTableExtension* ext_table,
|
5414
|
-
int encode_options, upb_Arena* arena, const char** extension_data,
|
5415
|
-
size_t* len) {
|
5416
|
-
const upb_Message_Extension* msg_ext = _upb_Message_Getext(msg, ext_table);
|
5417
|
-
UPB_ASSERT(ext_table->field.descriptortype == kUpb_FieldType_Message);
|
5418
|
-
if (msg_ext) {
|
5419
|
-
upb_EncodeStatus status =
|
5420
|
-
upb_Encode(msg_ext->data.ptr, msg_ext->ext->sub.submsg, encode_options,
|
5421
|
-
arena, (char**)extension_data, len);
|
5422
|
-
if (status != kUpb_EncodeStatus_Ok) {
|
5423
|
-
return kUpb_GetExtensionAsBytes_EncodeError;
|
5424
|
-
}
|
5425
|
-
return kUpb_GetExtensionAsBytes_Ok;
|
5426
|
-
}
|
5427
|
-
int field_number = ext_table->field.number;
|
5428
|
-
upb_FindUnknownRet result = upb_MiniTable_FindUnknown(msg, field_number);
|
5429
|
-
if (result.status != kUpb_FindUnknown_Ok) {
|
5430
|
-
return kUpb_GetExtensionAsBytes_NotPresent;
|
5431
|
-
}
|
5432
|
-
const char* data = result.ptr;
|
5433
|
-
uint32_t tag;
|
5434
|
-
uint64_t message_len = 0;
|
5435
|
-
data = upb_WireReader_ReadTag(data, &tag);
|
5436
|
-
data = upb_WireReader_ReadVarint(data, &message_len);
|
5437
|
-
*extension_data = data;
|
5438
|
-
*len = message_len;
|
5439
|
-
return kUpb_GetExtensionAsBytes_Ok;
|
5447
|
+
// Now that the fuse has been performed (and can no longer fail) we need to
|
5448
|
+
// append `r2` to `r1`'s linked list.
|
5449
|
+
_upb_Arena_DoFuseArenaLists(r1.root, r2.root);
|
5450
|
+
return r1.root;
|
5440
5451
|
}
|
5441
5452
|
|
5442
|
-
static
|
5443
|
-
|
5453
|
+
static bool _upb_Arena_FixupRefs(upb_Arena* new_root, uintptr_t ref_delta) {
|
5454
|
+
if (ref_delta == 0) return true; // No fixup required.
|
5455
|
+
uintptr_t poc =
|
5456
|
+
upb_Atomic_Load(&new_root->parent_or_count, memory_order_relaxed);
|
5457
|
+
if (_upb_Arena_IsTaggedPointer(poc)) return false;
|
5458
|
+
uintptr_t with_refs = poc - ref_delta;
|
5459
|
+
UPB_ASSERT(!_upb_Arena_IsTaggedPointer(with_refs));
|
5460
|
+
return upb_Atomic_CompareExchangeStrong(&new_root->parent_or_count, &poc,
|
5461
|
+
with_refs, memory_order_relaxed,
|
5462
|
+
memory_order_relaxed);
|
5444
5463
|
}
|
5445
5464
|
|
5446
|
-
|
5447
|
-
|
5448
|
-
const int depth_limit = 100; // TODO: this should be a parameter
|
5449
|
-
size_t size;
|
5450
|
-
upb_FindUnknownRet ret;
|
5451
|
-
|
5452
|
-
const char* ptr = upb_Message_GetUnknown(msg, &size);
|
5453
|
-
upb_EpsCopyInputStream stream;
|
5454
|
-
upb_EpsCopyInputStream_Init(&stream, &ptr, size, true);
|
5455
|
-
|
5456
|
-
while (!upb_EpsCopyInputStream_IsDone(&stream, &ptr)) {
|
5457
|
-
uint32_t tag;
|
5458
|
-
const char* unknown_begin = ptr;
|
5459
|
-
ptr = upb_WireReader_ReadTag(ptr, &tag);
|
5460
|
-
if (!ptr) return upb_FindUnknownRet_ParseError();
|
5461
|
-
if (field_number == upb_WireReader_GetFieldNumber(tag)) {
|
5462
|
-
ret.status = kUpb_FindUnknown_Ok;
|
5463
|
-
ret.ptr = upb_EpsCopyInputStream_GetAliasedPtr(&stream, unknown_begin);
|
5464
|
-
ptr = _upb_WireReader_SkipValue(ptr, tag, depth_limit, &stream);
|
5465
|
-
// Because we know that the input is a flat buffer, it is safe to perform
|
5466
|
-
// pointer arithmetic on aliased pointers.
|
5467
|
-
ret.len = upb_EpsCopyInputStream_GetAliasedPtr(&stream, ptr) - ret.ptr;
|
5468
|
-
return ret;
|
5469
|
-
}
|
5465
|
+
bool upb_Arena_Fuse(upb_Arena* a1, upb_Arena* a2) {
|
5466
|
+
if (a1 == a2) return true; // trivial fuse
|
5470
5467
|
|
5471
|
-
|
5472
|
-
|
5468
|
+
// Do not fuse initial blocks since we cannot lifetime extend them.
|
5469
|
+
// Any other fuse scenario is allowed.
|
5470
|
+
if (upb_Arena_HasInitialBlock(a1) || upb_Arena_HasInitialBlock(a2)) {
|
5471
|
+
return false;
|
5473
5472
|
}
|
5474
|
-
ret.status = kUpb_FindUnknown_NotPresent;
|
5475
|
-
ret.ptr = NULL;
|
5476
|
-
ret.len = 0;
|
5477
|
-
return ret;
|
5478
|
-
}
|
5479
5473
|
|
5480
|
-
//
|
5481
|
-
|
5482
|
-
|
5483
|
-
|
5484
|
-
|
5485
|
-
|
5486
|
-
// We need to loop and merge unknowns that have matching tag field->number.
|
5487
|
-
upb_Message* message = NULL;
|
5488
|
-
// Callers should check that message is not set first before calling
|
5489
|
-
// PromotoUnknownToMessage.
|
5490
|
-
UPB_ASSERT(mini_table->subs[field->submsg_index].submsg == sub_mini_table);
|
5491
|
-
bool is_oneof = _upb_MiniTableField_InOneOf(field);
|
5492
|
-
if (!is_oneof || _upb_getoneofcase_field(msg, field) == field->number) {
|
5493
|
-
UPB_ASSERT(upb_Message_GetMessage(msg, field, NULL) == NULL);
|
5494
|
-
}
|
5495
|
-
upb_UnknownToMessageRet ret;
|
5496
|
-
ret.status = kUpb_UnknownToMessage_Ok;
|
5497
|
-
do {
|
5498
|
-
unknown = upb_MiniTable_FindUnknown(msg, field->number);
|
5499
|
-
switch (unknown.status) {
|
5500
|
-
case kUpb_FindUnknown_Ok: {
|
5501
|
-
const char* unknown_data = unknown.ptr;
|
5502
|
-
size_t unknown_size = unknown.len;
|
5503
|
-
ret = upb_MiniTable_ParseUnknownMessage(unknown_data, unknown_size,
|
5504
|
-
sub_mini_table, message,
|
5505
|
-
decode_options, arena);
|
5506
|
-
if (ret.status == kUpb_UnknownToMessage_Ok) {
|
5507
|
-
message = ret.message;
|
5508
|
-
upb_Message_DeleteUnknown(msg, unknown_data, unknown_size);
|
5509
|
-
}
|
5510
|
-
} break;
|
5511
|
-
case kUpb_FindUnknown_ParseError:
|
5512
|
-
ret.status = kUpb_UnknownToMessage_ParseError;
|
5513
|
-
break;
|
5514
|
-
case kUpb_FindUnknown_NotPresent:
|
5515
|
-
// If we parsed at least one unknown, we are done.
|
5516
|
-
ret.status =
|
5517
|
-
message ? kUpb_UnknownToMessage_Ok : kUpb_UnknownToMessage_NotFound;
|
5518
|
-
break;
|
5519
|
-
}
|
5520
|
-
} while (unknown.status == kUpb_FindUnknown_Ok);
|
5521
|
-
if (message) {
|
5522
|
-
if (is_oneof) {
|
5523
|
-
*_upb_oneofcase_field(msg, field) = field->number;
|
5474
|
+
// The number of refs we ultimately need to transfer to the new root.
|
5475
|
+
uintptr_t ref_delta = 0;
|
5476
|
+
while (true) {
|
5477
|
+
upb_Arena* new_root = _upb_Arena_DoFuse(a1, a2, &ref_delta);
|
5478
|
+
if (new_root != NULL && _upb_Arena_FixupRefs(new_root, ref_delta)) {
|
5479
|
+
return true;
|
5524
5480
|
}
|
5525
|
-
upb_Message_SetMessage(msg, mini_table, field, message);
|
5526
|
-
ret.message = message;
|
5527
5481
|
}
|
5528
|
-
return ret;
|
5529
5482
|
}
|
5530
5483
|
|
5531
|
-
|
5532
|
-
|
5533
|
-
//
|
5534
|
-
// kUpb_LabelFlags_IsPacked.
|
5535
|
-
// TODO(b/251007554): Optimize. Instead of converting messages one at a time,
|
5536
|
-
// scan all unknown data once and compact.
|
5537
|
-
upb_UnknownToMessage_Status upb_MiniTable_PromoteUnknownToMessageArray(
|
5538
|
-
upb_Message* msg, const upb_MiniTableField* field,
|
5539
|
-
const upb_MiniTable* mini_table, int decode_options, upb_Arena* arena) {
|
5540
|
-
upb_Array* repeated_messages = upb_Message_GetMutableArray(msg, field);
|
5541
|
-
// Find all unknowns with given field number and parse.
|
5542
|
-
upb_FindUnknownRet unknown;
|
5543
|
-
do {
|
5544
|
-
unknown = upb_MiniTable_FindUnknown(msg, field->number);
|
5545
|
-
if (unknown.status == kUpb_FindUnknown_Ok) {
|
5546
|
-
upb_UnknownToMessageRet ret = upb_MiniTable_ParseUnknownMessage(
|
5547
|
-
unknown.ptr, unknown.len, mini_table,
|
5548
|
-
/* base_message= */ NULL, decode_options, arena);
|
5549
|
-
if (ret.status == kUpb_UnknownToMessage_Ok) {
|
5550
|
-
upb_MessageValue value;
|
5551
|
-
value.msg_val = ret.message;
|
5552
|
-
// Allocate array on demand before append.
|
5553
|
-
if (!repeated_messages) {
|
5554
|
-
upb_Message_ResizeArray(msg, field, 0, arena);
|
5555
|
-
repeated_messages = upb_Message_GetMutableArray(msg, field);
|
5556
|
-
}
|
5557
|
-
if (!upb_Array_Append(repeated_messages, value, arena)) {
|
5558
|
-
return kUpb_UnknownToMessage_OutOfMemory;
|
5559
|
-
}
|
5560
|
-
upb_Message_DeleteUnknown(msg, unknown.ptr, unknown.len);
|
5561
|
-
} else {
|
5562
|
-
return ret.status;
|
5563
|
-
}
|
5564
|
-
}
|
5565
|
-
} while (unknown.status == kUpb_FindUnknown_Ok);
|
5566
|
-
return kUpb_UnknownToMessage_Ok;
|
5567
|
-
}
|
5484
|
+
|
5485
|
+
|
5486
|
+
// Must be last.
|
5568
5487
|
|
5569
5488
|
upb_MapInsertStatus upb_Message_InsertMapEntry(upb_Map* map,
|
5570
5489
|
const upb_MiniTable* mini_table,
|
@@ -5572,7 +5491,7 @@ upb_MapInsertStatus upb_Message_InsertMapEntry(upb_Map* map,
|
|
5572
5491
|
upb_Message* map_entry_message,
|
5573
5492
|
upb_Arena* arena) {
|
5574
5493
|
const upb_MiniTable* map_entry_mini_table =
|
5575
|
-
mini_table->subs[field->submsg_index].submsg;
|
5494
|
+
mini_table->subs[field->UPB_PRIVATE(submsg_index)].submsg;
|
5576
5495
|
UPB_ASSERT(map_entry_mini_table);
|
5577
5496
|
UPB_ASSERT(map_entry_mini_table->field_count == 2);
|
5578
5497
|
const upb_MiniTableField* map_entry_key_field =
|
@@ -5592,41 +5511,6 @@ upb_MapInsertStatus upb_Message_InsertMapEntry(upb_Map* map,
|
|
5592
5511
|
return upb_Map_Insert(map, map_entry_key, map_entry_value, arena);
|
5593
5512
|
}
|
5594
5513
|
|
5595
|
-
// Moves repeated messages in unknowns to a upb_Map.
|
5596
|
-
upb_UnknownToMessage_Status upb_MiniTable_PromoteUnknownToMap(
|
5597
|
-
upb_Message* msg, const upb_MiniTable* mini_table,
|
5598
|
-
const upb_MiniTableField* field, int decode_options, upb_Arena* arena) {
|
5599
|
-
const upb_MiniTable* map_entry_mini_table =
|
5600
|
-
mini_table->subs[field->submsg_index].submsg;
|
5601
|
-
UPB_ASSERT(map_entry_mini_table);
|
5602
|
-
UPB_ASSERT(map_entry_mini_table);
|
5603
|
-
UPB_ASSERT(map_entry_mini_table->field_count == 2);
|
5604
|
-
UPB_ASSERT(upb_FieldMode_Get(field) == kUpb_FieldMode_Map);
|
5605
|
-
// Find all unknowns with given field number and parse.
|
5606
|
-
upb_FindUnknownRet unknown;
|
5607
|
-
while (1) {
|
5608
|
-
unknown = upb_MiniTable_FindUnknown(msg, field->number);
|
5609
|
-
if (unknown.status != kUpb_FindUnknown_Ok) break;
|
5610
|
-
upb_UnknownToMessageRet ret = upb_MiniTable_ParseUnknownMessage(
|
5611
|
-
unknown.ptr, unknown.len, map_entry_mini_table,
|
5612
|
-
/* base_message= */ NULL, decode_options, arena);
|
5613
|
-
if (ret.status != kUpb_UnknownToMessage_Ok) return ret.status;
|
5614
|
-
// Allocate map on demand before append.
|
5615
|
-
upb_Map* map = upb_Message_GetOrCreateMutableMap(msg, map_entry_mini_table,
|
5616
|
-
field, arena);
|
5617
|
-
upb_Message* map_entry_message = ret.message;
|
5618
|
-
upb_MapInsertStatus insert_status = upb_Message_InsertMapEntry(
|
5619
|
-
map, mini_table, field, map_entry_message, arena);
|
5620
|
-
if (insert_status == kUpb_MapInsertStatus_OutOfMemory) {
|
5621
|
-
return kUpb_UnknownToMessage_OutOfMemory;
|
5622
|
-
}
|
5623
|
-
UPB_ASSUME(insert_status == kUpb_MapInsertStatus_Inserted ||
|
5624
|
-
insert_status == kUpb_MapInsertStatus_Replaced);
|
5625
|
-
upb_Message_DeleteUnknown(msg, unknown.ptr, unknown.len);
|
5626
|
-
}
|
5627
|
-
return kUpb_UnknownToMessage_Ok;
|
5628
|
-
}
|
5629
|
-
|
5630
5514
|
|
5631
5515
|
#include <math.h>
|
5632
5516
|
|
@@ -5816,7 +5700,7 @@ const upb_MiniTableField* upb_MiniTable_FindFieldByNumber(
|
|
5816
5700
|
int hi = t->field_count - 1;
|
5817
5701
|
while (lo <= hi) {
|
5818
5702
|
int mid = (lo + hi) / 2;
|
5819
|
-
|
5703
|
+
uint32_t num = t->fields[mid].number;
|
5820
5704
|
if (num < number) {
|
5821
5705
|
lo = mid + 1;
|
5822
5706
|
continue;
|
@@ -5832,15 +5716,15 @@ const upb_MiniTableField* upb_MiniTable_FindFieldByNumber(
|
|
5832
5716
|
|
5833
5717
|
upb_FieldType upb_MiniTableField_Type(const upb_MiniTableField* field) {
|
5834
5718
|
if (field->mode & kUpb_LabelFlags_IsAlternate) {
|
5835
|
-
if (field->descriptortype == kUpb_FieldType_Int32) {
|
5719
|
+
if (field->UPB_PRIVATE(descriptortype) == kUpb_FieldType_Int32) {
|
5836
5720
|
return kUpb_FieldType_Enum;
|
5837
|
-
} else if (field->descriptortype == kUpb_FieldType_Bytes) {
|
5721
|
+
} else if (field->UPB_PRIVATE(descriptortype) == kUpb_FieldType_Bytes) {
|
5838
5722
|
return kUpb_FieldType_String;
|
5839
5723
|
} else {
|
5840
5724
|
UPB_ASSERT(false);
|
5841
5725
|
}
|
5842
5726
|
}
|
5843
|
-
return field->descriptortype;
|
5727
|
+
return field->UPB_PRIVATE(descriptortype);
|
5844
5728
|
}
|
5845
5729
|
|
5846
5730
|
static bool upb_MiniTable_Is_Oneof(const upb_MiniTableField* f) {
|
@@ -5979,14 +5863,14 @@ static const char* upb_MiniTable_DecodeBase92Varint(upb_MtDecoder* d,
|
|
5979
5863
|
|
5980
5864
|
static bool upb_MiniTable_HasSub(upb_MiniTableField* field,
|
5981
5865
|
uint64_t msg_modifiers) {
|
5982
|
-
switch (field->descriptortype) {
|
5866
|
+
switch (field->UPB_PRIVATE(descriptortype)) {
|
5983
5867
|
case kUpb_FieldType_Message:
|
5984
5868
|
case kUpb_FieldType_Group:
|
5985
5869
|
case kUpb_FieldType_Enum:
|
5986
5870
|
return true;
|
5987
5871
|
case kUpb_FieldType_String:
|
5988
5872
|
if (!(msg_modifiers & kUpb_MessageModifier_ValidateUtf8)) {
|
5989
|
-
field->descriptortype = kUpb_FieldType_Bytes;
|
5873
|
+
field->UPB_PRIVATE(descriptortype) = kUpb_FieldType_Bytes;
|
5990
5874
|
field->mode |= kUpb_LabelFlags_IsAlternate;
|
5991
5875
|
}
|
5992
5876
|
return false;
|
@@ -5997,25 +5881,25 @@ static bool upb_MiniTable_HasSub(upb_MiniTableField* field,
|
|
5997
5881
|
|
5998
5882
|
static bool upb_MtDecoder_FieldIsPackable(upb_MiniTableField* field) {
|
5999
5883
|
return (field->mode & kUpb_FieldMode_Array) &&
|
6000
|
-
|
5884
|
+
upb_FieldType_IsPackable(field->UPB_PRIVATE(descriptortype));
|
6001
5885
|
}
|
6002
5886
|
|
6003
5887
|
static void upb_MiniTable_SetTypeAndSub(upb_MiniTableField* field,
|
6004
5888
|
upb_FieldType type, uint32_t* sub_count,
|
6005
5889
|
uint64_t msg_modifiers,
|
6006
5890
|
bool is_proto3_enum) {
|
6007
|
-
field->descriptortype = type;
|
5891
|
+
field->UPB_PRIVATE(descriptortype) = type;
|
6008
5892
|
|
6009
5893
|
if (is_proto3_enum) {
|
6010
|
-
UPB_ASSERT(field->descriptortype == kUpb_FieldType_Enum);
|
6011
|
-
field->descriptortype = kUpb_FieldType_Int32;
|
5894
|
+
UPB_ASSERT(field->UPB_PRIVATE(descriptortype) == kUpb_FieldType_Enum);
|
5895
|
+
field->UPB_PRIVATE(descriptortype) = kUpb_FieldType_Int32;
|
6012
5896
|
field->mode |= kUpb_LabelFlags_IsAlternate;
|
6013
5897
|
}
|
6014
5898
|
|
6015
5899
|
if (upb_MiniTable_HasSub(field, msg_modifiers)) {
|
6016
|
-
field->submsg_index = sub_count ? (*sub_count)++ : 0;
|
5900
|
+
field->UPB_PRIVATE(submsg_index) = sub_count ? (*sub_count)++ : 0;
|
6017
5901
|
} else {
|
6018
|
-
field->submsg_index = kUpb_NoSub;
|
5902
|
+
field->UPB_PRIVATE(submsg_index) = kUpb_NoSub;
|
6019
5903
|
}
|
6020
5904
|
|
6021
5905
|
if (upb_MtDecoder_FieldIsPackable(field) &&
|
@@ -6085,14 +5969,14 @@ static void upb_MiniTable_SetField(upb_MtDecoder* d, uint8_t ch,
|
|
6085
5969
|
field->offset = kHasbitPresence;
|
6086
5970
|
if (type == kUpb_EncodedType_Group || type == kUpb_EncodedType_Message) {
|
6087
5971
|
field->mode |= pointer_rep << kUpb_FieldRep_Shift;
|
6088
|
-
} else if (type >= sizeof(kUpb_EncodedToFieldRep)) {
|
5972
|
+
} else if ((unsigned long)type >= sizeof(kUpb_EncodedToFieldRep)) {
|
6089
5973
|
upb_MtDecoder_ErrorFormat(d, "Invalid field type: %d", (int)type);
|
6090
5974
|
UPB_UNREACHABLE();
|
6091
5975
|
} else {
|
6092
5976
|
field->mode |= kUpb_EncodedToFieldRep[type] << kUpb_FieldRep_Shift;
|
6093
5977
|
}
|
6094
5978
|
}
|
6095
|
-
if (type >= sizeof(kUpb_EncodedToType)) {
|
5979
|
+
if ((unsigned long)type >= sizeof(kUpb_EncodedToType)) {
|
6096
5980
|
upb_MtDecoder_ErrorFormat(d, "Invalid field type: %d", (int)type);
|
6097
5981
|
UPB_UNREACHABLE();
|
6098
5982
|
}
|
@@ -6508,7 +6392,7 @@ static void upb_MtDecoder_AssignOffsets(upb_MtDecoder* d) {
|
|
6508
6392
|
|
6509
6393
|
static void upb_MtDecoder_ValidateEntryField(upb_MtDecoder* d,
|
6510
6394
|
const upb_MiniTableField* f,
|
6511
|
-
|
6395
|
+
uint32_t expected_num) {
|
6512
6396
|
const char* name = expected_num == 1 ? "key" : "val";
|
6513
6397
|
if (f->number != expected_num) {
|
6514
6398
|
upb_MtDecoder_ErrorFormat(d,
|
@@ -6532,7 +6416,7 @@ static void upb_MtDecoder_ValidateEntryField(upb_MtDecoder* d,
|
|
6532
6416
|
|
6533
6417
|
if ((1 << upb_MiniTableField_Type(f)) & not_ok_types) {
|
6534
6418
|
upb_MtDecoder_ErrorFormat(d, "map %s cannot have type %d", name,
|
6535
|
-
(int)f->descriptortype);
|
6419
|
+
(int)f->UPB_PRIVATE(descriptortype));
|
6536
6420
|
}
|
6537
6421
|
}
|
6538
6422
|
|
@@ -6585,37 +6469,17 @@ static void upb_MtDecoder_ParseMessageSet(upb_MtDecoder* d, const char* data,
|
|
6585
6469
|
ret->required_count = 0;
|
6586
6470
|
}
|
6587
6471
|
|
6588
|
-
upb_MiniTable*
|
6589
|
-
|
6590
|
-
|
6591
|
-
|
6592
|
-
upb_Status* status) {
|
6593
|
-
upb_MtDecoder decoder = {
|
6594
|
-
.platform = platform,
|
6595
|
-
.vec =
|
6596
|
-
{
|
6597
|
-
.data = *buf,
|
6598
|
-
.capacity = *buf_size / sizeof(*decoder.vec.data),
|
6599
|
-
.size = 0,
|
6600
|
-
},
|
6601
|
-
.arena = arena,
|
6602
|
-
.status = status,
|
6603
|
-
.table = upb_Arena_Malloc(arena, sizeof(*decoder.table)),
|
6604
|
-
};
|
6605
|
-
|
6606
|
-
if (UPB_SETJMP(decoder.err)) {
|
6607
|
-
decoder.table = NULL;
|
6608
|
-
goto done;
|
6609
|
-
}
|
6472
|
+
static upb_MiniTable* upb_MtDecoder_DoBuildMiniTableWithBuf(
|
6473
|
+
upb_MtDecoder* decoder, const char* data, size_t len, void** buf,
|
6474
|
+
size_t* buf_size) {
|
6475
|
+
upb_MtDecoder_CheckOutOfMemory(decoder, decoder->table);
|
6610
6476
|
|
6611
|
-
|
6612
|
-
|
6613
|
-
decoder
|
6614
|
-
decoder
|
6615
|
-
decoder
|
6616
|
-
decoder
|
6617
|
-
decoder.table->table_mask = -1;
|
6618
|
-
decoder.table->required_count = 0;
|
6477
|
+
decoder->table->size = 0;
|
6478
|
+
decoder->table->field_count = 0;
|
6479
|
+
decoder->table->ext = kUpb_ExtMode_NonExtendable;
|
6480
|
+
decoder->table->dense_below = 0;
|
6481
|
+
decoder->table->table_mask = -1;
|
6482
|
+
decoder->table->required_count = 0;
|
6619
6483
|
|
6620
6484
|
// Strip off and verify the version tag.
|
6621
6485
|
if (!len--) goto done;
|
@@ -6623,29 +6487,64 @@ upb_MiniTable* upb_MiniTable_BuildWithBuf(const char* data, size_t len,
|
|
6623
6487
|
|
6624
6488
|
switch (vers) {
|
6625
6489
|
case kUpb_EncodedVersion_MapV1:
|
6626
|
-
upb_MtDecoder_ParseMap(
|
6490
|
+
upb_MtDecoder_ParseMap(decoder, data, len);
|
6627
6491
|
break;
|
6628
6492
|
|
6629
6493
|
case kUpb_EncodedVersion_MessageV1:
|
6630
|
-
upb_MtDecoder_ParseMessage(
|
6631
|
-
upb_MtDecoder_AssignHasbits(decoder
|
6632
|
-
upb_MtDecoder_SortLayoutItems(
|
6633
|
-
upb_MtDecoder_AssignOffsets(
|
6494
|
+
upb_MtDecoder_ParseMessage(decoder, data, len);
|
6495
|
+
upb_MtDecoder_AssignHasbits(decoder->table);
|
6496
|
+
upb_MtDecoder_SortLayoutItems(decoder);
|
6497
|
+
upb_MtDecoder_AssignOffsets(decoder);
|
6634
6498
|
break;
|
6635
6499
|
|
6636
6500
|
case kUpb_EncodedVersion_MessageSetV1:
|
6637
|
-
upb_MtDecoder_ParseMessageSet(
|
6501
|
+
upb_MtDecoder_ParseMessageSet(decoder, data, len);
|
6638
6502
|
break;
|
6639
6503
|
|
6640
6504
|
default:
|
6641
|
-
upb_MtDecoder_ErrorFormat(
|
6505
|
+
upb_MtDecoder_ErrorFormat(decoder, "Invalid message version: %c", vers);
|
6642
6506
|
UPB_UNREACHABLE();
|
6643
6507
|
}
|
6644
6508
|
|
6645
6509
|
done:
|
6646
|
-
*buf = decoder
|
6647
|
-
*buf_size = decoder
|
6648
|
-
return decoder
|
6510
|
+
*buf = decoder->vec.data;
|
6511
|
+
*buf_size = decoder->vec.capacity * sizeof(*decoder->vec.data);
|
6512
|
+
return decoder->table;
|
6513
|
+
}
|
6514
|
+
|
6515
|
+
static upb_MiniTable* upb_MtDecoder_BuildMiniTableWithBuf(
|
6516
|
+
upb_MtDecoder* const decoder, const char* const data, const size_t len,
|
6517
|
+
void** const buf, size_t* const buf_size) {
|
6518
|
+
if (UPB_SETJMP(decoder->err) != 0) {
|
6519
|
+
*buf = decoder->vec.data;
|
6520
|
+
*buf_size = decoder->vec.capacity * sizeof(*decoder->vec.data);
|
6521
|
+
return NULL;
|
6522
|
+
}
|
6523
|
+
|
6524
|
+
return upb_MtDecoder_DoBuildMiniTableWithBuf(decoder, data, len, buf,
|
6525
|
+
buf_size);
|
6526
|
+
}
|
6527
|
+
|
6528
|
+
upb_MiniTable* upb_MiniTable_BuildWithBuf(const char* data, size_t len,
|
6529
|
+
upb_MiniTablePlatform platform,
|
6530
|
+
upb_Arena* arena, void** buf,
|
6531
|
+
size_t* buf_size,
|
6532
|
+
upb_Status* status) {
|
6533
|
+
upb_MtDecoder decoder = {
|
6534
|
+
.platform = platform,
|
6535
|
+
.vec =
|
6536
|
+
{
|
6537
|
+
.data = *buf,
|
6538
|
+
.capacity = *buf_size / sizeof(*decoder.vec.data),
|
6539
|
+
.size = 0,
|
6540
|
+
},
|
6541
|
+
.arena = arena,
|
6542
|
+
.status = status,
|
6543
|
+
.table = upb_Arena_Malloc(arena, sizeof(*decoder.table)),
|
6544
|
+
};
|
6545
|
+
|
6546
|
+
return upb_MtDecoder_BuildMiniTableWithBuf(&decoder, data, len, buf,
|
6547
|
+
buf_size);
|
6649
6548
|
}
|
6650
6549
|
|
6651
6550
|
static size_t upb_MiniTableEnum_Size(size_t count) {
|
@@ -6684,85 +6583,83 @@ static void upb_MiniTableEnum_BuildValue(upb_MtDecoder* d, uint32_t val) {
|
|
6684
6583
|
}
|
6685
6584
|
}
|
6686
6585
|
|
6687
|
-
upb_MiniTableEnum*
|
6688
|
-
|
6689
|
-
upb_Status* status) {
|
6690
|
-
upb_MtDecoder decoder = {
|
6691
|
-
.enum_table = upb_Arena_Malloc(arena, upb_MiniTableEnum_Size(2)),
|
6692
|
-
.enum_value_count = 0,
|
6693
|
-
.enum_data_count = 0,
|
6694
|
-
.enum_data_capacity = 1,
|
6695
|
-
.status = status,
|
6696
|
-
.end = UPB_PTRADD(data, len),
|
6697
|
-
.arena = arena,
|
6698
|
-
};
|
6699
|
-
|
6700
|
-
if (UPB_SETJMP(decoder.err)) return NULL;
|
6701
|
-
|
6586
|
+
static upb_MiniTableEnum* upb_MtDecoder_DoBuildMiniTableEnum(
|
6587
|
+
upb_MtDecoder* decoder, const char* data, size_t len) {
|
6702
6588
|
// If the string is non-empty then it must begin with a version tag.
|
6703
6589
|
if (len) {
|
6704
6590
|
if (*data != kUpb_EncodedVersion_EnumV1) {
|
6705
|
-
upb_MtDecoder_ErrorFormat(
|
6591
|
+
upb_MtDecoder_ErrorFormat(decoder, "Invalid enum version: %c", *data);
|
6706
6592
|
UPB_UNREACHABLE();
|
6707
6593
|
}
|
6708
6594
|
data++;
|
6709
6595
|
len--;
|
6710
6596
|
}
|
6711
6597
|
|
6712
|
-
upb_MtDecoder_CheckOutOfMemory(
|
6598
|
+
upb_MtDecoder_CheckOutOfMemory(decoder, decoder->enum_table);
|
6713
6599
|
|
6714
6600
|
// Guarantee at least 64 bits of mask without checking mask size.
|
6715
|
-
decoder
|
6716
|
-
decoder
|
6717
|
-
decoder
|
6601
|
+
decoder->enum_table->mask_limit = 64;
|
6602
|
+
decoder->enum_table = _upb_MiniTable_AddEnumDataMember(decoder, 0);
|
6603
|
+
decoder->enum_table = _upb_MiniTable_AddEnumDataMember(decoder, 0);
|
6718
6604
|
|
6719
|
-
decoder
|
6605
|
+
decoder->enum_table->value_count = 0;
|
6720
6606
|
|
6721
6607
|
const char* ptr = data;
|
6722
6608
|
uint32_t base = 0;
|
6723
6609
|
|
6724
|
-
while (ptr < decoder
|
6610
|
+
while (ptr < decoder->end) {
|
6725
6611
|
char ch = *ptr++;
|
6726
6612
|
if (ch <= kUpb_EncodedValue_MaxEnumMask) {
|
6727
6613
|
uint32_t mask = _upb_FromBase92(ch);
|
6728
6614
|
for (int i = 0; i < 5; i++, base++, mask >>= 1) {
|
6729
|
-
if (mask & 1) upb_MiniTableEnum_BuildValue(
|
6615
|
+
if (mask & 1) upb_MiniTableEnum_BuildValue(decoder, base);
|
6730
6616
|
}
|
6731
6617
|
} else if (kUpb_EncodedValue_MinSkip <= ch &&
|
6732
6618
|
ch <= kUpb_EncodedValue_MaxSkip) {
|
6733
6619
|
uint32_t skip;
|
6734
|
-
ptr = upb_MiniTable_DecodeBase92Varint(
|
6620
|
+
ptr = upb_MiniTable_DecodeBase92Varint(decoder, ptr, ch,
|
6735
6621
|
kUpb_EncodedValue_MinSkip,
|
6736
6622
|
kUpb_EncodedValue_MaxSkip, &skip);
|
6737
6623
|
base += skip;
|
6738
6624
|
} else {
|
6739
|
-
upb_MtDecoder_ErrorFormat(
|
6625
|
+
upb_MtDecoder_ErrorFormat(decoder, "Unexpected character: %c", ch);
|
6740
6626
|
return NULL;
|
6741
6627
|
}
|
6742
6628
|
}
|
6743
6629
|
|
6744
|
-
return decoder
|
6630
|
+
return decoder->enum_table;
|
6745
6631
|
}
|
6746
6632
|
|
6747
|
-
|
6748
|
-
|
6749
|
-
|
6750
|
-
|
6751
|
-
|
6752
|
-
|
6633
|
+
static upb_MiniTableEnum* upb_MtDecoder_BuildMiniTableEnum(
|
6634
|
+
upb_MtDecoder* const decoder, const char* const data, size_t const len) {
|
6635
|
+
if (UPB_SETJMP(decoder->err) != 0) return NULL;
|
6636
|
+
return upb_MtDecoder_DoBuildMiniTableEnum(decoder, data, len);
|
6637
|
+
}
|
6638
|
+
|
6639
|
+
upb_MiniTableEnum* upb_MiniTableEnum_Build(const char* data, size_t len,
|
6640
|
+
upb_Arena* arena,
|
6641
|
+
upb_Status* status) {
|
6753
6642
|
upb_MtDecoder decoder = {
|
6754
|
-
.
|
6643
|
+
.enum_table = upb_Arena_Malloc(arena, upb_MiniTableEnum_Size(2)),
|
6644
|
+
.enum_value_count = 0,
|
6645
|
+
.enum_data_count = 0,
|
6646
|
+
.enum_data_capacity = 1,
|
6755
6647
|
.status = status,
|
6756
|
-
.
|
6757
|
-
.
|
6648
|
+
.end = UPB_PTRADD(data, len),
|
6649
|
+
.arena = arena,
|
6758
6650
|
};
|
6759
6651
|
|
6760
|
-
|
6652
|
+
return upb_MtDecoder_BuildMiniTableEnum(&decoder, data, len);
|
6653
|
+
}
|
6761
6654
|
|
6655
|
+
static const char* upb_MtDecoder_DoBuildMiniTableExtension(
|
6656
|
+
upb_MtDecoder* decoder, const char* data, size_t len,
|
6657
|
+
upb_MiniTableExtension* ext, const upb_MiniTable* extendee,
|
6658
|
+
upb_MiniTableSub sub) {
|
6762
6659
|
// If the string is non-empty then it must begin with a version tag.
|
6763
6660
|
if (len) {
|
6764
6661
|
if (*data != kUpb_EncodedVersion_ExtensionV1) {
|
6765
|
-
upb_MtDecoder_ErrorFormat(
|
6662
|
+
upb_MtDecoder_ErrorFormat(decoder, "Invalid ext version: %c", *data);
|
6766
6663
|
UPB_UNREACHABLE();
|
6767
6664
|
}
|
6768
6665
|
data++;
|
@@ -6771,7 +6668,7 @@ const char* _upb_MiniTableExtension_Build(const char* data, size_t len,
|
|
6771
6668
|
|
6772
6669
|
uint16_t count = 0;
|
6773
6670
|
const char* ret =
|
6774
|
-
upb_MtDecoder_Parse(
|
6671
|
+
upb_MtDecoder_Parse(decoder, data, len, ext, sizeof(*ext), &count, NULL);
|
6775
6672
|
if (!ret || count != 1) return NULL;
|
6776
6673
|
|
6777
6674
|
upb_MiniTableField* f = &ext->field;
|
@@ -6794,6 +6691,47 @@ const char* _upb_MiniTableExtension_Build(const char* data, size_t len,
|
|
6794
6691
|
return ret;
|
6795
6692
|
}
|
6796
6693
|
|
6694
|
+
static const char* upb_MtDecoder_BuildMiniTableExtension(
|
6695
|
+
upb_MtDecoder* const decoder, const char* const data, const size_t len,
|
6696
|
+
upb_MiniTableExtension* const ext, const upb_MiniTable* const extendee,
|
6697
|
+
const upb_MiniTableSub sub) {
|
6698
|
+
if (UPB_SETJMP(decoder->err) != 0) return NULL;
|
6699
|
+
return upb_MtDecoder_DoBuildMiniTableExtension(decoder, data, len, ext,
|
6700
|
+
extendee, sub);
|
6701
|
+
}
|
6702
|
+
|
6703
|
+
const char* _upb_MiniTableExtension_Init(const char* data, size_t len,
|
6704
|
+
upb_MiniTableExtension* ext,
|
6705
|
+
const upb_MiniTable* extendee,
|
6706
|
+
upb_MiniTableSub sub,
|
6707
|
+
upb_MiniTablePlatform platform,
|
6708
|
+
upb_Status* status) {
|
6709
|
+
upb_MtDecoder decoder = {
|
6710
|
+
.arena = NULL,
|
6711
|
+
.status = status,
|
6712
|
+
.table = NULL,
|
6713
|
+
.platform = platform,
|
6714
|
+
};
|
6715
|
+
|
6716
|
+
return upb_MtDecoder_BuildMiniTableExtension(&decoder, data, len, ext,
|
6717
|
+
extendee, sub);
|
6718
|
+
}
|
6719
|
+
|
6720
|
+
upb_MiniTableExtension* _upb_MiniTableExtension_Build(
|
6721
|
+
const char* data, size_t len, const upb_MiniTable* extendee,
|
6722
|
+
upb_MiniTableSub sub, upb_MiniTablePlatform platform, upb_Arena* arena,
|
6723
|
+
upb_Status* status) {
|
6724
|
+
upb_MiniTableExtension* ext =
|
6725
|
+
upb_Arena_Malloc(arena, sizeof(upb_MiniTableExtension));
|
6726
|
+
if (UPB_UNLIKELY(!ext)) return NULL;
|
6727
|
+
|
6728
|
+
const char* ptr = _upb_MiniTableExtension_Init(data, len, ext, extendee, sub,
|
6729
|
+
platform, status);
|
6730
|
+
if (UPB_UNLIKELY(!ptr)) return NULL;
|
6731
|
+
|
6732
|
+
return ext;
|
6733
|
+
}
|
6734
|
+
|
6797
6735
|
upb_MiniTable* _upb_MiniTable_Build(const char* data, size_t len,
|
6798
6736
|
upb_MiniTablePlatform platform,
|
6799
6737
|
upb_Arena* arena, upb_Status* status) {
|
@@ -6815,7 +6753,7 @@ bool upb_MiniTable_SetSubMessage(upb_MiniTable* table,
|
|
6815
6753
|
|
6816
6754
|
const bool sub_is_map = sub->ext & kUpb_ExtMode_IsMapEntry;
|
6817
6755
|
|
6818
|
-
switch (field->descriptortype) {
|
6756
|
+
switch (field->UPB_PRIVATE(descriptortype)) {
|
6819
6757
|
case kUpb_FieldType_Message:
|
6820
6758
|
if (sub_is_map) {
|
6821
6759
|
const bool table_is_map = table->ext & kUpb_ExtMode_IsMapEntry;
|
@@ -6833,7 +6771,8 @@ bool upb_MiniTable_SetSubMessage(upb_MiniTable* table,
|
|
6833
6771
|
return false;
|
6834
6772
|
}
|
6835
6773
|
|
6836
|
-
upb_MiniTableSub* table_sub =
|
6774
|
+
upb_MiniTableSub* table_sub =
|
6775
|
+
(void*)&table->subs[field->UPB_PRIVATE(submsg_index)];
|
6837
6776
|
table_sub->submsg = sub;
|
6838
6777
|
return true;
|
6839
6778
|
}
|
@@ -6845,11 +6784,73 @@ bool upb_MiniTable_SetSubEnum(upb_MiniTable* table, upb_MiniTableField* field,
|
|
6845
6784
|
(uintptr_t)(table->fields + table->field_count));
|
6846
6785
|
UPB_ASSERT(sub);
|
6847
6786
|
|
6848
|
-
upb_MiniTableSub* table_sub =
|
6787
|
+
upb_MiniTableSub* table_sub =
|
6788
|
+
(void*)&table->subs[field->UPB_PRIVATE(submsg_index)];
|
6849
6789
|
table_sub->subenum = sub;
|
6850
6790
|
return true;
|
6851
6791
|
}
|
6852
6792
|
|
6793
|
+
uint32_t upb_MiniTable_GetSubList(const upb_MiniTable* mt,
|
6794
|
+
const upb_MiniTableField** subs) {
|
6795
|
+
uint32_t msg_count = 0;
|
6796
|
+
uint32_t enum_count = 0;
|
6797
|
+
|
6798
|
+
for (int i = 0; i < mt->field_count; i++) {
|
6799
|
+
const upb_MiniTableField* f = &mt->fields[i];
|
6800
|
+
if (upb_MiniTableField_CType(f) == kUpb_CType_Message) {
|
6801
|
+
*subs = f;
|
6802
|
+
++subs;
|
6803
|
+
msg_count++;
|
6804
|
+
}
|
6805
|
+
}
|
6806
|
+
|
6807
|
+
for (int i = 0; i < mt->field_count; i++) {
|
6808
|
+
const upb_MiniTableField* f = &mt->fields[i];
|
6809
|
+
if (upb_MiniTableField_CType(f) == kUpb_CType_Enum) {
|
6810
|
+
*subs = f;
|
6811
|
+
++subs;
|
6812
|
+
enum_count++;
|
6813
|
+
}
|
6814
|
+
}
|
6815
|
+
|
6816
|
+
return (msg_count << 16) | enum_count;
|
6817
|
+
}
|
6818
|
+
|
6819
|
+
// The list of sub_tables and sub_enums must exactly match the number and order
|
6820
|
+
// of sub-message fields and sub-enum fields given by upb_MiniTable_GetSubList()
|
6821
|
+
// above.
|
6822
|
+
bool upb_MiniTable_Link(upb_MiniTable* mt, const upb_MiniTable** sub_tables,
|
6823
|
+
size_t sub_table_count,
|
6824
|
+
const upb_MiniTableEnum** sub_enums,
|
6825
|
+
size_t sub_enum_count) {
|
6826
|
+
uint32_t msg_count = 0;
|
6827
|
+
uint32_t enum_count = 0;
|
6828
|
+
|
6829
|
+
for (int i = 0; i < mt->field_count; i++) {
|
6830
|
+
upb_MiniTableField* f = (upb_MiniTableField*)&mt->fields[i];
|
6831
|
+
if (upb_MiniTableField_CType(f) == kUpb_CType_Message) {
|
6832
|
+
const upb_MiniTable* sub = sub_tables[msg_count++];
|
6833
|
+
if (msg_count > sub_table_count) return false;
|
6834
|
+
if (sub != NULL) {
|
6835
|
+
if (!upb_MiniTable_SetSubMessage(mt, f, sub)) return false;
|
6836
|
+
}
|
6837
|
+
}
|
6838
|
+
}
|
6839
|
+
|
6840
|
+
for (int i = 0; i < mt->field_count; i++) {
|
6841
|
+
upb_MiniTableField* f = (upb_MiniTableField*)&mt->fields[i];
|
6842
|
+
if (upb_MiniTableField_CType(f) == kUpb_CType_Enum) {
|
6843
|
+
const upb_MiniTableEnum* sub = sub_enums[enum_count++];
|
6844
|
+
if (enum_count > sub_enum_count) return false;
|
6845
|
+
if (sub != NULL) {
|
6846
|
+
if (!upb_MiniTable_SetSubEnum(mt, f, sub)) return false;
|
6847
|
+
}
|
6848
|
+
}
|
6849
|
+
}
|
6850
|
+
|
6851
|
+
return true;
|
6852
|
+
}
|
6853
|
+
|
6853
6854
|
#include <inttypes.h>
|
6854
6855
|
|
6855
6856
|
|
@@ -7022,7 +7023,7 @@ char* upb_MtDataEncoder_PutField(upb_MtDataEncoder* e, char* ptr,
|
|
7022
7023
|
// are bit flags).
|
7023
7024
|
encoded_type += kUpb_EncodedType_RepeatedBase;
|
7024
7025
|
|
7025
|
-
if (
|
7026
|
+
if (upb_FieldType_IsPackable(type)) {
|
7026
7027
|
bool field_is_packed = field_mod & kUpb_FieldModifier_IsPacked;
|
7027
7028
|
bool default_is_packed = in->state.msg_state.msg_modifiers &
|
7028
7029
|
kUpb_MessageModifier_DefaultIsPacked;
|
@@ -7142,23 +7143,22 @@ upb_ExtensionRegistry* upb_ExtensionRegistry_New(upb_Arena* arena) {
|
|
7142
7143
|
return r;
|
7143
7144
|
}
|
7144
7145
|
|
7146
|
+
UPB_API bool upb_ExtensionRegistry_Add(upb_ExtensionRegistry* r,
|
7147
|
+
const upb_MiniTableExtension* e) {
|
7148
|
+
char buf[EXTREG_KEY_SIZE];
|
7149
|
+
extreg_key(buf, e->extendee, e->field.number);
|
7150
|
+
if (upb_strtable_lookup2(&r->exts, buf, EXTREG_KEY_SIZE, NULL)) return false;
|
7151
|
+
return upb_strtable_insert(&r->exts, buf, EXTREG_KEY_SIZE,
|
7152
|
+
upb_value_constptr(e), r->arena);
|
7153
|
+
}
|
7154
|
+
|
7145
7155
|
bool upb_ExtensionRegistry_AddArray(upb_ExtensionRegistry* r,
|
7146
7156
|
const upb_MiniTableExtension** e,
|
7147
7157
|
size_t count) {
|
7148
|
-
char buf[EXTREG_KEY_SIZE];
|
7149
7158
|
const upb_MiniTableExtension** start = e;
|
7150
7159
|
const upb_MiniTableExtension** end = UPB_PTRADD(e, count);
|
7151
7160
|
for (; e < end; e++) {
|
7152
|
-
|
7153
|
-
extreg_key(buf, ext->extendee, ext->field.number);
|
7154
|
-
upb_value v;
|
7155
|
-
if (upb_strtable_lookup2(&r->exts, buf, EXTREG_KEY_SIZE, &v)) {
|
7156
|
-
goto failure;
|
7157
|
-
}
|
7158
|
-
if (!upb_strtable_insert(&r->exts, buf, EXTREG_KEY_SIZE,
|
7159
|
-
upb_value_constptr(ext), r->arena)) {
|
7160
|
-
goto failure;
|
7161
|
-
}
|
7161
|
+
if (!upb_ExtensionRegistry_Add(r, *e)) goto failure;
|
7162
7162
|
}
|
7163
7163
|
return true;
|
7164
7164
|
|
@@ -7166,6 +7166,7 @@ failure:
|
|
7166
7166
|
// Back out the entries previously added.
|
7167
7167
|
for (end = e, e = start; e < end; e++) {
|
7168
7168
|
const upb_MiniTableExtension* ext = *e;
|
7169
|
+
char buf[EXTREG_KEY_SIZE];
|
7169
7170
|
extreg_key(buf, ext->extendee, ext->field.number);
|
7170
7171
|
upb_strtable_remove2(&r->exts, buf, EXTREG_KEY_SIZE, NULL);
|
7171
7172
|
}
|
@@ -9035,7 +9036,7 @@ static void _upb_FieldDef_Create(upb_DefBuilder* ctx, const char* prefix,
|
|
9035
9036
|
}
|
9036
9037
|
} else if (has_type_name) {
|
9037
9038
|
f->type_ =
|
9038
|
-
UPB_FIELD_TYPE_UNSPECIFIED; // We'll
|
9039
|
+
UPB_FIELD_TYPE_UNSPECIFIED; // We'll assign this in resolve_fielddef()
|
9039
9040
|
}
|
9040
9041
|
|
9041
9042
|
if (f->type_ < kUpb_FieldType_Double || f->type_ > kUpb_FieldType_SInt64) {
|
@@ -9080,8 +9081,7 @@ static void _upb_FieldDef_Create(upb_DefBuilder* ctx, const char* prefix,
|
|
9080
9081
|
upb_OneofDef* oneof = (upb_OneofDef*)upb_MessageDef_Oneof(m, oneof_index);
|
9081
9082
|
f->scope.oneof = oneof;
|
9082
9083
|
|
9083
|
-
|
9084
|
-
if (!ok) _upb_DefBuilder_OomErr(ctx);
|
9084
|
+
_upb_OneofDef_Insert(ctx, oneof, f, name.data, name.size);
|
9085
9085
|
}
|
9086
9086
|
|
9087
9087
|
UPB_DEF_SET_OPTIONS(f->opts, FieldDescriptorProto, FieldOptions, field_proto);
|
@@ -9320,9 +9320,9 @@ void _upb_FieldDef_BuildMiniTableExtension(upb_DefBuilder* ctx,
|
|
9320
9320
|
} else if (_upb_FieldDef_IsClosedEnum(f)) {
|
9321
9321
|
sub.subenum = _upb_EnumDef_MiniTable(f->sub.enumdef);
|
9322
9322
|
}
|
9323
|
-
bool ok2 =
|
9324
|
-
|
9325
|
-
|
9323
|
+
bool ok2 = upb_MiniTableExtension_Init(desc.data, desc.size, mut_ext,
|
9324
|
+
upb_MessageDef_MiniTable(f->msgdef),
|
9325
|
+
sub, ctx->status);
|
9326
9326
|
if (!ok2) _upb_DefBuilder_Errf(ctx, "Could not build extension mini table");
|
9327
9327
|
}
|
9328
9328
|
|
@@ -10803,15 +10803,35 @@ const upb_FieldDef* upb_OneofDef_LookupNumber(const upb_OneofDef* o,
|
|
10803
10803
|
: NULL;
|
10804
10804
|
}
|
10805
10805
|
|
10806
|
-
|
10807
|
-
const
|
10806
|
+
void _upb_OneofDef_Insert(upb_DefBuilder* ctx, upb_OneofDef* o,
|
10807
|
+
const upb_FieldDef* f, const char* name,
|
10808
|
+
size_t size) {
|
10808
10809
|
o->field_count++;
|
10809
10810
|
if (_upb_FieldDef_IsProto3Optional(f)) o->synthetic = true;
|
10810
10811
|
|
10811
10812
|
const int number = upb_FieldDef_Number(f);
|
10812
10813
|
const upb_value v = upb_value_constptr(f);
|
10813
|
-
|
10814
|
-
|
10814
|
+
|
10815
|
+
// TODO(salo): This lookup is unfortunate because we also perform it when
|
10816
|
+
// inserting into the message's table. Unfortunately that step occurs after
|
10817
|
+
// this one and moving things around could be tricky so let's leave it for
|
10818
|
+
// a future refactoring.
|
10819
|
+
const bool number_exists = upb_inttable_lookup(&o->itof, number, NULL);
|
10820
|
+
if (UPB_UNLIKELY(number_exists)) {
|
10821
|
+
_upb_DefBuilder_Errf(ctx, "oneof fields have the same number (%d)", number);
|
10822
|
+
}
|
10823
|
+
|
10824
|
+
// TODO(salo): More redundant work happening here.
|
10825
|
+
const bool name_exists = upb_strtable_lookup2(&o->ntof, name, size, NULL);
|
10826
|
+
if (UPB_UNLIKELY(name_exists)) {
|
10827
|
+
_upb_DefBuilder_Errf(ctx, "oneof fields have the same name (%s)", name);
|
10828
|
+
}
|
10829
|
+
|
10830
|
+
const bool ok = upb_inttable_insert(&o->itof, number, v, ctx->arena) &&
|
10831
|
+
upb_strtable_insert(&o->ntof, name, size, v, ctx->arena);
|
10832
|
+
if (UPB_UNLIKELY(!ok)) {
|
10833
|
+
_upb_DefBuilder_OomErr(ctx);
|
10834
|
+
}
|
10815
10835
|
}
|
10816
10836
|
|
10817
10837
|
// Returns the synthetic count.
|
@@ -11168,7 +11188,7 @@ static void _upb_Decoder_Munge(int type, wireval* val) {
|
|
11168
11188
|
static upb_Message* _upb_Decoder_NewSubMessage(
|
11169
11189
|
upb_Decoder* d, const upb_MiniTableSub* subs,
|
11170
11190
|
const upb_MiniTableField* field) {
|
11171
|
-
const upb_MiniTable* subl = subs[field->submsg_index].submsg;
|
11191
|
+
const upb_MiniTable* subl = subs[field->UPB_PRIVATE(submsg_index)].submsg;
|
11172
11192
|
UPB_ASSERT(subl);
|
11173
11193
|
upb_Message* msg = _upb_Message_New(subl, &d->arena);
|
11174
11194
|
if (!msg) _upb_Decoder_ErrorJmp(d, kUpb_DecodeStatus_OutOfMemory);
|
@@ -11207,7 +11227,7 @@ static const char* _upb_Decoder_DecodeSubMessage(
|
|
11207
11227
|
upb_Decoder* d, const char* ptr, upb_Message* submsg,
|
11208
11228
|
const upb_MiniTableSub* subs, const upb_MiniTableField* field, int size) {
|
11209
11229
|
int saved_delta = upb_EpsCopyInputStream_PushLimit(&d->input, ptr, size);
|
11210
|
-
const upb_MiniTable* subl = subs[field->submsg_index].submsg;
|
11230
|
+
const upb_MiniTable* subl = subs[field->UPB_PRIVATE(submsg_index)].submsg;
|
11211
11231
|
UPB_ASSERT(subl);
|
11212
11232
|
ptr = _upb_Decoder_RecurseSubMessage(d, ptr, submsg, subl, DECODE_NOGROUP);
|
11213
11233
|
upb_EpsCopyInputStream_PopLimit(&d->input, ptr, saved_delta);
|
@@ -11238,7 +11258,7 @@ UPB_FORCEINLINE
|
|
11238
11258
|
static const char* _upb_Decoder_DecodeKnownGroup(
|
11239
11259
|
upb_Decoder* d, const char* ptr, upb_Message* submsg,
|
11240
11260
|
const upb_MiniTableSub* subs, const upb_MiniTableField* field) {
|
11241
|
-
const upb_MiniTable* subl = subs[field->submsg_index].submsg;
|
11261
|
+
const upb_MiniTable* subl = subs[field->UPB_PRIVATE(submsg_index)].submsg;
|
11242
11262
|
UPB_ASSERT(subl);
|
11243
11263
|
return _upb_Decoder_DecodeGroup(d, ptr, submsg, subl, field->number);
|
11244
11264
|
}
|
@@ -11302,7 +11322,7 @@ static const char* _upb_Decoder_DecodeEnumArray(upb_Decoder* d, const char* ptr,
|
|
11302
11322
|
const upb_MiniTableSub* subs,
|
11303
11323
|
const upb_MiniTableField* field,
|
11304
11324
|
wireval* val) {
|
11305
|
-
const upb_MiniTableEnum* e = subs[field->submsg_index].subenum;
|
11325
|
+
const upb_MiniTableEnum* e = subs[field->UPB_PRIVATE(submsg_index)].subenum;
|
11306
11326
|
if (!_upb_Decoder_CheckEnum(d, ptr, msg, e, field, val)) return ptr;
|
11307
11327
|
void* mem = UPB_PTR_AT(_upb_array_ptr(arr), arr->size * 4, void);
|
11308
11328
|
arr->size++;
|
@@ -11356,7 +11376,7 @@ static const char* _upb_Decoder_DecodeVarintPacked(
|
|
11356
11376
|
while (!_upb_Decoder_IsDone(d, &ptr)) {
|
11357
11377
|
wireval elem;
|
11358
11378
|
ptr = _upb_Decoder_DecodeVarint(d, ptr, &elem.uint64_val);
|
11359
|
-
_upb_Decoder_Munge(field->descriptortype, &elem);
|
11379
|
+
_upb_Decoder_Munge(field->UPB_PRIVATE(descriptortype), &elem);
|
11360
11380
|
if (_upb_Decoder_Reserve(d, arr, 1)) {
|
11361
11381
|
out = UPB_PTR_AT(_upb_array_ptr(arr), arr->size << lg2, void);
|
11362
11382
|
}
|
@@ -11373,7 +11393,7 @@ static const char* _upb_Decoder_DecodeEnumPacked(
|
|
11373
11393
|
upb_Decoder* d, const char* ptr, upb_Message* msg, upb_Array* arr,
|
11374
11394
|
const upb_MiniTableSub* subs, const upb_MiniTableField* field,
|
11375
11395
|
wireval* val) {
|
11376
|
-
const upb_MiniTableEnum* e = subs[field->submsg_index].subenum;
|
11396
|
+
const upb_MiniTableEnum* e = subs[field->UPB_PRIVATE(submsg_index)].subenum;
|
11377
11397
|
int saved_limit = upb_EpsCopyInputStream_PushLimit(&d->input, ptr, val->size);
|
11378
11398
|
char* out = UPB_PTR_AT(_upb_array_ptr(arr), arr->size * 4, void);
|
11379
11399
|
while (!_upb_Decoder_IsDone(d, &ptr)) {
|
@@ -11419,7 +11439,7 @@ upb_Array* _upb_Decoder_CreateArray(upb_Decoder* d,
|
|
11419
11439
|
[kUpb_FieldType_SInt64] = 3,
|
11420
11440
|
};
|
11421
11441
|
|
11422
|
-
size_t lg2 = kElemSizeLg2[field->descriptortype];
|
11442
|
+
size_t lg2 = kElemSizeLg2[field->UPB_PRIVATE(descriptortype)];
|
11423
11443
|
upb_Array* ret = _upb_Array_New(&d->arena, 4, lg2);
|
11424
11444
|
if (!ret) _upb_Decoder_ErrorJmp(d, kUpb_DecodeStatus_OutOfMemory);
|
11425
11445
|
return ret;
|
@@ -11465,7 +11485,8 @@ static const char* _upb_Decoder_DecodeToArray(upb_Decoder* d, const char* ptr,
|
|
11465
11485
|
*UPB_PTR_AT(_upb_array_ptr(arr), arr->size * sizeof(void*),
|
11466
11486
|
upb_Message*) = submsg;
|
11467
11487
|
arr->size++;
|
11468
|
-
if (UPB_UNLIKELY(field->descriptortype ==
|
11488
|
+
if (UPB_UNLIKELY(field->UPB_PRIVATE(descriptortype) ==
|
11489
|
+
kUpb_FieldType_Group)) {
|
11469
11490
|
return _upb_Decoder_DecodeKnownGroup(d, ptr, submsg, subs, field);
|
11470
11491
|
} else {
|
11471
11492
|
return _upb_Decoder_DecodeSubMessage(d, ptr, submsg, subs, field,
|
@@ -11516,8 +11537,8 @@ upb_Map* _upb_Decoder_CreateMap(upb_Decoder* d, const upb_MiniTable* entry) {
|
|
11516
11537
|
|
11517
11538
|
const upb_MiniTableField* key_field = &entry->fields[0];
|
11518
11539
|
const upb_MiniTableField* val_field = &entry->fields[1];
|
11519
|
-
char key_size = kSizeInMap[key_field->descriptortype];
|
11520
|
-
char val_size = kSizeInMap[val_field->descriptortype];
|
11540
|
+
char key_size = kSizeInMap[key_field->UPB_PRIVATE(descriptortype)];
|
11541
|
+
char val_size = kSizeInMap[val_field->UPB_PRIVATE(descriptortype)];
|
11521
11542
|
UPB_ASSERT(key_field->offset == offsetof(upb_MapEntryData, k));
|
11522
11543
|
UPB_ASSERT(val_field->offset == offsetof(upb_MapEntryData, v));
|
11523
11544
|
upb_Map* ret = _upb_Map_New(&d->arena, key_size, val_size);
|
@@ -11534,7 +11555,7 @@ static const char* _upb_Decoder_DecodeToMap(upb_Decoder* d, const char* ptr,
|
|
11534
11555
|
upb_Map* map = *map_p;
|
11535
11556
|
upb_MapEntry ent;
|
11536
11557
|
UPB_ASSERT(upb_MiniTableField_Type(field) == kUpb_FieldType_Message);
|
11537
|
-
const upb_MiniTable* entry = subs[field->submsg_index].submsg;
|
11558
|
+
const upb_MiniTable* entry = subs[field->UPB_PRIVATE(submsg_index)].submsg;
|
11538
11559
|
|
11539
11560
|
UPB_ASSERT(entry->field_count == 2);
|
11540
11561
|
UPB_ASSERT(!upb_IsRepeatedOrMap(&entry->fields[0]));
|
@@ -11548,8 +11569,8 @@ static const char* _upb_Decoder_DecodeToMap(upb_Decoder* d, const char* ptr,
|
|
11548
11569
|
// Parse map entry.
|
11549
11570
|
memset(&ent, 0, sizeof(ent));
|
11550
11571
|
|
11551
|
-
if (entry->fields[1].descriptortype == kUpb_FieldType_Message ||
|
11552
|
-
entry->fields[1].descriptortype == kUpb_FieldType_Group) {
|
11572
|
+
if (entry->fields[1].UPB_PRIVATE(descriptortype) == kUpb_FieldType_Message ||
|
11573
|
+
entry->fields[1].UPB_PRIVATE(descriptortype) == kUpb_FieldType_Group) {
|
11553
11574
|
const upb_MiniTable* submsg_table = entry->subs[0].submsg;
|
11554
11575
|
// Any sub-message entry must be linked. We do not allow dynamic tree
|
11555
11576
|
// shaking in this case.
|
@@ -11592,10 +11613,11 @@ static const char* _upb_Decoder_DecodeToSubMessage(
|
|
11592
11613
|
const upb_MiniTableSub* subs, const upb_MiniTableField* field, wireval* val,
|
11593
11614
|
int op) {
|
11594
11615
|
void* mem = UPB_PTR_AT(msg, field->offset, void);
|
11595
|
-
int type = field->descriptortype;
|
11616
|
+
int type = field->UPB_PRIVATE(descriptortype);
|
11596
11617
|
|
11597
11618
|
if (UPB_UNLIKELY(op == kUpb_DecodeOp_Enum) &&
|
11598
|
-
!_upb_Decoder_CheckEnum(d, ptr, msg,
|
11619
|
+
!_upb_Decoder_CheckEnum(d, ptr, msg,
|
11620
|
+
subs[field->UPB_PRIVATE(submsg_index)].subenum,
|
11599
11621
|
field, val)) {
|
11600
11622
|
return ptr;
|
11601
11623
|
}
|
@@ -11838,7 +11860,7 @@ static const upb_MiniTableField* _upb_Decoder_FindField(upb_Decoder* d,
|
|
11838
11860
|
if (t->dense_below < t->field_count) {
|
11839
11861
|
/* Linear search non-dense fields. Resume scanning from last_field_index
|
11840
11862
|
* since fields are usually in order. */
|
11841
|
-
|
11863
|
+
size_t last = *last_field_index;
|
11842
11864
|
for (idx = last; idx < t->field_count; idx++) {
|
11843
11865
|
if (t->fields[idx].number == field_number) {
|
11844
11866
|
goto found;
|
@@ -11902,7 +11924,7 @@ int _upb_Decoder_GetVarintOp(const upb_MiniTableField* field) {
|
|
11902
11924
|
[kUpb_FakeFieldType_MessageSetItem] = kUpb_DecodeOp_UnknownField,
|
11903
11925
|
};
|
11904
11926
|
|
11905
|
-
return kVarintOps[field->descriptortype];
|
11927
|
+
return kVarintOps[field->UPB_PRIVATE(descriptortype)];
|
11906
11928
|
}
|
11907
11929
|
|
11908
11930
|
UPB_FORCEINLINE
|
@@ -11911,8 +11933,22 @@ static void _upb_Decoder_CheckUnlinked(const upb_MiniTable* mt,
|
|
11911
11933
|
int* op) {
|
11912
11934
|
// If sub-message is not linked, treat as unknown.
|
11913
11935
|
if (field->mode & kUpb_LabelFlags_IsExtension) return;
|
11914
|
-
const upb_MiniTableSub* sub = &mt->subs[field->submsg_index];
|
11915
|
-
if (
|
11936
|
+
const upb_MiniTableSub* sub = &mt->subs[field->UPB_PRIVATE(submsg_index)];
|
11937
|
+
if (sub->submsg) return;
|
11938
|
+
#ifndef NDEBUG
|
11939
|
+
const upb_MiniTableField* oneof = upb_MiniTable_GetOneof(mt, field);
|
11940
|
+
if (oneof) {
|
11941
|
+
// All other members of the oneof must be message fields that are also
|
11942
|
+
// unlinked.
|
11943
|
+
do {
|
11944
|
+
assert(upb_MiniTableField_CType(oneof) == kUpb_CType_Message);
|
11945
|
+
const upb_MiniTableSub* oneof_sub =
|
11946
|
+
&mt->subs[oneof->UPB_PRIVATE(submsg_index)];
|
11947
|
+
assert(!oneof_sub);
|
11948
|
+
} while (upb_MiniTable_NextOneofField(mt, &oneof));
|
11949
|
+
}
|
11950
|
+
#endif // NDEBUG
|
11951
|
+
*op = kUpb_DecodeOp_UnknownField;
|
11916
11952
|
}
|
11917
11953
|
|
11918
11954
|
int _upb_Decoder_GetDelimitedOp(const upb_MiniTable* mt,
|
@@ -11965,7 +12001,7 @@ int _upb_Decoder_GetDelimitedOp(const upb_MiniTable* mt,
|
|
11965
12001
|
// repeated msgset type
|
11966
12002
|
};
|
11967
12003
|
|
11968
|
-
int ndx = field->descriptortype;
|
12004
|
+
int ndx = field->UPB_PRIVATE(descriptortype);
|
11969
12005
|
if (upb_FieldMode_Get(field) == kUpb_FieldMode_Array) ndx += kRepeatedBase;
|
11970
12006
|
int op = kDelimitedOps[ndx];
|
11971
12007
|
|
@@ -11994,17 +12030,17 @@ static const char* _upb_Decoder_DecodeWireValue(upb_Decoder* d, const char* ptr,
|
|
11994
12030
|
case kUpb_WireType_Varint:
|
11995
12031
|
ptr = _upb_Decoder_DecodeVarint(d, ptr, &val->uint64_val);
|
11996
12032
|
*op = _upb_Decoder_GetVarintOp(field);
|
11997
|
-
_upb_Decoder_Munge(field->descriptortype, val);
|
12033
|
+
_upb_Decoder_Munge(field->UPB_PRIVATE(descriptortype), val);
|
11998
12034
|
return ptr;
|
11999
12035
|
case kUpb_WireType_32Bit:
|
12000
12036
|
*op = kUpb_DecodeOp_Scalar4Byte;
|
12001
|
-
if (((1 << field->descriptortype) & kFixed32OkMask) == 0) {
|
12037
|
+
if (((1 << field->UPB_PRIVATE(descriptortype)) & kFixed32OkMask) == 0) {
|
12002
12038
|
*op = kUpb_DecodeOp_UnknownField;
|
12003
12039
|
}
|
12004
12040
|
return upb_WireReader_ReadFixed32(ptr, &val->uint32_val);
|
12005
12041
|
case kUpb_WireType_64Bit:
|
12006
12042
|
*op = kUpb_DecodeOp_Scalar8Byte;
|
12007
|
-
if (((1 << field->descriptortype) & kFixed64OkMask) == 0) {
|
12043
|
+
if (((1 << field->UPB_PRIVATE(descriptortype)) & kFixed64OkMask) == 0) {
|
12008
12044
|
*op = kUpb_DecodeOp_UnknownField;
|
12009
12045
|
}
|
12010
12046
|
return upb_WireReader_ReadFixed64(ptr, &val->uint64_val);
|
@@ -12014,10 +12050,11 @@ static const char* _upb_Decoder_DecodeWireValue(upb_Decoder* d, const char* ptr,
|
|
12014
12050
|
return ptr;
|
12015
12051
|
case kUpb_WireType_StartGroup:
|
12016
12052
|
val->uint32_val = field->number;
|
12017
|
-
if (field->descriptortype == kUpb_FieldType_Group) {
|
12053
|
+
if (field->UPB_PRIVATE(descriptortype) == kUpb_FieldType_Group) {
|
12018
12054
|
*op = kUpb_DecodeOp_SubMessage;
|
12019
12055
|
_upb_Decoder_CheckUnlinked(mt, field, op);
|
12020
|
-
} else if (field->descriptortype ==
|
12056
|
+
} else if (field->UPB_PRIVATE(descriptortype) ==
|
12057
|
+
kUpb_FakeFieldType_MessageSetItem) {
|
12021
12058
|
*op = kUpb_DecodeOp_MessageSetItem;
|
12022
12059
|
} else {
|
12023
12060
|
*op = kUpb_DecodeOp_UnknownField;
|
@@ -12231,9 +12268,10 @@ static upb_DecodeStatus upb_Decoder_Decode(upb_Decoder* const decoder,
|
|
12231
12268
|
UPB_ASSERT(decoder->status != kUpb_DecodeStatus_Ok);
|
12232
12269
|
}
|
12233
12270
|
|
12234
|
-
|
12235
|
-
|
12236
|
-
arena->
|
12271
|
+
_upb_MemBlock* blocks =
|
12272
|
+
upb_Atomic_Load(&decoder->arena.blocks, memory_order_relaxed);
|
12273
|
+
arena->head = decoder->arena.head;
|
12274
|
+
upb_Atomic_Store(&arena->blocks, blocks, memory_order_relaxed);
|
12237
12275
|
return decoder->status;
|
12238
12276
|
}
|
12239
12277
|
|
@@ -12241,25 +12279,31 @@ upb_DecodeStatus upb_Decode(const char* buf, size_t size, void* msg,
|
|
12241
12279
|
const upb_MiniTable* l,
|
12242
12280
|
const upb_ExtensionRegistry* extreg, int options,
|
12243
12281
|
upb_Arena* arena) {
|
12244
|
-
upb_Decoder
|
12282
|
+
upb_Decoder decoder;
|
12245
12283
|
unsigned depth = (unsigned)options >> 16;
|
12246
12284
|
|
12247
|
-
upb_EpsCopyInputStream_Init(&
|
12285
|
+
upb_EpsCopyInputStream_Init(&decoder.input, &buf, size,
|
12248
12286
|
options & kUpb_DecodeOption_AliasString);
|
12249
12287
|
|
12250
|
-
|
12251
|
-
|
12252
|
-
|
12253
|
-
|
12254
|
-
|
12255
|
-
|
12256
|
-
|
12257
|
-
|
12258
|
-
|
12259
|
-
|
12260
|
-
|
12288
|
+
decoder.extreg = extreg;
|
12289
|
+
decoder.unknown = NULL;
|
12290
|
+
decoder.depth = depth ? depth : kUpb_WireFormat_DefaultDepthLimit;
|
12291
|
+
decoder.end_group = DECODE_NOGROUP;
|
12292
|
+
decoder.options = (uint16_t)options;
|
12293
|
+
decoder.missing_required = false;
|
12294
|
+
decoder.status = kUpb_DecodeStatus_Ok;
|
12295
|
+
|
12296
|
+
// Violating the encapsulation of the arena for performance reasons.
|
12297
|
+
// This is a temporary arena that we swap into and swap out of when we are
|
12298
|
+
// done. The temporary arena only needs to be able to handle allocation,
|
12299
|
+
// not fuse or free, so it does not need many of the members to be initialized
|
12300
|
+
// (particularly parent_or_count).
|
12301
|
+
_upb_MemBlock* blocks = upb_Atomic_Load(&arena->blocks, memory_order_relaxed);
|
12302
|
+
decoder.arena.head = arena->head;
|
12303
|
+
decoder.arena.block_alloc = arena->block_alloc;
|
12304
|
+
upb_Atomic_Init(&decoder.arena.blocks, blocks);
|
12261
12305
|
|
12262
|
-
return upb_Decoder_Decode(&
|
12306
|
+
return upb_Decoder_Decode(&decoder, buf, msg, l, arena);
|
12263
12307
|
}
|
12264
12308
|
|
12265
12309
|
#undef OP_FIXPCK_LG2
|
@@ -13441,7 +13485,7 @@ static void encode_scalar(upb_encstate* e, const void* _field_mem,
|
|
13441
13485
|
break; \
|
13442
13486
|
}
|
13443
13487
|
|
13444
|
-
switch (f->descriptortype) {
|
13488
|
+
switch (f->UPB_PRIVATE(descriptortype)) {
|
13445
13489
|
case kUpb_FieldType_Double:
|
13446
13490
|
CASE(double, double, kUpb_WireType_64Bit, val);
|
13447
13491
|
case kUpb_FieldType_Float:
|
@@ -13477,7 +13521,7 @@ static void encode_scalar(upb_encstate* e, const void* _field_mem,
|
|
13477
13521
|
case kUpb_FieldType_Group: {
|
13478
13522
|
size_t size;
|
13479
13523
|
void* submsg = *(void**)field_mem;
|
13480
|
-
const upb_MiniTable* subm = subs[f->submsg_index].submsg;
|
13524
|
+
const upb_MiniTable* subm = subs[f->UPB_PRIVATE(submsg_index)].submsg;
|
13481
13525
|
if (submsg == NULL) {
|
13482
13526
|
return;
|
13483
13527
|
}
|
@@ -13491,7 +13535,7 @@ static void encode_scalar(upb_encstate* e, const void* _field_mem,
|
|
13491
13535
|
case kUpb_FieldType_Message: {
|
13492
13536
|
size_t size;
|
13493
13537
|
void* submsg = *(void**)field_mem;
|
13494
|
-
const upb_MiniTable* subm = subs[f->submsg_index].submsg;
|
13538
|
+
const upb_MiniTable* subm = subs[f->UPB_PRIVATE(submsg_index)].submsg;
|
13495
13539
|
if (submsg == NULL) {
|
13496
13540
|
return;
|
13497
13541
|
}
|
@@ -13536,7 +13580,7 @@ static void encode_array(upb_encstate* e, const upb_Message* msg,
|
|
13536
13580
|
|
13537
13581
|
#define TAG(wire_type) (packed ? 0 : (f->number << 3 | wire_type))
|
13538
13582
|
|
13539
|
-
switch (f->descriptortype) {
|
13583
|
+
switch (f->UPB_PRIVATE(descriptortype)) {
|
13540
13584
|
case kUpb_FieldType_Double:
|
13541
13585
|
encode_fixedarray(e, arr, sizeof(double), TAG(kUpb_WireType_64Bit));
|
13542
13586
|
break;
|
@@ -13580,7 +13624,7 @@ static void encode_array(upb_encstate* e, const upb_Message* msg,
|
|
13580
13624
|
case kUpb_FieldType_Group: {
|
13581
13625
|
const void* const* start = _upb_array_constptr(arr);
|
13582
13626
|
const void* const* ptr = start + arr->size;
|
13583
|
-
const upb_MiniTable* subm = subs[f->submsg_index].submsg;
|
13627
|
+
const upb_MiniTable* subm = subs[f->UPB_PRIVATE(submsg_index)].submsg;
|
13584
13628
|
if (--e->depth == 0) encode_err(e, kUpb_EncodeStatus_MaxDepthExceeded);
|
13585
13629
|
do {
|
13586
13630
|
size_t size;
|
@@ -13595,7 +13639,7 @@ static void encode_array(upb_encstate* e, const upb_Message* msg,
|
|
13595
13639
|
case kUpb_FieldType_Message: {
|
13596
13640
|
const void* const* start = _upb_array_constptr(arr);
|
13597
13641
|
const void* const* ptr = start + arr->size;
|
13598
|
-
const upb_MiniTable* subm = subs[f->submsg_index].submsg;
|
13642
|
+
const upb_MiniTable* subm = subs[f->UPB_PRIVATE(submsg_index)].submsg;
|
13599
13643
|
if (--e->depth == 0) encode_err(e, kUpb_EncodeStatus_MaxDepthExceeded);
|
13600
13644
|
do {
|
13601
13645
|
size_t size;
|
@@ -13634,14 +13678,15 @@ static void encode_map(upb_encstate* e, const upb_Message* msg,
|
|
13634
13678
|
const upb_MiniTableSub* subs,
|
13635
13679
|
const upb_MiniTableField* f) {
|
13636
13680
|
const upb_Map* map = *UPB_PTR_AT(msg, f->offset, const upb_Map*);
|
13637
|
-
const upb_MiniTable* layout = subs[f->submsg_index].submsg;
|
13681
|
+
const upb_MiniTable* layout = subs[f->UPB_PRIVATE(submsg_index)].submsg;
|
13638
13682
|
UPB_ASSERT(layout->field_count == 2);
|
13639
13683
|
|
13640
13684
|
if (map == NULL) return;
|
13641
13685
|
|
13642
13686
|
if (e->options & kUpb_EncodeOption_Deterministic) {
|
13643
13687
|
_upb_sortedmap sorted;
|
13644
|
-
_upb_mapsorter_pushmap(&e->sorter,
|
13688
|
+
_upb_mapsorter_pushmap(&e->sorter,
|
13689
|
+
layout->fields[0].UPB_PRIVATE(descriptortype), map,
|
13645
13690
|
&sorted);
|
13646
13691
|
upb_MapEntry ent;
|
13647
13692
|
while (_upb_sortedmap_next(&e->sorter, map, &sorted, &ent)) {
|
@@ -13837,7 +13882,7 @@ upb_EncodeStatus upb_Encode(const void* msg, const upb_MiniTable* l,
|
|
13837
13882
|
e.buf = NULL;
|
13838
13883
|
e.limit = NULL;
|
13839
13884
|
e.ptr = NULL;
|
13840
|
-
e.depth = depth ? depth :
|
13885
|
+
e.depth = depth ? depth : kUpb_WireFormat_DefaultDepthLimit;
|
13841
13886
|
e.options = options;
|
13842
13887
|
_upb_mapsorter_init(&e.sorter);
|
13843
13888
|
|
@@ -13924,3 +13969,6 @@ const char* _upb_WireReader_SkipGroup(const char* ptr, uint32_t tag,
|
|
13924
13969
|
#undef UPB_DESCRIPTOR_UPB_H_FILENAME
|
13925
13970
|
#undef UPB_DESC
|
13926
13971
|
#undef UPB_IS_GOOGLE3
|
13972
|
+
#undef UPB_ATOMIC
|
13973
|
+
#undef UPB_USE_C11_ATOMICS
|
13974
|
+
#undef UPB_PRIVATE
|