typia 4.1.6 → 5.0.0-dev.20230713
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.
- package/README.md +9 -1
- package/lib/factories/MetadataTagFactory.js +11 -4
- package/lib/factories/MetadataTagFactory.js.map +1 -1
- package/lib/factories/ProtocolFactory.d.ts +8 -0
- package/lib/factories/ProtocolFactory.js +113 -0
- package/lib/factories/ProtocolFactory.js.map +1 -0
- package/lib/factories/internal/protocols/ProtocolMetadataUtil.d.ts +16 -0
- package/lib/factories/internal/protocols/ProtocolMetadataUtil.js +173 -0
- package/lib/factories/internal/protocols/ProtocolMetadataUtil.js.map +1 -0
- package/lib/factories/internal/protocols/emplace_protocol_object.d.ts +3 -0
- package/lib/factories/internal/protocols/emplace_protocol_object.js +47 -0
- package/lib/factories/internal/protocols/emplace_protocol_object.js.map +1 -0
- package/lib/factories/internal/protocols/emplace_protocol_property.d.ts +4 -0
- package/lib/factories/internal/protocols/emplace_protocol_property.js +20 -0
- package/lib/factories/internal/protocols/emplace_protocol_property.js.map +1 -0
- package/lib/factories/internal/protocols/iterate_protocol_atomic.d.ts +3 -0
- package/lib/factories/internal/protocols/iterate_protocol_atomic.js +69 -0
- package/lib/factories/internal/protocols/iterate_protocol_atomic.js.map +1 -0
- package/lib/factories/internal/protocols/iterate_protocol_constant.d.ts +2 -0
- package/lib/factories/internal/protocols/iterate_protocol_constant.js +30 -0
- package/lib/factories/internal/protocols/iterate_protocol_constant.js.map +1 -0
- package/lib/factories/internal/protocols/iterate_protocol_main.d.ts +3 -0
- package/lib/factories/internal/protocols/iterate_protocol_main.js +17 -0
- package/lib/factories/internal/protocols/iterate_protocol_main.js.map +1 -0
- package/lib/factories/internal/protocols/iterate_protocol_map.d.ts +4 -0
- package/lib/factories/internal/protocols/iterate_protocol_map.js +75 -0
- package/lib/factories/internal/protocols/iterate_protocol_map.js.map +1 -0
- package/lib/factories/internal/protocols/iterate_protocol_metadata.d.ts +5 -0
- package/lib/factories/internal/protocols/iterate_protocol_metadata.js +190 -0
- package/lib/factories/internal/protocols/iterate_protocol_metadata.js.map +1 -0
- package/lib/factories/internal/protocols/iterate_protocol_native.d.ts +2 -0
- package/lib/factories/internal/protocols/iterate_protocol_native.js +33 -0
- package/lib/factories/internal/protocols/iterate_protocol_native.js.map +1 -0
- package/lib/factories/internal/protocols/iterate_protocol_never.d.ts +1 -0
- package/lib/factories/internal/protocols/iterate_protocol_never.js +6 -0
- package/lib/factories/internal/protocols/iterate_protocol_never.js.map +1 -0
- package/lib/factories/internal/protocols/iterate_protocol_object.d.ts +4 -0
- package/lib/factories/internal/protocols/iterate_protocol_object.js +157 -0
- package/lib/factories/internal/protocols/iterate_protocol_object.js.map +1 -0
- package/lib/factories/internal/protocols/iterate_protocol_repeated.d.ts +5 -0
- package/lib/factories/internal/protocols/iterate_protocol_repeated.js +25 -0
- package/lib/factories/internal/protocols/iterate_protocol_repeated.js.map +1 -0
- package/lib/factories/internal/protocols/iterate_protocol_tuple.d.ts +3 -0
- package/lib/factories/internal/protocols/iterate_protocol_tuple.js +46 -0
- package/lib/factories/internal/protocols/iterate_protocol_tuple.js.map +1 -0
- package/lib/functional/$number.js +2 -2
- package/lib/functional/$number.js.map +1 -1
- package/lib/functional/$proto_bytes.d.ts +2 -0
- package/lib/functional/$proto_bytes.js +37 -0
- package/lib/functional/$proto_bytes.js.map +1 -0
- package/lib/functional/$proto_field.d.ts +10 -0
- package/lib/functional/$proto_field.js +42 -0
- package/lib/functional/$proto_field.js.map +1 -0
- package/lib/functional/$proto_float.d.ts +4 -0
- package/lib/functional/$proto_float.js +28 -0
- package/lib/functional/$proto_float.js.map +1 -0
- package/lib/functional/$proto_i32.d.ts +2 -0
- package/lib/functional/$proto_i32.js +23 -0
- package/lib/functional/$proto_i32.js.map +1 -0
- package/lib/functional/$proto_i64.d.ts +2 -0
- package/lib/functional/$proto_i64.js +31 -0
- package/lib/functional/$proto_i64.js.map +1 -0
- package/lib/functional/$proto_size.d.ts +6 -0
- package/lib/functional/$proto_size.js +76 -0
- package/lib/functional/$proto_size.js.map +1 -0
- package/lib/functional/$proto_string.d.ts +2 -0
- package/lib/functional/$proto_string.js +34 -0
- package/lib/functional/$proto_string.js.map +1 -0
- package/lib/functional/$varint.d.ts +6 -0
- package/lib/functional/$varint.js +99 -0
- package/lib/functional/$varint.js.map +1 -0
- package/lib/functional/$zigzag.d.ts +4 -0
- package/lib/functional/$zigzag.js +34 -0
- package/lib/functional/$zigzag.js.map +1 -0
- package/lib/json.d.ts +455 -0
- package/lib/json.js +85 -0
- package/lib/json.js.map +1 -0
- package/lib/messages/IProtocolMap.d.ts +5 -0
- package/lib/messages/IProtocolMap.js +3 -0
- package/lib/messages/IProtocolMap.js.map +1 -0
- package/lib/messages/IProtocolMessage.d.ts +5 -0
- package/lib/messages/IProtocolMessage.js +3 -0
- package/lib/messages/IProtocolMessage.js.map +1 -0
- package/lib/messages/IProtocolProperty.d.ts +12 -0
- package/lib/messages/IProtocolProperty.js +3 -0
- package/lib/messages/IProtocolProperty.js.map +1 -0
- package/lib/metadata/IMetadataTag.d.ts +3 -3
- package/lib/metadata/Metadata.js.map +1 -1
- package/lib/misc.d.ts +442 -0
- package/lib/misc.js +98 -0
- package/lib/misc.js.map +1 -0
- package/lib/module.d.ts +132 -1022
- package/lib/module.js +32 -184
- package/lib/module.js.map +1 -1
- package/lib/programmers/IsPruneProgrammer.js +2 -2
- package/lib/programmers/IsPruneProgrammer.js.map +1 -1
- package/lib/programmers/internal/application_alias.d.ts +2 -2
- package/lib/programmers/internal/application_alias.js.map +1 -1
- package/lib/programmers/internal/application_array.js.map +1 -1
- package/lib/programmers/internal/application_native.js.map +1 -1
- package/lib/programmers/internal/application_number.js +8 -5
- package/lib/programmers/internal/application_number.js.map +1 -1
- package/lib/programmers/internal/application_object.js.map +1 -1
- package/lib/programmers/internal/application_resolved.d.ts +2 -2
- package/lib/programmers/internal/application_resolved.js.map +1 -1
- package/lib/programmers/internal/application_schema.js.map +1 -1
- package/lib/programmers/internal/application_tuple.js.map +1 -1
- package/lib/programmers/json/JsonApplicationProgrammer.d.ts +8 -0
- package/lib/programmers/{ApplicationProgrammer.js → json/JsonApplicationProgrammer.js} +8 -8
- package/lib/programmers/json/JsonApplicationProgrammer.js.map +1 -0
- package/lib/programmers/{AssertStringifyProgrammer.d.ts → json/JsonAssertParseProgrammer.d.ts} +2 -2
- package/lib/programmers/{AssertParseProgrammer.js → json/JsonAssertParseProgrammer.js} +10 -10
- package/lib/programmers/json/JsonAssertParseProgrammer.js.map +1 -0
- package/lib/programmers/json/JsonAssertStringifyProgrammer.d.ts +5 -0
- package/lib/programmers/{AssertStringifyProgrammer.js → json/JsonAssertStringifyProgrammer.js} +12 -12
- package/lib/programmers/json/JsonAssertStringifyProgrammer.js.map +1 -0
- package/lib/programmers/{IsCloneProgrammer.d.ts → json/JsonIsParseProgrammer.d.ts} +2 -2
- package/lib/programmers/{IsParseProgrammer.js → json/JsonIsParseProgrammer.js} +10 -10
- package/lib/programmers/json/JsonIsParseProgrammer.js.map +1 -0
- package/lib/programmers/{IsStringifyProgrammer.d.ts → json/JsonIsStringifyProgrammer.d.ts} +1 -1
- package/lib/programmers/{IsStringifyProgrammer.js → json/JsonIsStringifyProgrammer.js} +7 -7
- package/lib/programmers/json/JsonIsStringifyProgrammer.js.map +1 -0
- package/lib/programmers/{StringifyProgrammer.d.ts → json/JsonStringifyProgrammer.d.ts} +2 -2
- package/lib/programmers/{StringifyProgrammer.js → json/JsonStringifyProgrammer.js} +30 -30
- package/lib/programmers/json/JsonStringifyProgrammer.js.map +1 -0
- package/lib/programmers/json/JsonValidateParseProgrammer.d.ts +5 -0
- package/lib/programmers/{ValidateParseProgrammer.js → json/JsonValidateParseProgrammer.js} +10 -10
- package/lib/programmers/json/JsonValidateParseProgrammer.js.map +1 -0
- package/lib/programmers/json/JsonValidateStringifyProgrammer.d.ts +5 -0
- package/lib/programmers/{ValidateStringifyProgrammer.js → json/JsonValidateStringifyProgrammer.js} +12 -12
- package/lib/programmers/json/JsonValidateStringifyProgrammer.js.map +1 -0
- package/lib/programmers/{AssertPruneProgrammer.d.ts → misc/MiscAssertCloneProgrammer.d.ts} +2 -2
- package/lib/programmers/{AssertCloneProgrammer.js → misc/MiscAssertCloneProgrammer.js} +12 -12
- package/lib/programmers/misc/MiscAssertCloneProgrammer.js.map +1 -0
- package/lib/programmers/{AssertCloneProgrammer.d.ts → misc/MiscAssertPruneProgrammer.d.ts} +2 -2
- package/lib/programmers/{AssertPruneProgrammer.js → misc/MiscAssertPruneProgrammer.js} +12 -12
- package/lib/programmers/misc/MiscAssertPruneProgrammer.js.map +1 -0
- package/lib/programmers/{CloneProgrammer.d.ts → misc/MiscCloneProgrammer.d.ts} +2 -2
- package/lib/programmers/{CloneProgrammer.js → misc/MiscCloneProgrammer.js} +20 -20
- package/lib/programmers/misc/MiscCloneProgrammer.js.map +1 -0
- package/lib/programmers/{AssertParseProgrammer.d.ts → misc/MiscIsCloneProgrammer.d.ts} +2 -2
- package/lib/programmers/{IsCloneProgrammer.js → misc/MiscIsCloneProgrammer.js} +12 -12
- package/lib/programmers/misc/MiscIsCloneProgrammer.js.map +1 -0
- package/lib/programmers/{LiteralsProgrammer.d.ts → misc/MiscLiteralsProgrammer.d.ts} +2 -2
- package/lib/programmers/{LiteralsProgrammer.js → misc/MiscLiteralsProgrammer.js} +12 -11
- package/lib/programmers/misc/MiscLiteralsProgrammer.js.map +1 -0
- package/lib/programmers/{PruneProgrammer.d.ts → misc/MiscPruneProgrammer.d.ts} +2 -2
- package/lib/programmers/{PruneProgrammer.js → misc/MiscPruneProgrammer.js} +20 -20
- package/lib/programmers/misc/MiscPruneProgrammer.js.map +1 -0
- package/lib/programmers/misc/MiscValidateCloneProgrammer.d.ts +5 -0
- package/lib/programmers/{ValidateCloneProgrammer.js → misc/MiscValidateCloneProgrammer.js} +12 -12
- package/lib/programmers/misc/MiscValidateCloneProgrammer.js.map +1 -0
- package/lib/programmers/misc/MiscValidatePruneProgrammer.d.ts +5 -0
- package/lib/programmers/{ValidatePruneProgrammer.js → misc/MiscValidatePruneProgrammer.js} +12 -12
- package/lib/programmers/misc/MiscValidatePruneProgrammer.js.map +1 -0
- package/lib/programmers/protobuf/ProtobufMessageProgrammer.d.ts +5 -0
- package/lib/programmers/protobuf/ProtobufMessageProgrammer.js +141 -0
- package/lib/programmers/protobuf/ProtobufMessageProgrammer.js.map +1 -0
- package/lib/protobuf.d.ts +2 -0
- package/lib/protobuf.js +11 -0
- package/lib/protobuf.js.map +1 -0
- package/lib/transformers/CallExpressionTransformer.js +122 -101
- package/lib/transformers/CallExpressionTransformer.js.map +1 -1
- package/lib/transformers/features/AssertTransformer.d.ts +3 -0
- package/lib/transformers/features/{validators/AssertTransformer.js → AssertTransformer.js} +2 -2
- package/lib/transformers/features/AssertTransformer.js.map +1 -0
- package/lib/transformers/features/CreateAssertTransformer.d.ts +3 -0
- package/lib/transformers/features/{validators/CreateAssertTransformer.js → CreateAssertTransformer.js} +2 -2
- package/lib/transformers/features/CreateAssertTransformer.js.map +1 -0
- package/lib/transformers/features/CreateIsTransformer.d.ts +3 -0
- package/lib/transformers/features/{validators/CreateIsTransformer.js → CreateIsTransformer.js} +2 -2
- package/lib/transformers/features/CreateIsTransformer.js.map +1 -0
- package/lib/transformers/features/{miscellaneous/CreateRandomTransformer.d.ts → CreateRandomTransformer.d.ts} +1 -1
- package/lib/transformers/features/{miscellaneous/CreateRandomTransformer.js → CreateRandomTransformer.js} +1 -1
- package/lib/transformers/features/CreateRandomTransformer.js.map +1 -0
- package/lib/transformers/features/CreateValidateTransformer.d.ts +3 -0
- package/lib/transformers/features/{validators/CreateValidateTransformer.js → CreateValidateTransformer.js} +2 -2
- package/lib/transformers/features/CreateValidateTransformer.js.map +1 -0
- package/lib/transformers/features/IsTransformer.d.ts +3 -0
- package/lib/transformers/features/{validators/IsTransformer.js → IsTransformer.js} +2 -2
- package/lib/transformers/features/IsTransformer.js.map +1 -0
- package/lib/transformers/features/{miscellaneous/RandomTransformer.d.ts → RandomTransformer.d.ts} +1 -1
- package/lib/transformers/features/{miscellaneous/RandomTransformer.js → RandomTransformer.js} +1 -1
- package/lib/transformers/features/RandomTransformer.js.map +1 -0
- package/lib/transformers/features/ValidateTransformer.d.ts +3 -0
- package/lib/transformers/features/{validators/ValidateTransformer.js → ValidateTransformer.js} +2 -2
- package/lib/transformers/features/ValidateTransformer.js.map +1 -0
- package/lib/transformers/features/{parsers → json}/AssertParseTransformer.js +4 -2
- package/lib/transformers/features/json/AssertParseTransformer.js.map +1 -0
- package/lib/transformers/features/{stringifiers → json}/AssertStringifyTransformer.js +2 -2
- package/lib/transformers/features/json/AssertStringifyTransformer.js.map +1 -0
- package/lib/transformers/features/{parsers → json}/CreateAssertParseTransformer.js +4 -2
- package/lib/transformers/features/json/CreateAssertParseTransformer.js.map +1 -0
- package/lib/transformers/features/{stringifiers → json}/CreateAssertStringifyTransformer.js +2 -2
- package/lib/transformers/features/json/CreateAssertStringifyTransformer.js.map +1 -0
- package/lib/transformers/features/{parsers → json}/CreateIsParseTransformer.js +2 -2
- package/lib/transformers/features/json/CreateIsParseTransformer.js.map +1 -0
- package/lib/transformers/features/{stringifiers → json}/CreateIsStringifyTransformer.js +2 -2
- package/lib/transformers/features/json/CreateIsStringifyTransformer.js.map +1 -0
- package/lib/transformers/features/{stringifiers → json}/CreateStringifyTransformer.js +2 -2
- package/lib/transformers/features/json/CreateStringifyTransformer.js.map +1 -0
- package/lib/transformers/features/{parsers → json}/CreateValidateParseTransformer.js +4 -2
- package/lib/transformers/features/json/CreateValidateParseTransformer.js.map +1 -0
- package/lib/transformers/features/{stringifiers → json}/CreateValidateStringifyProgrammer.js +2 -2
- package/lib/transformers/features/json/CreateValidateStringifyProgrammer.js.map +1 -0
- package/lib/transformers/features/{parsers → json}/IsParseTransformer.js +2 -2
- package/lib/transformers/features/json/IsParseTransformer.js.map +1 -0
- package/lib/transformers/features/{stringifiers → json}/IsStringifyTransformer.js +2 -2
- package/lib/transformers/features/json/IsStringifyTransformer.js.map +1 -0
- package/lib/transformers/features/{stringifiers → json}/StringifyTransformer.js +2 -2
- package/lib/transformers/features/json/StringifyTransformer.js.map +1 -0
- package/lib/transformers/features/{parsers → json}/ValidateParseTransformer.js +4 -2
- package/lib/transformers/features/json/ValidateParseTransformer.js.map +1 -0
- package/lib/transformers/features/{stringifiers → json}/ValidateStringifyTransformer.js +2 -2
- package/lib/transformers/features/json/ValidateStringifyTransformer.js.map +1 -0
- package/lib/transformers/features/{miscellaneous → misc}/ApplicationTransformer.js +3 -5
- package/lib/transformers/features/misc/ApplicationTransformer.js.map +1 -0
- package/lib/transformers/features/{miscellaneous → misc}/AssertCloneTransformer.js +4 -2
- package/lib/transformers/features/misc/AssertCloneTransformer.js.map +1 -0
- package/lib/transformers/features/{miscellaneous → misc}/AssertPruneTransformer.js +4 -2
- package/lib/transformers/features/misc/AssertPruneTransformer.js.map +1 -0
- package/lib/transformers/features/{miscellaneous → misc}/CloneTransformer.js +2 -2
- package/lib/transformers/features/misc/CloneTransformer.js.map +1 -0
- package/lib/transformers/features/{miscellaneous → misc}/CreateAssertCloneTransformer.js +4 -2
- package/lib/transformers/features/misc/CreateAssertCloneTransformer.js.map +1 -0
- package/lib/transformers/features/{miscellaneous → misc}/CreateAssertPruneTransformer.js +4 -2
- package/lib/transformers/features/misc/CreateAssertPruneTransformer.js.map +1 -0
- package/lib/transformers/features/{miscellaneous → misc}/CreateCloneTransformer.js +2 -2
- package/lib/transformers/features/misc/CreateCloneTransformer.js.map +1 -0
- package/lib/transformers/features/{miscellaneous → misc}/CreateIsCloneTransformer.js +2 -2
- package/lib/transformers/features/misc/CreateIsCloneTransformer.js.map +1 -0
- package/lib/transformers/features/misc/CreateIsPruneTransformer.js.map +1 -0
- package/lib/transformers/features/{miscellaneous → misc}/CreatePruneTransformer.js +2 -2
- package/lib/transformers/features/misc/CreatePruneTransformer.js.map +1 -0
- package/lib/transformers/features/{miscellaneous → misc}/CreateValidateCloneTransformer.js +4 -2
- package/lib/transformers/features/misc/CreateValidateCloneTransformer.js.map +1 -0
- package/lib/transformers/features/{miscellaneous → misc}/CreateValidatePruneTransformer.js +4 -2
- package/lib/transformers/features/misc/CreateValidatePruneTransformer.js.map +1 -0
- package/lib/transformers/features/{miscellaneous → misc}/IsCloneTransformer.js +2 -2
- package/lib/transformers/features/misc/IsCloneTransformer.js.map +1 -0
- package/lib/transformers/features/misc/IsPruneTransformer.js.map +1 -0
- package/lib/transformers/features/{miscellaneous → misc}/LiteralsTransformer.js +2 -2
- package/lib/transformers/features/misc/LiteralsTransformer.js.map +1 -0
- package/lib/transformers/features/misc/MetadataTransformer.js.map +1 -0
- package/lib/transformers/features/{miscellaneous → misc}/PruneTransformer.js +2 -2
- package/lib/transformers/features/misc/PruneTransformer.js.map +1 -0
- package/lib/transformers/features/{miscellaneous → misc}/ValidateCloneTransformer.js +4 -2
- package/lib/transformers/features/misc/ValidateCloneTransformer.js.map +1 -0
- package/lib/transformers/features/{miscellaneous → misc}/ValidatePruneTransformer.js +4 -2
- package/lib/transformers/features/misc/ValidatePruneTransformer.js.map +1 -0
- package/lib/transformers/features/protobuf/MessageTransformer.d.ts +5 -0
- package/lib/transformers/features/protobuf/MessageTransformer.js +20 -0
- package/lib/transformers/features/protobuf/MessageTransformer.js.map +1 -0
- package/lib/utils/NameEncoder.d.ts +4 -0
- package/lib/utils/NameEncoder.js +89 -0
- package/lib/utils/NameEncoder.js.map +1 -0
- package/package.json +1 -1
- package/src/factories/MetadataTagFactory.ts +362 -355
- package/src/factories/ProtocolFactory.ts +80 -0
- package/src/factories/internal/protocols/ProtocolMetadataUtil.ts +180 -0
- package/src/factories/internal/protocols/emplace_protocol_object.ts +25 -0
- package/src/factories/internal/protocols/emplace_protocol_property.ts +12 -0
- package/src/factories/internal/protocols/iterate_protocol_atomic.ts +34 -0
- package/src/factories/internal/protocols/iterate_protocol_constant.ts +27 -0
- package/src/factories/internal/protocols/iterate_protocol_main.ts +19 -0
- package/src/factories/internal/protocols/iterate_protocol_map.ts +58 -0
- package/src/factories/internal/protocols/iterate_protocol_metadata.ts +96 -0
- package/src/factories/internal/protocols/iterate_protocol_native.ts +34 -0
- package/src/factories/internal/protocols/iterate_protocol_never.ts +1 -0
- package/src/factories/internal/protocols/iterate_protocol_object.ts +110 -0
- package/src/factories/internal/protocols/iterate_protocol_repeated.ts +34 -0
- package/src/factories/internal/protocols/iterate_protocol_tuple.ts +29 -0
- package/src/functional/$number.ts +3 -2
- package/src/functional/$proto_bytes.ts +25 -0
- package/src/functional/$proto_field.ts +30 -0
- package/src/functional/$proto_float.ts +37 -0
- package/src/functional/$proto_i32.ts +29 -0
- package/src/functional/$proto_i64.ts +37 -0
- package/src/functional/$proto_size.ts +82 -0
- package/src/functional/$proto_string.ts +24 -0
- package/src/functional/$varint.ts +130 -0
- package/src/functional/$zigzag.ts +39 -0
- package/src/json.ts +648 -0
- package/src/messages/IProtocolMap.ts +5 -0
- package/src/messages/IProtocolMessage.ts +6 -0
- package/src/messages/IProtocolProperty.ts +13 -0
- package/src/metadata/IMetadataTag.ts +113 -105
- package/src/metadata/Metadata.ts +606 -603
- package/src/misc.ts +651 -0
- package/src/module.ts +781 -2038
- package/src/programmers/IsPruneProgrammer.ts +2 -2
- package/src/programmers/internal/application_alias.ts +2 -2
- package/src/programmers/internal/application_array.ts +2 -2
- package/src/programmers/internal/application_native.ts +2 -2
- package/src/programmers/internal/application_number.ts +77 -74
- package/src/programmers/internal/application_object.ts +3 -3
- package/src/programmers/internal/application_resolved.ts +2 -2
- package/src/programmers/internal/application_schema.ts +2 -2
- package/src/programmers/internal/application_tuple.ts +2 -2
- package/src/programmers/{ApplicationProgrammer.ts → json/JsonApplicationProgrammer.ts} +6 -6
- package/src/programmers/{AssertParseProgrammer.ts → json/JsonAssertParseProgrammer.ts} +6 -6
- package/src/programmers/{AssertStringifyProgrammer.ts → json/JsonAssertStringifyProgrammer.ts} +8 -8
- package/src/programmers/{IsParseProgrammer.ts → json/JsonIsParseProgrammer.ts} +6 -6
- package/src/programmers/{IsStringifyProgrammer.ts → json/JsonIsStringifyProgrammer.ts} +7 -7
- package/src/programmers/{StringifyProgrammer.ts → json/JsonStringifyProgrammer.ts} +40 -39
- package/src/programmers/{ValidateParseProgrammer.ts → json/JsonValidateParseProgrammer.ts} +6 -6
- package/src/programmers/{ValidateStringifyProgrammer.ts → json/JsonValidateStringifyProgrammer.ts} +8 -8
- package/src/programmers/{AssertCloneProgrammer.ts → misc/MiscAssertCloneProgrammer.ts} +8 -8
- package/src/programmers/{AssertPruneProgrammer.ts → misc/MiscAssertPruneProgrammer.ts} +8 -8
- package/src/programmers/{CloneProgrammer.ts → misc/MiscCloneProgrammer.ts} +24 -24
- package/src/programmers/{IsCloneProgrammer.ts → misc/MiscIsCloneProgrammer.ts} +8 -8
- package/src/programmers/{LiteralsProgrammer.ts → misc/MiscLiteralsProgrammer.ts} +63 -62
- package/src/programmers/{PruneProgrammer.ts → misc/MiscPruneProgrammer.ts} +24 -24
- package/src/programmers/{ValidateCloneProgrammer.ts → misc/MiscValidateCloneProgrammer.ts} +8 -8
- package/src/programmers/{ValidatePruneProgrammer.ts → misc/MiscValidatePruneProgrammer.ts} +8 -8
- package/src/programmers/protobuf/ProtobufMessageProgrammer.ts +126 -0
- package/src/protobuf.ts +18 -0
- package/src/transformers/CallExpressionTransformer.ts +196 -179
- package/src/transformers/features/{validators/AssertTransformer.ts → AssertTransformer.ts} +2 -2
- package/src/transformers/features/{validators/CreateAssertTransformer.ts → CreateAssertTransformer.ts} +2 -2
- package/src/transformers/features/{validators/CreateIsTransformer.ts → CreateIsTransformer.ts} +2 -2
- package/src/transformers/features/{miscellaneous/CreateRandomTransformer.ts → CreateRandomTransformer.ts} +2 -2
- package/src/transformers/features/{validators/CreateValidateTransformer.ts → CreateValidateTransformer.ts} +2 -2
- package/src/transformers/features/{validators/IsTransformer.ts → IsTransformer.ts} +2 -2
- package/src/transformers/features/{miscellaneous/RandomTransformer.ts → RandomTransformer.ts} +2 -2
- package/src/transformers/features/{validators/ValidateTransformer.ts → ValidateTransformer.ts} +2 -2
- package/src/transformers/features/{parsers → json}/AssertParseTransformer.ts +3 -2
- package/src/transformers/features/{stringifiers → json}/AssertStringifyTransformer.ts +2 -2
- package/src/transformers/features/{parsers → json}/CreateAssertParseTransformer.ts +3 -2
- package/src/transformers/features/{stringifiers → json}/CreateAssertStringifyTransformer.ts +2 -2
- package/src/transformers/features/{parsers → json}/CreateIsParseTransformer.ts +2 -2
- package/src/transformers/features/{stringifiers → json}/CreateIsStringifyTransformer.ts +1 -1
- package/src/transformers/features/{stringifiers → json}/CreateStringifyTransformer.ts +2 -2
- package/src/transformers/features/{parsers → json}/CreateValidateParseTransformer.ts +3 -2
- package/src/transformers/features/{stringifiers → json}/CreateValidateStringifyProgrammer.ts +2 -2
- package/src/transformers/features/{parsers → json}/IsParseTransformer.ts +2 -2
- package/src/transformers/features/{stringifiers → json}/IsStringifyTransformer.ts +1 -1
- package/src/transformers/features/{stringifiers → json}/StringifyTransformer.ts +2 -2
- package/src/transformers/features/{parsers → json}/ValidateParseTransformer.ts +3 -2
- package/src/transformers/features/{stringifiers → json}/ValidateStringifyTransformer.ts +2 -2
- package/src/transformers/features/{miscellaneous → misc}/ApplicationTransformer.ts +102 -104
- package/src/transformers/features/{miscellaneous → misc}/AssertCloneTransformer.ts +3 -2
- package/src/transformers/features/{miscellaneous → misc}/AssertPruneTransformer.ts +3 -2
- package/src/transformers/features/{miscellaneous → misc}/CloneTransformer.ts +2 -2
- package/src/transformers/features/{miscellaneous → misc}/CreateAssertCloneTransformer.ts +3 -2
- package/src/transformers/features/{miscellaneous → misc}/CreateAssertPruneTransformer.ts +3 -2
- package/src/transformers/features/{miscellaneous → misc}/CreateCloneTransformer.ts +2 -2
- package/src/transformers/features/{miscellaneous → misc}/CreateIsCloneTransformer.ts +2 -2
- package/src/transformers/features/{miscellaneous → misc}/CreatePruneTransformer.ts +2 -2
- package/src/transformers/features/{miscellaneous → misc}/CreateValidateCloneTransformer.ts +3 -2
- package/src/transformers/features/{miscellaneous → misc}/CreateValidatePruneTransformer.ts +3 -2
- package/src/transformers/features/{miscellaneous → misc}/IsCloneTransformer.ts +2 -2
- package/src/transformers/features/{miscellaneous → misc}/LiteralsTransformer.ts +2 -2
- package/src/transformers/features/{miscellaneous → misc}/PruneTransformer.ts +2 -2
- package/src/transformers/features/{miscellaneous → misc}/ValidateCloneTransformer.ts +3 -2
- package/src/transformers/features/{miscellaneous → misc}/ValidatePruneTransformer.ts +3 -2
- package/src/transformers/features/protobuf/MessageTransformer.ts +31 -0
- package/src/utils/NameEncoder.ts +32 -0
- package/lib/programmers/ApplicationProgrammer.d.ts +0 -8
- package/lib/programmers/ApplicationProgrammer.js.map +0 -1
- package/lib/programmers/AssertCloneProgrammer.js.map +0 -1
- package/lib/programmers/AssertParseProgrammer.js.map +0 -1
- package/lib/programmers/AssertPruneProgrammer.js.map +0 -1
- package/lib/programmers/AssertStringifyProgrammer.js.map +0 -1
- package/lib/programmers/CloneProgrammer.js.map +0 -1
- package/lib/programmers/IsCloneProgrammer.js.map +0 -1
- package/lib/programmers/IsParseProgrammer.d.ts +0 -5
- package/lib/programmers/IsParseProgrammer.js.map +0 -1
- package/lib/programmers/IsStringifyProgrammer.js.map +0 -1
- package/lib/programmers/LiteralsProgrammer.js.map +0 -1
- package/lib/programmers/PruneProgrammer.js.map +0 -1
- package/lib/programmers/StringifyProgrammer.js.map +0 -1
- package/lib/programmers/ValidateCloneProgrammer.d.ts +0 -5
- package/lib/programmers/ValidateCloneProgrammer.js.map +0 -1
- package/lib/programmers/ValidateParseProgrammer.d.ts +0 -5
- package/lib/programmers/ValidateParseProgrammer.js.map +0 -1
- package/lib/programmers/ValidatePruneProgrammer.d.ts +0 -5
- package/lib/programmers/ValidatePruneProgrammer.js.map +0 -1
- package/lib/programmers/ValidateStringifyProgrammer.d.ts +0 -5
- package/lib/programmers/ValidateStringifyProgrammer.js.map +0 -1
- package/lib/transformers/features/miscellaneous/ApplicationTransformer.js.map +0 -1
- package/lib/transformers/features/miscellaneous/AssertCloneTransformer.js.map +0 -1
- package/lib/transformers/features/miscellaneous/AssertPruneTransformer.js.map +0 -1
- package/lib/transformers/features/miscellaneous/CloneTransformer.js.map +0 -1
- package/lib/transformers/features/miscellaneous/CreateAssertCloneTransformer.js.map +0 -1
- package/lib/transformers/features/miscellaneous/CreateAssertPruneTransformer.js.map +0 -1
- package/lib/transformers/features/miscellaneous/CreateCloneTransformer.js.map +0 -1
- package/lib/transformers/features/miscellaneous/CreateIsCloneTransformer.js.map +0 -1
- package/lib/transformers/features/miscellaneous/CreateIsPruneTransformer.js.map +0 -1
- package/lib/transformers/features/miscellaneous/CreatePruneTransformer.js.map +0 -1
- package/lib/transformers/features/miscellaneous/CreateRandomTransformer.js.map +0 -1
- package/lib/transformers/features/miscellaneous/CreateValidateCloneTransformer.js.map +0 -1
- package/lib/transformers/features/miscellaneous/CreateValidatePruneTransformer.js.map +0 -1
- package/lib/transformers/features/miscellaneous/IsCloneTransformer.js.map +0 -1
- package/lib/transformers/features/miscellaneous/IsPruneTransformer.js.map +0 -1
- package/lib/transformers/features/miscellaneous/LiteralsTransformer.js.map +0 -1
- package/lib/transformers/features/miscellaneous/MetadataTransformer.js.map +0 -1
- package/lib/transformers/features/miscellaneous/PruneTransformer.js.map +0 -1
- package/lib/transformers/features/miscellaneous/RandomTransformer.js.map +0 -1
- package/lib/transformers/features/miscellaneous/ValidateCloneTransformer.js.map +0 -1
- package/lib/transformers/features/miscellaneous/ValidatePruneTransformer.js.map +0 -1
- package/lib/transformers/features/parsers/AssertParseTransformer.js.map +0 -1
- package/lib/transformers/features/parsers/CreateAssertParseTransformer.js.map +0 -1
- package/lib/transformers/features/parsers/CreateIsParseTransformer.js.map +0 -1
- package/lib/transformers/features/parsers/CreateValidateParseTransformer.js.map +0 -1
- package/lib/transformers/features/parsers/IsParseTransformer.js.map +0 -1
- package/lib/transformers/features/parsers/ValidateParseTransformer.js.map +0 -1
- package/lib/transformers/features/stringifiers/AssertStringifyTransformer.js.map +0 -1
- package/lib/transformers/features/stringifiers/CreateAssertStringifyTransformer.js.map +0 -1
- package/lib/transformers/features/stringifiers/CreateIsStringifyTransformer.js.map +0 -1
- package/lib/transformers/features/stringifiers/CreateStringifyTransformer.js.map +0 -1
- package/lib/transformers/features/stringifiers/CreateValidateStringifyProgrammer.js.map +0 -1
- package/lib/transformers/features/stringifiers/IsStringifyTransformer.js.map +0 -1
- package/lib/transformers/features/stringifiers/StringifyTransformer.js.map +0 -1
- package/lib/transformers/features/stringifiers/ValidateStringifyTransformer.js.map +0 -1
- package/lib/transformers/features/validators/AssertTransformer.d.ts +0 -3
- package/lib/transformers/features/validators/AssertTransformer.js.map +0 -1
- package/lib/transformers/features/validators/CreateAssertTransformer.d.ts +0 -3
- package/lib/transformers/features/validators/CreateAssertTransformer.js.map +0 -1
- package/lib/transformers/features/validators/CreateIsTransformer.d.ts +0 -3
- package/lib/transformers/features/validators/CreateIsTransformer.js.map +0 -1
- package/lib/transformers/features/validators/CreateValidateTransformer.d.ts +0 -3
- package/lib/transformers/features/validators/CreateValidateTransformer.js.map +0 -1
- package/lib/transformers/features/validators/IsTransformer.d.ts +0 -3
- package/lib/transformers/features/validators/IsTransformer.js.map +0 -1
- package/lib/transformers/features/validators/ValidateTransformer.d.ts +0 -3
- package/lib/transformers/features/validators/ValidateTransformer.js.map +0 -1
- /package/lib/transformers/features/{parsers → json}/AssertParseTransformer.d.ts +0 -0
- /package/lib/transformers/features/{stringifiers → json}/AssertStringifyTransformer.d.ts +0 -0
- /package/lib/transformers/features/{parsers → json}/CreateAssertParseTransformer.d.ts +0 -0
- /package/lib/transformers/features/{stringifiers → json}/CreateAssertStringifyTransformer.d.ts +0 -0
- /package/lib/transformers/features/{parsers → json}/CreateIsParseTransformer.d.ts +0 -0
- /package/lib/transformers/features/{stringifiers → json}/CreateIsStringifyTransformer.d.ts +0 -0
- /package/lib/transformers/features/{stringifiers → json}/CreateStringifyTransformer.d.ts +0 -0
- /package/lib/transformers/features/{parsers → json}/CreateValidateParseTransformer.d.ts +0 -0
- /package/lib/transformers/features/{stringifiers → json}/CreateValidateStringifyProgrammer.d.ts +0 -0
- /package/lib/transformers/features/{parsers → json}/IsParseTransformer.d.ts +0 -0
- /package/lib/transformers/features/{stringifiers → json}/IsStringifyTransformer.d.ts +0 -0
- /package/lib/transformers/features/{stringifiers → json}/StringifyTransformer.d.ts +0 -0
- /package/lib/transformers/features/{parsers → json}/ValidateParseTransformer.d.ts +0 -0
- /package/lib/transformers/features/{stringifiers → json}/ValidateStringifyTransformer.d.ts +0 -0
- /package/lib/transformers/features/{miscellaneous → misc}/ApplicationTransformer.d.ts +0 -0
- /package/lib/transformers/features/{miscellaneous → misc}/AssertCloneTransformer.d.ts +0 -0
- /package/lib/transformers/features/{miscellaneous → misc}/AssertPruneTransformer.d.ts +0 -0
- /package/lib/transformers/features/{miscellaneous → misc}/CloneTransformer.d.ts +0 -0
- /package/lib/transformers/features/{miscellaneous → misc}/CreateAssertCloneTransformer.d.ts +0 -0
- /package/lib/transformers/features/{miscellaneous → misc}/CreateAssertPruneTransformer.d.ts +0 -0
- /package/lib/transformers/features/{miscellaneous → misc}/CreateCloneTransformer.d.ts +0 -0
- /package/lib/transformers/features/{miscellaneous → misc}/CreateIsCloneTransformer.d.ts +0 -0
- /package/lib/transformers/features/{miscellaneous → misc}/CreateIsPruneTransformer.d.ts +0 -0
- /package/lib/transformers/features/{miscellaneous → misc}/CreateIsPruneTransformer.js +0 -0
- /package/lib/transformers/features/{miscellaneous → misc}/CreatePruneTransformer.d.ts +0 -0
- /package/lib/transformers/features/{miscellaneous → misc}/CreateValidateCloneTransformer.d.ts +0 -0
- /package/lib/transformers/features/{miscellaneous → misc}/CreateValidatePruneTransformer.d.ts +0 -0
- /package/lib/transformers/features/{miscellaneous → misc}/IsCloneTransformer.d.ts +0 -0
- /package/lib/transformers/features/{miscellaneous → misc}/IsPruneTransformer.d.ts +0 -0
- /package/lib/transformers/features/{miscellaneous → misc}/IsPruneTransformer.js +0 -0
- /package/lib/transformers/features/{miscellaneous → misc}/LiteralsTransformer.d.ts +0 -0
- /package/lib/transformers/features/{miscellaneous → misc}/MetadataTransformer.d.ts +0 -0
- /package/lib/transformers/features/{miscellaneous → misc}/MetadataTransformer.js +0 -0
- /package/lib/transformers/features/{miscellaneous → misc}/PruneTransformer.d.ts +0 -0
- /package/lib/transformers/features/{miscellaneous → misc}/ValidateCloneTransformer.d.ts +0 -0
- /package/lib/transformers/features/{miscellaneous → misc}/ValidatePruneTransformer.d.ts +0 -0
- /package/src/transformers/features/{miscellaneous → misc}/CreateIsPruneTransformer.ts +0 -0
- /package/src/transformers/features/{miscellaneous → misc}/IsPruneTransformer.ts +0 -0
- /package/src/transformers/features/{miscellaneous → misc}/MetadataTransformer.ts +0 -0
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import ts from "typescript";
|
|
2
|
+
|
|
3
|
+
import { Metadata } from "../metadata/Metadata";
|
|
4
|
+
|
|
5
|
+
import { IProtocolMessage } from "../messages/IProtocolMessage";
|
|
6
|
+
import { MetadataCollection } from "./MetadataCollection";
|
|
7
|
+
import { MetadataFactory } from "./MetadataFactory";
|
|
8
|
+
import { emplace_protocol_object } from "./internal/protocols/emplace_protocol_object";
|
|
9
|
+
import { iterate_protocol_main } from "./internal/protocols/iterate_protocol_main";
|
|
10
|
+
|
|
11
|
+
export namespace ProtocolFactory {
|
|
12
|
+
export const metadata =
|
|
13
|
+
(checker: ts.TypeChecker) =>
|
|
14
|
+
(collection: MetadataCollection) =>
|
|
15
|
+
(type: ts.Type) =>
|
|
16
|
+
MetadataFactory.analyze(checker)({
|
|
17
|
+
resolve: false,
|
|
18
|
+
constant: true,
|
|
19
|
+
absorb: true,
|
|
20
|
+
validate: (meta) => {
|
|
21
|
+
if (meta.any) throw new Error(ErrorMessages.NO_ANY);
|
|
22
|
+
else if (meta.functional && meta.size() !== 1)
|
|
23
|
+
throw new Error(ErrorMessages.NO_FUNCTIONAL);
|
|
24
|
+
else if (meta.objects.find((o) => o.name === "__Main"))
|
|
25
|
+
throw new Error(ErrorMessages.NO_MAIN);
|
|
26
|
+
else if (meta.objects.find((o) => o.name === "__Timestamp"))
|
|
27
|
+
throw new Error(ErrorMessages.NO_TIMESTAMP);
|
|
28
|
+
else if (
|
|
29
|
+
meta.objects.some((o) =>
|
|
30
|
+
o.properties.some((p) => !is_atomic_key(p.key)),
|
|
31
|
+
) ||
|
|
32
|
+
meta.maps.some((m) => !is_atomic_key(m.key))
|
|
33
|
+
)
|
|
34
|
+
throw new Error(ErrorMessages.NOT_ALLOWED_KEY);
|
|
35
|
+
},
|
|
36
|
+
})(collection)(type);
|
|
37
|
+
|
|
38
|
+
export const generate =
|
|
39
|
+
(collection: MetadataCollection) =>
|
|
40
|
+
(dict: Map<string, IProtocolMessage>) =>
|
|
41
|
+
(meta: Metadata) => {
|
|
42
|
+
// EMPLACE OBJECTS
|
|
43
|
+
for (const obj of collection.objects())
|
|
44
|
+
emplace_protocol_object(dict)(obj);
|
|
45
|
+
|
|
46
|
+
// WHEN NOT OBJECT, WRAP IT INTO A FAKE MAIN OBJECT
|
|
47
|
+
iterate_protocol_main(dict)(meta);
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
const is_atomic_key = (key: Metadata) => {
|
|
51
|
+
if (
|
|
52
|
+
key.required &&
|
|
53
|
+
key.nullable === false &&
|
|
54
|
+
key.functional === false &&
|
|
55
|
+
key.resolved === null &&
|
|
56
|
+
key.size() ===
|
|
57
|
+
key.atomics.length +
|
|
58
|
+
key.constants
|
|
59
|
+
.map((c) => c.values.length)
|
|
60
|
+
.reduce((a, b) => a + b, 0) +
|
|
61
|
+
key.templates.length
|
|
62
|
+
) {
|
|
63
|
+
const set: Set<string> = new Set();
|
|
64
|
+
for (const atomic of key.atomics) set.add(atomic);
|
|
65
|
+
for (const constant of key.constants) set.add(constant.type);
|
|
66
|
+
if (key.templates.length) set.add("string");
|
|
67
|
+
|
|
68
|
+
return set.size === 1;
|
|
69
|
+
}
|
|
70
|
+
return false;
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
const enum ErrorMessages {
|
|
75
|
+
NO_ANY = `Error on typia.message(): any type is not supported in protocol buffer.`,
|
|
76
|
+
NO_FUNCTIONAL = `Error on typia.message(): functional type is not supported in protocol buffer.`,
|
|
77
|
+
NO_MAIN = `Error on typia.message(): reserved type "__Main" has been detected.`,
|
|
78
|
+
NO_TIMESTAMP = `Error on typia.message(): reserved type "__Timestamp" has been detected.`,
|
|
79
|
+
NOT_ALLOWED_KEY = `Error on typia.message(): only atomic key type is supported in protocol buffer.`,
|
|
80
|
+
}
|
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
import { IMetadataTag } from "../../../metadata/IMetadataTag";
|
|
2
|
+
import { Metadata } from "../../../metadata/Metadata";
|
|
3
|
+
import { MetadataArray } from "../../../metadata/MetadataArray";
|
|
4
|
+
import { MetadataObject } from "../../../metadata/MetadataObject";
|
|
5
|
+
import { MetadataProperty } from "../../../metadata/MetadataProperty";
|
|
6
|
+
|
|
7
|
+
import { Atomic } from "../../../typings/Atomic";
|
|
8
|
+
|
|
9
|
+
export namespace ProtocolMetadataUtil {
|
|
10
|
+
export function size(meta: Metadata): number {
|
|
11
|
+
return (
|
|
12
|
+
meta.atomics.length +
|
|
13
|
+
meta.constants.filter(
|
|
14
|
+
(c) =>
|
|
15
|
+
meta.atomics.find((type) => c.type === type) === undefined,
|
|
16
|
+
).length +
|
|
17
|
+
(meta.templates.length !== 0 &&
|
|
18
|
+
meta.atomics.find((type) => type === "string") === undefined &&
|
|
19
|
+
meta.constants.find((c) => c.type === "string") === undefined
|
|
20
|
+
? 1
|
|
21
|
+
: 0) +
|
|
22
|
+
meta.tuples.length +
|
|
23
|
+
meta.arrays.length +
|
|
24
|
+
meta.sets.length +
|
|
25
|
+
meta.maps.length +
|
|
26
|
+
meta.objects.length +
|
|
27
|
+
meta.natives.filter((n) => n === "Date").length +
|
|
28
|
+
(meta.natives.filter((n) => n !== "Date").length ? 1 : 0)
|
|
29
|
+
);
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
export function standalone(meta: Metadata): boolean {
|
|
33
|
+
return (
|
|
34
|
+
size(meta) === 1 &&
|
|
35
|
+
meta.required === true &&
|
|
36
|
+
meta.nullable === false &&
|
|
37
|
+
meta.tuples.length === 0 &&
|
|
38
|
+
meta.arrays.length === 0 &&
|
|
39
|
+
meta.sets.length === 0 &&
|
|
40
|
+
meta.maps.length === 0 &&
|
|
41
|
+
meta.objects.every((obj) =>
|
|
42
|
+
obj.properties.every((p) => p.key.isSoleLiteral()),
|
|
43
|
+
)
|
|
44
|
+
);
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
export function regular(obj: MetadataObject): boolean {
|
|
48
|
+
return obj.properties.every((p) => p.key.isSoleLiteral());
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
export function object(name: string, index: number): MetadataObject {
|
|
52
|
+
return MetadataObject.create({
|
|
53
|
+
name,
|
|
54
|
+
index,
|
|
55
|
+
properties: [],
|
|
56
|
+
description: undefined,
|
|
57
|
+
jsDocTags: [],
|
|
58
|
+
validated: false,
|
|
59
|
+
recursive: false,
|
|
60
|
+
nullables: [false],
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
export function property(
|
|
65
|
+
key: string,
|
|
66
|
+
value: Metadata,
|
|
67
|
+
tags: IMetadataTag[],
|
|
68
|
+
): MetadataProperty {
|
|
69
|
+
return MetadataProperty.create({
|
|
70
|
+
key: (() => {
|
|
71
|
+
const meta: Metadata = Metadata.initialize();
|
|
72
|
+
meta.constants.push({
|
|
73
|
+
type: "string",
|
|
74
|
+
values: [key],
|
|
75
|
+
});
|
|
76
|
+
return meta;
|
|
77
|
+
})(),
|
|
78
|
+
value: value,
|
|
79
|
+
description: null,
|
|
80
|
+
tags,
|
|
81
|
+
jsDocTags: [],
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
export function array(meta: Metadata): Metadata {
|
|
86
|
+
return Metadata.create({
|
|
87
|
+
any: false,
|
|
88
|
+
required: true,
|
|
89
|
+
optional: false,
|
|
90
|
+
nullable: false,
|
|
91
|
+
functional: false,
|
|
92
|
+
resolved: null,
|
|
93
|
+
aliases: [],
|
|
94
|
+
atomics: [],
|
|
95
|
+
constants: [],
|
|
96
|
+
templates: [],
|
|
97
|
+
rest: null,
|
|
98
|
+
arrays: [
|
|
99
|
+
MetadataArray.create({
|
|
100
|
+
name: meta.getName(),
|
|
101
|
+
value: meta,
|
|
102
|
+
nullables: [false],
|
|
103
|
+
recursive: false,
|
|
104
|
+
index: null,
|
|
105
|
+
}),
|
|
106
|
+
],
|
|
107
|
+
tuples: [],
|
|
108
|
+
objects: [],
|
|
109
|
+
natives: [],
|
|
110
|
+
sets: [],
|
|
111
|
+
maps: [],
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
export function atomic(type: Atomic.Literal): Metadata {
|
|
116
|
+
return Metadata.create({
|
|
117
|
+
any: false,
|
|
118
|
+
required: true,
|
|
119
|
+
optional: false,
|
|
120
|
+
nullable: false,
|
|
121
|
+
functional: false,
|
|
122
|
+
resolved: null,
|
|
123
|
+
aliases: [],
|
|
124
|
+
atomics: [type],
|
|
125
|
+
constants: [],
|
|
126
|
+
templates: [],
|
|
127
|
+
rest: null,
|
|
128
|
+
arrays: [],
|
|
129
|
+
tuples: [],
|
|
130
|
+
objects: [],
|
|
131
|
+
natives: [],
|
|
132
|
+
sets: [],
|
|
133
|
+
maps: [],
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
export function reference(obj: MetadataObject): Metadata {
|
|
138
|
+
return Metadata.create({
|
|
139
|
+
any: false,
|
|
140
|
+
required: true,
|
|
141
|
+
optional: false,
|
|
142
|
+
nullable: false,
|
|
143
|
+
functional: false,
|
|
144
|
+
resolved: null,
|
|
145
|
+
aliases: [],
|
|
146
|
+
atomics: [],
|
|
147
|
+
constants: [],
|
|
148
|
+
templates: [],
|
|
149
|
+
rest: null,
|
|
150
|
+
arrays: [],
|
|
151
|
+
tuples: [],
|
|
152
|
+
objects: [obj],
|
|
153
|
+
natives: [],
|
|
154
|
+
sets: [],
|
|
155
|
+
maps: [],
|
|
156
|
+
});
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
export function map(elem: Metadata.Entry): Metadata {
|
|
160
|
+
return Metadata.create({
|
|
161
|
+
any: false,
|
|
162
|
+
required: true,
|
|
163
|
+
optional: false,
|
|
164
|
+
nullable: false,
|
|
165
|
+
functional: false,
|
|
166
|
+
resolved: null,
|
|
167
|
+
aliases: [],
|
|
168
|
+
atomics: [],
|
|
169
|
+
constants: [],
|
|
170
|
+
templates: [],
|
|
171
|
+
rest: null,
|
|
172
|
+
arrays: [],
|
|
173
|
+
tuples: [],
|
|
174
|
+
objects: [],
|
|
175
|
+
natives: [],
|
|
176
|
+
sets: [],
|
|
177
|
+
maps: [elem],
|
|
178
|
+
});
|
|
179
|
+
}
|
|
180
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { MetadataObject } from "../../../metadata/MetadataObject";
|
|
2
|
+
|
|
3
|
+
import { IProtocolMessage } from "../../../messages/IProtocolMessage";
|
|
4
|
+
import { emplace_protocol_property } from "./emplace_protocol_property";
|
|
5
|
+
|
|
6
|
+
export const emplace_protocol_object =
|
|
7
|
+
(dict: Map<string, IProtocolMessage>) => (object: MetadataObject) => {
|
|
8
|
+
if (dict.has(object.name)) return;
|
|
9
|
+
|
|
10
|
+
const regular = object.properties.filter((p) => p.key.isSoleLiteral());
|
|
11
|
+
const dynamic = object.properties.filter((p) => !p.key.isSoleLiteral());
|
|
12
|
+
|
|
13
|
+
if (dynamic.length) return;
|
|
14
|
+
|
|
15
|
+
const output: IProtocolMessage = {
|
|
16
|
+
name: object.name,
|
|
17
|
+
properties: [],
|
|
18
|
+
};
|
|
19
|
+
dict.set(object.name, output);
|
|
20
|
+
|
|
21
|
+
output.properties.push(
|
|
22
|
+
...regular.map((prop) => emplace_protocol_property(dict)(prop)),
|
|
23
|
+
);
|
|
24
|
+
return output;
|
|
25
|
+
};
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { MetadataProperty } from "../../../metadata/MetadataProperty";
|
|
2
|
+
|
|
3
|
+
import { IProtocolMessage } from "../../../messages/IProtocolMessage";
|
|
4
|
+
import { IProtocolProperty } from "../../../messages/IProtocolProperty";
|
|
5
|
+
import { iterate_protocol_metadata } from "./iterate_protocol_metadata";
|
|
6
|
+
|
|
7
|
+
export const emplace_protocol_property =
|
|
8
|
+
(dict: Map<string, IProtocolMessage>) =>
|
|
9
|
+
(property: MetadataProperty): IProtocolProperty => ({
|
|
10
|
+
key: property.key.getSoleLiteral()!,
|
|
11
|
+
...iterate_protocol_metadata(dict)(property.value)(property.tags),
|
|
12
|
+
});
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { IMetadataTag } from "../../../metadata/IMetadataTag";
|
|
2
|
+
|
|
3
|
+
import { Atomic } from "../../../typings/Atomic";
|
|
4
|
+
|
|
5
|
+
export const iterate_protocol_atomic =
|
|
6
|
+
(tags: IMetadataTag[]) => (type: Atomic.Literal) => {
|
|
7
|
+
if (type === "boolean") return "bool";
|
|
8
|
+
else if (type === "number") return number(tags);
|
|
9
|
+
else if (type === "bigint") return bigint(tags);
|
|
10
|
+
else return "string";
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
const number = (tagList: IMetadataTag[]) => {
|
|
14
|
+
const filtered: IMetadataTag.INumberType[] = tagList.filter(
|
|
15
|
+
(tag) => tag.kind === "type",
|
|
16
|
+
) as IMetadataTag.INumberType[];
|
|
17
|
+
|
|
18
|
+
for (const { value } of filtered)
|
|
19
|
+
if (value === "int") return "int32";
|
|
20
|
+
else if (value === "uint") return "uint32";
|
|
21
|
+
return "double";
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
const bigint = (tagList: IMetadataTag[]) => {
|
|
25
|
+
const filtered: IMetadataTag.INumberType[] = tagList.filter(
|
|
26
|
+
(tag) =>
|
|
27
|
+
tag.kind === "type" &&
|
|
28
|
+
(tag.value === "int64" || tag.value === "uint64"),
|
|
29
|
+
) as IMetadataTag.INumberType[];
|
|
30
|
+
|
|
31
|
+
for (const { value } of filtered)
|
|
32
|
+
if (value === "int64" || value === "uint64") return value;
|
|
33
|
+
return "int64";
|
|
34
|
+
};
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { MetadataConstant } from "../../../metadata/MetadataConstant";
|
|
2
|
+
|
|
3
|
+
export const iterate_protocol_constant = ({
|
|
4
|
+
type,
|
|
5
|
+
values,
|
|
6
|
+
}: MetadataConstant) => {
|
|
7
|
+
if (type === "boolean") return "bool";
|
|
8
|
+
else if (type === "number") return number(values);
|
|
9
|
+
else if (type === "bigint") return bigint(values);
|
|
10
|
+
else return "string";
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
const bigint = (values: bigint[]): string => {
|
|
14
|
+
return values.every((v) => v >= BigInt(0)) ? "uint64" : "int64";
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
const number = (values: number[]): string => {
|
|
18
|
+
return values.some((v) => Math.floor(v) !== v)
|
|
19
|
+
? "double"
|
|
20
|
+
: values.every((v) => v >= 0)
|
|
21
|
+
? values.every((v) => v <= 2 ** 64 - 1)
|
|
22
|
+
? "uint32"
|
|
23
|
+
: "uint64"
|
|
24
|
+
: values.every((v) => -(2 ** 31) <= v && v <= 2 ** 31 - 1)
|
|
25
|
+
? "int32"
|
|
26
|
+
: "int64";
|
|
27
|
+
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { Metadata } from "../../../metadata/Metadata";
|
|
2
|
+
|
|
3
|
+
import { IProtocolMessage } from "../../../messages/IProtocolMessage";
|
|
4
|
+
import { ProtocolMetadataUtil } from "./ProtocolMetadataUtil";
|
|
5
|
+
import { emplace_protocol_object } from "./emplace_protocol_object";
|
|
6
|
+
|
|
7
|
+
export const iterate_protocol_main =
|
|
8
|
+
(dict: Map<string, IProtocolMessage>) =>
|
|
9
|
+
(meta: Metadata): string => {
|
|
10
|
+
// ONLY ONE OBJECT TYPE
|
|
11
|
+
if (ProtocolMetadataUtil.standalone(meta) && meta.objects.length === 1)
|
|
12
|
+
return meta.getName();
|
|
13
|
+
|
|
14
|
+
const obj = ProtocolMetadataUtil.object("__Main", dict.size);
|
|
15
|
+
obj.properties.push(ProtocolMetadataUtil.property("value", meta, []));
|
|
16
|
+
emplace_protocol_object(dict)(obj);
|
|
17
|
+
|
|
18
|
+
return obj.name;
|
|
19
|
+
};
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { Metadata } from "../../../metadata/Metadata";
|
|
2
|
+
import { MetadataObject } from "../../../metadata/MetadataObject";
|
|
3
|
+
|
|
4
|
+
import { IProtocolMap } from "../../../messages/IProtocolMap";
|
|
5
|
+
import { IProtocolMessage } from "../../../messages/IProtocolMessage";
|
|
6
|
+
import { ProtocolMetadataUtil } from "./ProtocolMetadataUtil";
|
|
7
|
+
import { emplace_protocol_object } from "./emplace_protocol_object";
|
|
8
|
+
import { iterate_protocol_atomic } from "./iterate_protocol_atomic";
|
|
9
|
+
import { iterate_protocol_constant } from "./iterate_protocol_constant";
|
|
10
|
+
import { iterate_protocol_metadata } from "./iterate_protocol_metadata";
|
|
11
|
+
|
|
12
|
+
export const iterate_protocol_map =
|
|
13
|
+
(sole: boolean) =>
|
|
14
|
+
(dict: Map<string, IProtocolMessage>) =>
|
|
15
|
+
(prop: Metadata.Entry): string | IProtocolMap => {
|
|
16
|
+
if (sole === true)
|
|
17
|
+
return {
|
|
18
|
+
type: "map",
|
|
19
|
+
key: getKeyName(prop.key),
|
|
20
|
+
value: getValueName(dict)(prop.value),
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
const obj: MetadataObject = ProtocolMetadataUtil.object(
|
|
24
|
+
`Map.Wrapper<${prop.key.getName()}, ${prop.value.getName()}>`,
|
|
25
|
+
dict.size,
|
|
26
|
+
);
|
|
27
|
+
obj.properties.push(
|
|
28
|
+
ProtocolMetadataUtil.property(
|
|
29
|
+
"value",
|
|
30
|
+
ProtocolMetadataUtil.map(prop),
|
|
31
|
+
[],
|
|
32
|
+
),
|
|
33
|
+
);
|
|
34
|
+
emplace_protocol_object(dict)(obj);
|
|
35
|
+
return obj.name;
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
const getKeyName = (meta: Metadata) => {
|
|
39
|
+
for (const atomic of meta.atomics)
|
|
40
|
+
return iterate_protocol_atomic([])(atomic);
|
|
41
|
+
for (const constant of meta.constants)
|
|
42
|
+
return iterate_protocol_constant(constant);
|
|
43
|
+
return "string";
|
|
44
|
+
};
|
|
45
|
+
|
|
46
|
+
const getValueName =
|
|
47
|
+
(dict: Map<string, IProtocolMessage>) => (meta: Metadata) => {
|
|
48
|
+
if (ProtocolMetadataUtil.standalone(meta))
|
|
49
|
+
return iterate_protocol_metadata(dict)(meta)([]).oneOf[0]!.type;
|
|
50
|
+
|
|
51
|
+
const obj: MetadataObject = ProtocolMetadataUtil.object(
|
|
52
|
+
`Map.Value<${meta.getName()}>`,
|
|
53
|
+
dict.size,
|
|
54
|
+
);
|
|
55
|
+
obj.properties.push(ProtocolMetadataUtil.property("value", meta, []));
|
|
56
|
+
emplace_protocol_object(dict)(obj);
|
|
57
|
+
return obj.name;
|
|
58
|
+
};
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
import { IMetadataTag } from "../../../metadata/IMetadataTag";
|
|
2
|
+
import { Metadata } from "../../../metadata/Metadata";
|
|
3
|
+
|
|
4
|
+
import { IProtocolMap } from "../../../messages/IProtocolMap";
|
|
5
|
+
import { IProtocolMessage } from "../../../messages/IProtocolMessage";
|
|
6
|
+
import { IProtocolProperty } from "../../../messages/IProtocolProperty";
|
|
7
|
+
import { iterate_protocol_atomic } from "./iterate_protocol_atomic";
|
|
8
|
+
import { iterate_protocol_constant } from "./iterate_protocol_constant";
|
|
9
|
+
import { iterate_protocol_map } from "./iterate_protocol_map";
|
|
10
|
+
import { iterate_protocol_native } from "./iterate_protocol_native";
|
|
11
|
+
import { iterate_protocol_never } from "./iterate_protocol_never";
|
|
12
|
+
import { iterate_protocol_object } from "./iterate_protocol_object";
|
|
13
|
+
import { iterate_protocol_repeated } from "./iterate_protocol_repeated";
|
|
14
|
+
import { iterate_protocol_tuple } from "./iterate_protocol_tuple";
|
|
15
|
+
|
|
16
|
+
export const iterate_protocol_metadata =
|
|
17
|
+
(dict: Map<string, IProtocolMessage>) =>
|
|
18
|
+
(meta: Metadata) =>
|
|
19
|
+
(tags: IMetadataTag[]): Omit<IProtocolProperty, "key"> => {
|
|
20
|
+
// PREPARE ASSETS
|
|
21
|
+
const sole: boolean = meta.size() === 1;
|
|
22
|
+
const bucket: boolean = sole && meta.bucket() === 1;
|
|
23
|
+
const required: boolean =
|
|
24
|
+
(meta.required && !meta.nullable) ||
|
|
25
|
+
(sole &&
|
|
26
|
+
(meta.arrays.length === 1 ||
|
|
27
|
+
meta.sets.length === 1 ||
|
|
28
|
+
meta.maps.length === 1 ||
|
|
29
|
+
(meta.objects.length === 1 &&
|
|
30
|
+
meta.objects[0]!.properties.length === 1 &&
|
|
31
|
+
!meta.objects[0]!.properties[0]?.key.isSoleLiteral())));
|
|
32
|
+
|
|
33
|
+
const oneOf: IProtocolProperty.IOneOf[] = [];
|
|
34
|
+
const add = (type: string | IProtocolMap) => {
|
|
35
|
+
if (oneOf.some((one) => one.type === type)) return;
|
|
36
|
+
oneOf.push({
|
|
37
|
+
type,
|
|
38
|
+
});
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
// WHEN SINGULAR ARRAY TYPE
|
|
42
|
+
if (sole && meta.arrays.length + meta.sets.length === 1) {
|
|
43
|
+
const [container, child] =
|
|
44
|
+
meta.arrays.length === 1
|
|
45
|
+
? (["Array", meta.arrays[0]!.value] as const)
|
|
46
|
+
: (["Set", meta.sets[0]!] as const);
|
|
47
|
+
add(
|
|
48
|
+
iterate_protocol_repeated(container)(true, true)(dict)(child)(
|
|
49
|
+
tags,
|
|
50
|
+
),
|
|
51
|
+
);
|
|
52
|
+
return {
|
|
53
|
+
required,
|
|
54
|
+
oneOf,
|
|
55
|
+
repeated: true,
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
// ATOMIC TYPES
|
|
60
|
+
for (const type of meta.atomics)
|
|
61
|
+
add(iterate_protocol_atomic(tags)(type));
|
|
62
|
+
for (const constant of meta.constants)
|
|
63
|
+
add(iterate_protocol_constant(constant));
|
|
64
|
+
if (meta.templates.length) add("string");
|
|
65
|
+
if (meta.size() === 0) add(iterate_protocol_never());
|
|
66
|
+
|
|
67
|
+
// OBJECT TYPES
|
|
68
|
+
for (const obj of meta.objects)
|
|
69
|
+
add(iterate_protocol_object(sole)(dict)(obj));
|
|
70
|
+
for (const map of meta.maps) add(iterate_protocol_map(sole)(dict)(map));
|
|
71
|
+
for (const native of meta.natives)
|
|
72
|
+
add(iterate_protocol_native(dict)(native));
|
|
73
|
+
|
|
74
|
+
// ARRAY TYPES
|
|
75
|
+
for (const tuple of meta.tuples)
|
|
76
|
+
add(iterate_protocol_tuple(dict)(tuple.elements));
|
|
77
|
+
for (const array of meta.arrays)
|
|
78
|
+
add(
|
|
79
|
+
iterate_protocol_repeated("Array")(false, bucket)(dict)(
|
|
80
|
+
array.value,
|
|
81
|
+
)(tags),
|
|
82
|
+
);
|
|
83
|
+
for (const set of meta.sets)
|
|
84
|
+
add(
|
|
85
|
+
iterate_protocol_repeated("Set")(false, bucket)(dict)(set)(
|
|
86
|
+
tags,
|
|
87
|
+
),
|
|
88
|
+
);
|
|
89
|
+
|
|
90
|
+
// RETURNS
|
|
91
|
+
return {
|
|
92
|
+
required,
|
|
93
|
+
oneOf,
|
|
94
|
+
repeated: false,
|
|
95
|
+
};
|
|
96
|
+
};
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { Metadata } from "../../../metadata/Metadata";
|
|
2
|
+
|
|
3
|
+
import { IProtocolMessage } from "../../../messages/IProtocolMessage";
|
|
4
|
+
import { ProtocolMetadataUtil } from "./ProtocolMetadataUtil";
|
|
5
|
+
import { emplace_protocol_object } from "./emplace_protocol_object";
|
|
6
|
+
|
|
7
|
+
export const iterate_protocol_native =
|
|
8
|
+
(dict: Map<string, IProtocolMessage>) => (native: string) => {
|
|
9
|
+
if (native === "Date") {
|
|
10
|
+
const obj = ProtocolMetadataUtil.object("__Timestamp", dict.size);
|
|
11
|
+
obj.properties.push(
|
|
12
|
+
ProtocolMetadataUtil.property("seconds", integer("bigint"), [
|
|
13
|
+
{
|
|
14
|
+
kind: "type",
|
|
15
|
+
value: "int64",
|
|
16
|
+
},
|
|
17
|
+
]),
|
|
18
|
+
ProtocolMetadataUtil.property("nanos", integer("number"), [
|
|
19
|
+
{
|
|
20
|
+
kind: "type",
|
|
21
|
+
value: "int",
|
|
22
|
+
},
|
|
23
|
+
]),
|
|
24
|
+
);
|
|
25
|
+
emplace_protocol_object(dict)(obj);
|
|
26
|
+
return "__Timestamp";
|
|
27
|
+
} else return "bytes";
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
const integer = (type: "number" | "bigint") => {
|
|
31
|
+
const meta = Metadata.initialize();
|
|
32
|
+
meta.atomics.push(type);
|
|
33
|
+
return meta;
|
|
34
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export const iterate_protocol_never = () => "uint32";
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import { Metadata } from "../../../metadata/Metadata";
|
|
2
|
+
import { MetadataObject } from "../../../metadata/MetadataObject";
|
|
3
|
+
import { MetadataProperty } from "../../../metadata/MetadataProperty";
|
|
4
|
+
|
|
5
|
+
import { Atomic } from "../../../typings/Atomic";
|
|
6
|
+
|
|
7
|
+
import { MapUtil } from "../../../utils/MapUtil";
|
|
8
|
+
|
|
9
|
+
import { IProtocolMap } from "../../../messages/IProtocolMap";
|
|
10
|
+
import { IProtocolMessage } from "../../../messages/IProtocolMessage";
|
|
11
|
+
import { ProtocolMetadataUtil } from "./ProtocolMetadataUtil";
|
|
12
|
+
import { emplace_protocol_object } from "./emplace_protocol_object";
|
|
13
|
+
import { iterate_protocol_metadata } from "./iterate_protocol_metadata";
|
|
14
|
+
|
|
15
|
+
export const iterate_protocol_object =
|
|
16
|
+
(sole: boolean) =>
|
|
17
|
+
(dict: Map<string, IProtocolMessage>) =>
|
|
18
|
+
(obj: MetadataObject): string | IProtocolMap => {
|
|
19
|
+
// ONLY REGULAR PROPERTIES
|
|
20
|
+
const statics: MetadataProperty[] = obj.properties.filter(filter(true));
|
|
21
|
+
const dynamics: Metadata.Entry[] = aggregate(
|
|
22
|
+
obj.properties.filter(filter(false)),
|
|
23
|
+
);
|
|
24
|
+
if (dynamics.length === 0) return obj.name;
|
|
25
|
+
|
|
26
|
+
const regular: MetadataObject | undefined = statics.length
|
|
27
|
+
? (() => {
|
|
28
|
+
const r: MetadataObject = ProtocolMetadataUtil.object(
|
|
29
|
+
`${obj.name}.__Regular`,
|
|
30
|
+
dict.size,
|
|
31
|
+
);
|
|
32
|
+
r.properties.push(...statics);
|
|
33
|
+
emplace_protocol_object(dict)(r);
|
|
34
|
+
return r;
|
|
35
|
+
})()
|
|
36
|
+
: undefined;
|
|
37
|
+
|
|
38
|
+
// ONLY ONE TYPED DYNAMIC PROPERTY EXISTS
|
|
39
|
+
if (regular === undefined && dynamics.length === 1 && sole === true) {
|
|
40
|
+
const { key, value } = dynamics[0]!;
|
|
41
|
+
return {
|
|
42
|
+
type: "map",
|
|
43
|
+
key: key.getName(),
|
|
44
|
+
value: ProtocolMetadataUtil.standalone(value)
|
|
45
|
+
? iterate_protocol_metadata(dict)(value)([]).oneOf[0]!.type
|
|
46
|
+
: (() => {
|
|
47
|
+
const wrapper = ProtocolMetadataUtil.object(
|
|
48
|
+
`${obj.name}.__Wrapper`,
|
|
49
|
+
dict.size,
|
|
50
|
+
);
|
|
51
|
+
wrapper.properties.push(
|
|
52
|
+
ProtocolMetadataUtil.property("value", value, []),
|
|
53
|
+
);
|
|
54
|
+
emplace_protocol_object(dict)(wrapper);
|
|
55
|
+
return wrapper.name;
|
|
56
|
+
})(),
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
// DO WRAP
|
|
61
|
+
const wrapper: MetadataObject = ProtocolMetadataUtil.object(
|
|
62
|
+
`${obj.name}.__Wrapper`,
|
|
63
|
+
dict.size,
|
|
64
|
+
);
|
|
65
|
+
if (regular !== undefined)
|
|
66
|
+
wrapper.properties.push(
|
|
67
|
+
ProtocolMetadataUtil.property(
|
|
68
|
+
"regular",
|
|
69
|
+
ProtocolMetadataUtil.reference(regular),
|
|
70
|
+
[],
|
|
71
|
+
),
|
|
72
|
+
);
|
|
73
|
+
wrapper.properties.push(
|
|
74
|
+
...dynamics.map((map, i) =>
|
|
75
|
+
ProtocolMetadataUtil.property(
|
|
76
|
+
`__map_${i}`,
|
|
77
|
+
ProtocolMetadataUtil.map(map),
|
|
78
|
+
[],
|
|
79
|
+
),
|
|
80
|
+
),
|
|
81
|
+
);
|
|
82
|
+
emplace_protocol_object(dict)(wrapper);
|
|
83
|
+
return wrapper.name;
|
|
84
|
+
};
|
|
85
|
+
|
|
86
|
+
const filter = (regular: boolean) => (prop: MetadataProperty) =>
|
|
87
|
+
regular === prop.key.isSoleLiteral();
|
|
88
|
+
|
|
89
|
+
const aggregate = (properties: MetadataProperty[]): Metadata.Entry[] => {
|
|
90
|
+
const unique: Map<Atomic.Literal, MetadataProperty[]> = new Map();
|
|
91
|
+
for (const prop of properties) {
|
|
92
|
+
if (prop.key.templates)
|
|
93
|
+
MapUtil.take(unique)("string", () => []).push(prop);
|
|
94
|
+
for (const type of prop.key.atomics)
|
|
95
|
+
MapUtil.take(unique)(type, () => []).push(prop);
|
|
96
|
+
for (const { type } of prop.key.constants)
|
|
97
|
+
MapUtil.take(unique)(type, () => []).push(prop);
|
|
98
|
+
}
|
|
99
|
+
const output: Metadata.Entry[] = [];
|
|
100
|
+
for (const [key, properties] of unique) {
|
|
101
|
+
const value: Metadata = properties
|
|
102
|
+
.map((x) => x.value)
|
|
103
|
+
.reduce((x, y) => Metadata.merge(x, y));
|
|
104
|
+
output.push({
|
|
105
|
+
key: ProtocolMetadataUtil.atomic(key),
|
|
106
|
+
value,
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
return output;
|
|
110
|
+
};
|