typia 5.0.0-dev.20230824 → 5.0.0-dev.20230828
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 +1 -2
- package/lib/IRandomGenerator.d.ts +4 -3
- package/lib/executable/TypiaGenerateWizard.js +1 -1
- package/lib/executable/TypiaGenerateWizard.js.map +1 -1
- package/lib/executable/TypiaSetupWizard.js +1 -1
- package/lib/executable/TypiaSetupWizard.js.map +1 -1
- package/lib/executable/setup/PackageManager.js +1 -1
- package/lib/executable/setup/PackageManager.js.map +1 -1
- package/lib/executable/setup/PluginConfigurator.js +2 -2
- package/lib/executable/setup/PluginConfigurator.js.map +1 -1
- package/lib/factories/ExpressionFactory.d.ts +1 -1
- package/lib/factories/ExpressionFactory.js +3 -3
- package/lib/factories/ExpressionFactory.js.map +1 -1
- package/lib/factories/JsonMetadataFactory.d.ts +7 -0
- package/lib/factories/JsonMetadataFactory.js +38 -0
- package/lib/factories/JsonMetadataFactory.js.map +1 -0
- package/lib/factories/LiteralFactory.js +6 -2
- package/lib/factories/LiteralFactory.js.map +1 -1
- package/lib/factories/MetadataCollection.js +0 -2
- package/lib/factories/MetadataCollection.js.map +1 -1
- package/lib/factories/MetadataCommentTagFactory.js +543 -0
- package/lib/factories/MetadataCommentTagFactory.js.map +1 -0
- package/lib/factories/MetadataFactory.d.ts +22 -2
- package/lib/factories/MetadataFactory.js +221 -17
- package/lib/factories/MetadataFactory.js.map +1 -1
- package/lib/factories/MetadataTypeTagFactory.d.ts +7 -0
- package/lib/factories/MetadataTypeTagFactory.js +280 -0
- package/lib/factories/MetadataTypeTagFactory.js.map +1 -0
- package/lib/factories/NumericRangeFactory.d.ts +6 -0
- package/lib/factories/NumericRangeFactory.js +34 -0
- package/lib/factories/NumericRangeFactory.js.map +1 -0
- package/lib/factories/ProtobufFactory.js +109 -73
- package/lib/factories/ProtobufFactory.js.map +1 -1
- package/lib/factories/TypeFactory.d.ts +0 -1
- package/lib/factories/TypeFactory.js +0 -5
- package/lib/factories/TypeFactory.js.map +1 -1
- package/lib/factories/internal/metadata/emend_metadata_atomics.js +7 -1
- package/lib/factories/internal/metadata/emend_metadata_atomics.js.map +1 -1
- package/lib/factories/internal/metadata/emplace_metadata_alias.d.ts +1 -1
- package/lib/factories/internal/metadata/emplace_metadata_alias.js +20 -19
- package/lib/factories/internal/metadata/emplace_metadata_alias.js.map +1 -1
- package/lib/factories/internal/metadata/emplace_metadata_array_type.d.ts +1 -1
- package/lib/factories/internal/metadata/emplace_metadata_array_type.js +20 -7
- package/lib/factories/internal/metadata/emplace_metadata_array_type.js.map +1 -1
- package/lib/factories/internal/metadata/emplace_metadata_object.d.ts +1 -1
- package/lib/factories/internal/metadata/emplace_metadata_object.js +100 -85
- package/lib/factories/internal/metadata/emplace_metadata_object.js.map +1 -1
- package/lib/factories/internal/metadata/emplace_metadata_tuple.d.ts +1 -1
- package/lib/factories/internal/metadata/emplace_metadata_tuple.js +34 -21
- package/lib/factories/internal/metadata/emplace_metadata_tuple.js.map +1 -1
- package/lib/factories/internal/metadata/explore_metadata.d.ts +1 -1
- package/lib/factories/internal/metadata/explore_metadata.js +12 -12
- package/lib/factories/internal/metadata/explore_metadata.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata.d.ts +1 -1
- package/lib/factories/internal/metadata/iterate_metadata.js +39 -19
- package/lib/factories/internal/metadata/iterate_metadata.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_alias.d.ts +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_alias.js +12 -10
- package/lib/factories/internal/metadata/iterate_metadata_alias.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_array.d.ts +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_array.js +11 -9
- package/lib/factories/internal/metadata/iterate_metadata_array.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_atomic.js +2 -1
- package/lib/factories/internal/metadata/iterate_metadata_atomic.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_collection.d.ts +2 -1
- package/lib/factories/internal/metadata/iterate_metadata_collection.js +47 -45
- package/lib/factories/internal/metadata/iterate_metadata_collection.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_comment_tags.d.ts +2 -1
- package/lib/factories/internal/metadata/iterate_metadata_comment_tags.js +17 -22
- package/lib/factories/internal/metadata/iterate_metadata_comment_tags.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_intersection.d.ts +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_intersection.js +147 -135
- package/lib/factories/internal/metadata/iterate_metadata_intersection.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_map.d.ts +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_map.js +28 -15
- package/lib/factories/internal/metadata/iterate_metadata_map.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_object.d.ts +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_object.js +16 -14
- package/lib/factories/internal/metadata/iterate_metadata_object.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_resolve.d.ts +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_resolve.js +28 -15
- package/lib/factories/internal/metadata/iterate_metadata_resolve.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_set.d.ts +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_set.js +24 -11
- package/lib/factories/internal/metadata/iterate_metadata_set.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_template.d.ts +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_template.js +28 -15
- package/lib/factories/internal/metadata/iterate_metadata_template.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_tuple.d.ts +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_tuple.js +11 -9
- package/lib/factories/internal/metadata/iterate_metadata_tuple.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_union.d.ts +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_union.js +20 -7
- package/lib/factories/internal/metadata/iterate_metadata_union.js.map +1 -1
- package/lib/functional/Namespace.js +0 -16
- package/lib/functional/Namespace.js.map +1 -1
- package/lib/programmers/AssertProgrammer.js +28 -8
- package/lib/programmers/AssertProgrammer.js.map +1 -1
- package/lib/programmers/CheckerProgrammer.js +78 -60
- package/lib/programmers/CheckerProgrammer.js.map +1 -1
- package/lib/programmers/FeatureProgrammer.d.ts +4 -6
- package/lib/programmers/FeatureProgrammer.js +7 -7
- package/lib/programmers/FeatureProgrammer.js.map +1 -1
- package/lib/programmers/IsProgrammer.d.ts +1 -1
- package/lib/programmers/IsProgrammer.js +33 -20
- package/lib/programmers/IsProgrammer.js.map +1 -1
- package/lib/programmers/RandomProgrammer.js +163 -138
- package/lib/programmers/RandomProgrammer.js.map +1 -1
- package/lib/programmers/TypiaProgrammer.js +58 -28
- package/lib/programmers/TypiaProgrammer.js.map +1 -1
- package/lib/programmers/ValidateProgrammer.js +28 -8
- package/lib/programmers/ValidateProgrammer.js.map +1 -1
- package/lib/programmers/helpers/CloneJoiner.js +10 -2
- package/lib/programmers/helpers/CloneJoiner.js.map +1 -1
- package/lib/programmers/helpers/ICheckEntry.d.ts +3 -2
- package/lib/programmers/helpers/ProtobufUtil.d.ts +6 -2
- package/lib/programmers/helpers/ProtobufUtil.js +175 -17
- package/lib/programmers/helpers/ProtobufUtil.js.map +1 -1
- package/lib/programmers/helpers/RandomJoiner.d.ts +3 -5
- package/lib/programmers/helpers/RandomJoiner.js +7 -10
- package/lib/programmers/helpers/RandomJoiner.js.map +1 -1
- package/lib/programmers/helpers/RandomRanger.d.ts +5 -6
- package/lib/programmers/helpers/RandomRanger.js +13 -33
- package/lib/programmers/helpers/RandomRanger.js.map +1 -1
- package/lib/programmers/helpers/UnionExplorer.d.ts +7 -8
- package/lib/programmers/helpers/UnionExplorer.js +6 -6
- package/lib/programmers/helpers/UnionExplorer.js.map +1 -1
- package/lib/programmers/internal/application_alias.js +0 -1
- package/lib/programmers/internal/application_alias.js.map +1 -1
- package/lib/programmers/internal/application_array.js +60 -20
- package/lib/programmers/internal/application_array.js.map +1 -1
- package/lib/programmers/internal/application_escaped.d.ts +4 -0
- package/lib/programmers/internal/{application_resolved.js → application_escaped.js} +4 -4
- package/lib/programmers/internal/application_escaped.js.map +1 -0
- package/lib/programmers/internal/application_number.js +95 -69
- package/lib/programmers/internal/application_number.js.map +1 -1
- package/lib/programmers/internal/application_object.js +0 -3
- package/lib/programmers/internal/application_object.js.map +1 -1
- package/lib/programmers/internal/application_schema.js +41 -24
- package/lib/programmers/internal/application_schema.js.map +1 -1
- package/lib/programmers/internal/application_string.js +56 -22
- package/lib/programmers/internal/application_string.js.map +1 -1
- package/lib/programmers/internal/check_array_length.js +25 -25
- package/lib/programmers/internal/check_array_length.js.map +1 -1
- package/lib/programmers/internal/check_bigint.js +13 -116
- package/lib/programmers/internal/check_bigint.js.map +1 -1
- package/lib/programmers/internal/check_dynamic_properties.js +1 -1
- package/lib/programmers/internal/check_dynamic_properties.js.map +1 -1
- package/lib/programmers/internal/check_number.js +62 -163
- package/lib/programmers/internal/check_number.js.map +1 -1
- package/lib/programmers/internal/check_string.js +16 -52
- package/lib/programmers/internal/check_string.js.map +1 -1
- package/lib/programmers/internal/check_template.js +16 -1
- package/lib/programmers/internal/check_template.js.map +1 -1
- package/lib/programmers/internal/check_union_array_like.js +4 -4
- package/lib/programmers/internal/check_union_array_like.js.map +1 -1
- package/lib/programmers/internal/feature_object_entries.js +1 -1
- package/lib/programmers/internal/feature_object_entries.js.map +1 -1
- package/lib/programmers/internal/random_custom.js +2 -2
- package/lib/programmers/internal/random_custom.js.map +1 -1
- package/lib/programmers/json/JsonApplicationProgrammer.js +5 -1
- package/lib/programmers/json/JsonApplicationProgrammer.js.map +1 -1
- package/lib/programmers/json/JsonAssertParseProgrammer.js +2 -0
- package/lib/programmers/json/JsonAssertParseProgrammer.js.map +1 -1
- package/lib/programmers/json/JsonIsParseProgrammer.js +2 -0
- package/lib/programmers/json/JsonIsParseProgrammer.js.map +1 -1
- package/lib/programmers/json/JsonStringifyProgrammer.js +41 -78
- package/lib/programmers/json/JsonStringifyProgrammer.js.map +1 -1
- package/lib/programmers/json/JsonValidateParseProgrammer.js +2 -0
- package/lib/programmers/json/JsonValidateParseProgrammer.js.map +1 -1
- package/lib/programmers/misc/MiscCloneProgrammer.js +26 -17
- package/lib/programmers/misc/MiscCloneProgrammer.js.map +1 -1
- package/lib/programmers/{IsPruneProgrammer.d.ts → misc/MiscIsPruneProgrammer.d.ts} +2 -2
- package/lib/programmers/{IsPruneProgrammer.js → misc/MiscIsPruneProgrammer.js} +11 -11
- package/lib/programmers/misc/MiscIsPruneProgrammer.js.map +1 -0
- package/lib/programmers/misc/MiscLiteralsProgrammer.js +10 -5
- package/lib/programmers/misc/MiscLiteralsProgrammer.js.map +1 -1
- package/lib/programmers/misc/MiscPruneProgrammer.js +23 -14
- package/lib/programmers/misc/MiscPruneProgrammer.js.map +1 -1
- package/lib/programmers/protobuf/ProtobufDecodeProgrammer.js +24 -44
- package/lib/programmers/protobuf/ProtobufDecodeProgrammer.js.map +1 -1
- package/lib/programmers/protobuf/ProtobufEncodeProgrammer.js +138 -65
- package/lib/programmers/protobuf/ProtobufEncodeProgrammer.js.map +1 -1
- package/lib/programmers/protobuf/ProtobufMessageProgrammer.js +59 -85
- package/lib/programmers/protobuf/ProtobufMessageProgrammer.js.map +1 -1
- package/lib/schemas/json/IJsonSchema.d.ts +10 -38
- package/lib/schemas/metadata/IMetadataAlias.d.ts +0 -2
- package/lib/schemas/metadata/IMetadataProperty.d.ts +0 -2
- package/lib/schemas/metadata/IMetadataTypeTag.d.ts +2 -0
- package/lib/schemas/metadata/Metadata.d.ts +2 -2
- package/lib/schemas/metadata/Metadata.js +29 -29
- package/lib/schemas/metadata/Metadata.js.map +1 -1
- package/lib/schemas/metadata/MetadataAlias.d.ts +0 -2
- package/lib/schemas/metadata/MetadataAlias.js +0 -3
- package/lib/schemas/metadata/MetadataAlias.js.map +1 -1
- package/lib/schemas/metadata/MetadataArray.d.ts +2 -0
- package/lib/schemas/metadata/MetadataArray.js +45 -2
- package/lib/schemas/metadata/MetadataArray.js.map +1 -1
- package/lib/schemas/metadata/MetadataAtomic.d.ts +9 -0
- package/lib/schemas/metadata/MetadataAtomic.js +59 -0
- package/lib/schemas/metadata/MetadataAtomic.js.map +1 -0
- package/lib/schemas/metadata/MetadataProperty.d.ts +0 -2
- package/lib/schemas/metadata/MetadataProperty.js +0 -3
- package/lib/schemas/metadata/MetadataProperty.js.map +1 -1
- package/lib/schemas/metadata/MetadataTuple.d.ts +4 -2
- package/lib/schemas/metadata/MetadataTuple.js +1 -2
- package/lib/schemas/metadata/MetadataTuple.js.map +1 -1
- package/lib/tags/ExclusiveMaximum.d.ts +10 -8
- package/lib/tags/ExclusiveMinimum.d.ts +10 -8
- package/lib/tags/Format.d.ts +8 -8
- package/lib/tags/MaxItems.d.ts +8 -8
- package/lib/tags/MaxLength.d.ts +8 -8
- package/lib/tags/Maximum.d.ts +10 -8
- package/lib/tags/MinItems.d.ts +8 -8
- package/lib/tags/MinLength.d.ts +8 -8
- package/lib/tags/Minimum.d.ts +10 -8
- package/lib/tags/MultipleOf.d.ts +10 -8
- package/lib/tags/Pattern.d.ts +7 -8
- package/lib/tags/TagBase.d.ts +10 -6
- package/lib/tags/Type.d.ts +14 -13
- package/lib/tags/index.d.ts +1 -0
- package/lib/tags/index.js +1 -0
- package/lib/tags/index.js.map +1 -1
- package/lib/transform.d.ts +2 -1
- package/lib/transform.js +11 -3
- package/lib/transform.js.map +1 -1
- package/lib/transformers/CallExpressionTransformer.d.ts +1 -1
- package/lib/transformers/CallExpressionTransformer.js +2 -1
- package/lib/transformers/CallExpressionTransformer.js.map +1 -1
- package/lib/transformers/FileTransformer.js +18 -6
- package/lib/transformers/FileTransformer.js.map +1 -1
- package/lib/transformers/IProject.d.ts +3 -0
- package/lib/transformers/NodeTransformer.d.ts +1 -1
- package/lib/transformers/TransformerError.d.ts +12 -0
- package/lib/transformers/TransformerError.js +66 -0
- package/lib/transformers/TransformerError.js.map +1 -0
- package/lib/transformers/features/AssertTransformer.d.ts +1 -0
- package/lib/transformers/features/CreateAssertTransformer.d.ts +1 -0
- package/lib/transformers/features/CreateIsTransformer.d.ts +1 -0
- package/lib/transformers/features/CreateRandomTransformer.js +9 -4
- package/lib/transformers/features/CreateRandomTransformer.js.map +1 -1
- package/lib/transformers/features/CreateValidateTransformer.d.ts +1 -0
- package/lib/transformers/features/IsTransformer.d.ts +1 -0
- package/lib/transformers/features/RandomTransformer.js +9 -4
- package/lib/transformers/features/RandomTransformer.js.map +1 -1
- package/lib/transformers/features/ValidateTransformer.d.ts +1 -0
- package/lib/transformers/features/json/JsonApplicationTransformer.js +79 -19
- package/lib/transformers/features/json/JsonApplicationTransformer.js.map +1 -1
- package/lib/transformers/features/json/JsonAssertParseTransformer.d.ts +1 -0
- package/lib/transformers/features/json/JsonAssertStringifyTransformer.d.ts +1 -0
- package/lib/transformers/features/json/JsonCreateAssertParseTransformer.d.ts +1 -0
- package/lib/transformers/features/json/JsonCreateAssertStringifyTransformer.d.ts +1 -0
- package/lib/transformers/features/json/JsonCreateIsParseTransformer.d.ts +1 -0
- package/lib/transformers/features/json/JsonCreateIsStringifyTransformer.d.ts +1 -0
- package/lib/transformers/features/json/JsonCreateStringifyTransformer.d.ts +1 -0
- package/lib/transformers/features/json/JsonCreateValidateParseTransformer.d.ts +1 -0
- package/lib/transformers/features/json/JsonCreateValidateStringifyProgrammer.d.ts +1 -0
- package/lib/transformers/features/json/JsonIsParseTransformer.d.ts +1 -0
- package/lib/transformers/features/json/JsonIsStringifyTransformer.d.ts +1 -0
- package/lib/transformers/features/json/JsonStringifyTransformer.d.ts +1 -0
- package/lib/transformers/features/json/JsonValidateParseTransformer.d.ts +1 -0
- package/lib/transformers/features/json/JsonValidateStringifyTransformer.d.ts +1 -0
- package/lib/transformers/features/misc/MetadataTransformer.js +13 -5
- package/lib/transformers/features/misc/MetadataTransformer.js.map +1 -1
- package/lib/transformers/features/misc/MiscAssertCloneTransformer.d.ts +1 -0
- package/lib/transformers/features/misc/MiscAssertPruneTransformer.d.ts +1 -0
- package/lib/transformers/features/misc/MiscCloneTransformer.d.ts +1 -0
- package/lib/transformers/features/misc/MiscCreateAssertCloneTransformer.d.ts +1 -0
- package/lib/transformers/features/misc/MiscCreateAssertPruneTransformer.d.ts +1 -0
- package/lib/transformers/features/misc/MiscCreateCloneTransformer.d.ts +1 -0
- package/lib/transformers/features/misc/MiscCreateIsCloneTransformer.d.ts +1 -0
- package/lib/transformers/features/misc/MiscCreateIsPruneTransformer.d.ts +1 -0
- package/lib/transformers/features/misc/MiscCreateIsPruneTransformer.js +2 -2
- package/lib/transformers/features/misc/MiscCreateIsPruneTransformer.js.map +1 -1
- package/lib/transformers/features/misc/MiscCreatePruneTransformer.d.ts +1 -0
- package/lib/transformers/features/misc/MiscCreateValidateCloneTransformer.d.ts +1 -0
- package/lib/transformers/features/misc/MiscCreateValidatePruneTransformer.d.ts +1 -0
- package/lib/transformers/features/misc/MiscIsCloneTransformer.d.ts +1 -0
- package/lib/transformers/features/misc/MiscIsPruneTransformer.d.ts +1 -0
- package/lib/transformers/features/misc/MiscIsPruneTransformer.js +2 -2
- package/lib/transformers/features/misc/MiscIsPruneTransformer.js.map +1 -1
- package/lib/transformers/features/misc/MiscLiteralsTransformer.js +9 -4
- package/lib/transformers/features/misc/MiscLiteralsTransformer.js.map +1 -1
- package/lib/transformers/features/misc/MiscPruneTransformer.d.ts +1 -0
- package/lib/transformers/features/misc/MiscValidateCloneTransformer.d.ts +1 -0
- package/lib/transformers/features/misc/MiscValidatePruneTransformer.d.ts +1 -0
- package/lib/transformers/features/protobuf/CreateProtobufAssertDecodeTransformer.d.ts +1 -0
- package/lib/transformers/features/protobuf/CreateProtobufAssertEncodeTransformer.d.ts +1 -0
- package/lib/transformers/features/protobuf/CreateProtobufDecodeTransformer.d.ts +1 -0
- package/lib/transformers/features/protobuf/CreateProtobufEncodeTransformer.d.ts +1 -0
- package/lib/transformers/features/protobuf/CreateProtobufIsDecodeTransformer.d.ts +1 -0
- package/lib/transformers/features/protobuf/CreateProtobufIsEncodeTransformer.d.ts +1 -0
- package/lib/transformers/features/protobuf/CreateProtobufValidateDecodeTransformer.d.ts +1 -0
- package/lib/transformers/features/protobuf/CreateProtobufValidateEncodeTransformer.d.ts +1 -0
- package/lib/transformers/features/protobuf/ProtobufAssertDecodeTransformer.d.ts +1 -0
- package/lib/transformers/features/protobuf/ProtobufAssertEncodeTransformer.d.ts +1 -0
- package/lib/transformers/features/protobuf/ProtobufDecodeTransformer.d.ts +1 -0
- package/lib/transformers/features/protobuf/ProtobufEncodeTransformer.d.ts +1 -0
- package/lib/transformers/features/protobuf/ProtobufIsDecodeTransformer.d.ts +1 -0
- package/lib/transformers/features/protobuf/ProtobufIsEncodeTransformer.d.ts +1 -0
- package/lib/transformers/features/protobuf/ProtobufMessageTransformer.js +9 -2
- package/lib/transformers/features/protobuf/ProtobufMessageTransformer.js.map +1 -1
- package/lib/transformers/features/protobuf/ProtobufValidateDecodeTransformer.d.ts +1 -0
- package/lib/transformers/features/protobuf/ProtobufValidateEncodeTransformer.d.ts +1 -0
- package/lib/transformers/internal/GenericTransformer.js +17 -4
- package/lib/transformers/internal/GenericTransformer.js.map +1 -1
- package/lib/typings/ProtobufAtomic.d.ts +5 -0
- package/lib/{schemas/metadata/ICommentTag.js → typings/ProtobufAtomic.js} +1 -1
- package/lib/typings/ProtobufAtomic.js.map +1 -0
- package/lib/typings/ValidationPipe.d.ts +7 -0
- package/lib/{schemas/metadata/IMetadataCommentTag.js → typings/ValidationPipe.js} +1 -1
- package/lib/typings/ValidationPipe.js.map +1 -0
- package/package.json +4 -2
- package/src/IRandomGenerator.ts +4 -3
- package/src/executable/TypiaGenerateWizard.ts +1 -1
- package/src/executable/TypiaSetupWizard.ts +1 -1
- package/src/executable/setup/PackageManager.ts +1 -1
- package/src/executable/setup/PluginConfigurator.ts +2 -2
- package/src/factories/ExpressionFactory.ts +4 -4
- package/src/factories/JsonMetadataFactory.ts +43 -0
- package/src/factories/LiteralFactory.ts +11 -3
- package/src/factories/MetadataCollection.ts +0 -6
- package/src/factories/MetadataCommentTagFactory.ts +629 -0
- package/src/factories/MetadataFactory.ts +169 -7
- package/src/factories/MetadataTypeTagFactory.ts +313 -0
- package/src/factories/NumericRangeFactory.ts +33 -0
- package/src/factories/ProtobufFactory.ts +106 -99
- package/src/factories/TypeFactory.ts +0 -5
- package/src/factories/internal/metadata/emend_metadata_atomics.ts +6 -1
- package/src/factories/internal/metadata/emplace_metadata_alias.ts +12 -11
- package/src/factories/internal/metadata/emplace_metadata_array_type.ts +12 -5
- package/src/factories/internal/metadata/emplace_metadata_object.ts +20 -6
- package/src/factories/internal/metadata/emplace_metadata_tuple.ts +12 -2
- package/src/factories/internal/metadata/explore_metadata.ts +5 -11
- package/src/factories/internal/metadata/iterate_metadata.ts +44 -24
- package/src/factories/internal/metadata/iterate_metadata_alias.ts +7 -2
- package/src/factories/internal/metadata/iterate_metadata_array.ts +7 -2
- package/src/factories/internal/metadata/iterate_metadata_atomic.ts +2 -1
- package/src/factories/internal/metadata/iterate_metadata_collection.ts +30 -29
- package/src/factories/internal/metadata/iterate_metadata_comment_tags.ts +22 -27
- package/src/factories/internal/metadata/iterate_metadata_intersection.ts +44 -25
- package/src/factories/internal/metadata/iterate_metadata_map.ts +20 -4
- package/src/factories/internal/metadata/iterate_metadata_object.ts +2 -1
- package/src/factories/internal/metadata/iterate_metadata_resolve.ts +15 -12
- package/src/factories/internal/metadata/iterate_metadata_set.ts +11 -2
- package/src/factories/internal/metadata/iterate_metadata_template.ts +12 -3
- package/src/factories/internal/metadata/iterate_metadata_tuple.ts +7 -2
- package/src/factories/internal/metadata/iterate_metadata_union.ts +10 -7
- package/src/functional/Namespace.ts +0 -16
- package/src/programmers/AssertProgrammer.ts +57 -21
- package/src/programmers/CheckerProgrammer.ts +51 -120
- package/src/programmers/FeatureProgrammer.ts +15 -34
- package/src/programmers/IsProgrammer.ts +53 -42
- package/src/programmers/RandomProgrammer.ts +223 -242
- package/src/programmers/TypiaProgrammer.ts +27 -2
- package/src/programmers/ValidateProgrammer.ts +60 -21
- package/src/programmers/helpers/CloneJoiner.ts +57 -20
- package/src/programmers/helpers/ICheckEntry.ts +3 -2
- package/src/programmers/helpers/ProtobufUtil.ts +113 -17
- package/src/programmers/helpers/RandomJoiner.ts +11 -37
- package/src/programmers/helpers/RandomRanger.ts +16 -51
- package/src/programmers/helpers/UnionExplorer.ts +1 -20
- package/src/programmers/internal/application_alias.ts +0 -1
- package/src/programmers/internal/application_array.ts +32 -10
- package/src/programmers/internal/{application_resolved.ts → application_escaped.ts} +1 -1
- package/src/programmers/internal/application_number.ts +76 -70
- package/src/programmers/internal/application_object.ts +0 -3
- package/src/programmers/internal/application_schema.ts +40 -22
- package/src/programmers/internal/application_string.ts +33 -27
- package/src/programmers/internal/check_array_length.ts +34 -28
- package/src/programmers/internal/check_bigint.ts +25 -118
- package/src/programmers/internal/check_dynamic_properties.ts +1 -2
- package/src/programmers/internal/check_number.ts +81 -261
- package/src/programmers/internal/check_string.ts +28 -39
- package/src/programmers/internal/check_template.ts +17 -1
- package/src/programmers/internal/check_union_array_like.ts +1 -16
- package/src/programmers/internal/feature_object_entries.ts +12 -18
- package/src/programmers/internal/random_custom.ts +3 -3
- package/src/programmers/json/JsonApplicationProgrammer.ts +6 -3
- package/src/programmers/json/JsonAssertParseProgrammer.ts +7 -2
- package/src/programmers/json/JsonIsParseProgrammer.ts +7 -2
- package/src/programmers/json/JsonStringifyProgrammer.ts +32 -73
- package/src/programmers/json/JsonValidateParseProgrammer.ts +7 -2
- package/src/programmers/json/JsonValidateStringifyProgrammer.ts +1 -1
- package/src/programmers/misc/MiscCloneProgrammer.ts +24 -35
- package/src/programmers/{IsPruneProgrammer.ts → misc/MiscIsPruneProgrammer.ts} +7 -7
- package/src/programmers/misc/MiscLiteralsProgrammer.ts +11 -6
- package/src/programmers/misc/MiscPruneProgrammer.ts +16 -20
- package/src/programmers/protobuf/ProtobufDecodeProgrammer.ts +34 -68
- package/src/programmers/protobuf/ProtobufEncodeProgrammer.ts +153 -98
- package/src/programmers/protobuf/ProtobufMessageProgrammer.ts +6 -36
- package/src/schemas/json/IJsonSchema.ts +11 -38
- package/src/schemas/metadata/IMetadataAlias.ts +0 -2
- package/src/schemas/metadata/IMetadataProperty.ts +0 -2
- package/src/schemas/metadata/IMetadataTypeTag.ts +2 -0
- package/src/schemas/metadata/Metadata.ts +32 -46
- package/src/schemas/metadata/MetadataAlias.ts +0 -5
- package/src/schemas/metadata/MetadataArray.ts +21 -3
- package/src/schemas/metadata/MetadataAtomic.ts +42 -0
- package/src/schemas/metadata/MetadataProperty.ts +0 -5
- package/src/schemas/metadata/MetadataTuple.ts +5 -4
- package/src/tags/ExclusiveMaximum.ts +13 -8
- package/src/tags/ExclusiveMinimum.ts +13 -8
- package/src/tags/Format.ts +21 -20
- package/src/tags/MaxItems.ts +9 -8
- package/src/tags/MaxLength.ts +9 -8
- package/src/tags/Maximum.ts +13 -8
- package/src/tags/MinItems.ts +9 -8
- package/src/tags/MinLength.ts +9 -8
- package/src/tags/Minimum.ts +13 -8
- package/src/tags/MultipleOf.ts +15 -10
- package/src/tags/Pattern.ts +8 -8
- package/src/tags/TagBase.ts +18 -13
- package/src/tags/Type.ts +26 -29
- package/src/tags/index.ts +1 -0
- package/src/transform.ts +13 -5
- package/src/transformers/CallExpressionTransformer.ts +6 -3
- package/src/transformers/FileTransformer.ts +25 -13
- package/src/transformers/IProject.ts +3 -0
- package/src/transformers/NodeTransformer.ts +1 -1
- package/src/transformers/TransformerError.ts +55 -0
- package/src/transformers/features/CreateRandomTransformer.ts +11 -7
- package/src/transformers/features/RandomTransformer.ts +11 -7
- package/src/transformers/features/json/JsonApplicationTransformer.ts +39 -35
- package/src/transformers/features/misc/MetadataTransformer.ts +18 -10
- package/src/transformers/features/misc/MiscCreateIsPruneTransformer.ts +2 -2
- package/src/transformers/features/misc/MiscIsPruneTransformer.ts +2 -2
- package/src/transformers/features/misc/MiscLiteralsTransformer.ts +11 -7
- package/src/transformers/features/protobuf/ProtobufMessageTransformer.ts +9 -7
- package/src/transformers/internal/GenericTransformer.ts +17 -10
- package/src/typings/ProtobufAtomic.ts +19 -0
- package/src/typings/ValidationPipe.ts +9 -0
- package/lib/factories/MetadataTagFactory.d.ts +0 -6
- package/lib/factories/MetadataTagFactory.js +0 -312
- package/lib/factories/MetadataTagFactory.js.map +0 -1
- package/lib/factories/internal/metadata/iterate_metadata_type_tags.d.ts +0 -3
- package/lib/factories/internal/metadata/iterate_metadata_type_tags.js +0 -157
- package/lib/factories/internal/metadata/iterate_metadata_type_tags.js.map +0 -1
- package/lib/functional/$is_custom.d.ts +0 -2
- package/lib/functional/$is_custom.js +0 -13
- package/lib/functional/$is_custom.js.map +0 -1
- package/lib/functional/$is_date.d.ts +0 -1
- package/lib/functional/$is_date.js +0 -7
- package/lib/functional/$is_date.js.map +0 -1
- package/lib/functional/$is_datetime.d.ts +0 -1
- package/lib/functional/$is_datetime.js +0 -8
- package/lib/functional/$is_datetime.js.map +0 -1
- package/lib/functional/$is_email.d.ts +0 -1
- package/lib/functional/$is_email.js +0 -7
- package/lib/functional/$is_email.js.map +0 -1
- package/lib/functional/$is_ipv4.d.ts +0 -1
- package/lib/functional/$is_ipv4.js +0 -7
- package/lib/functional/$is_ipv4.js.map +0 -1
- package/lib/functional/$is_ipv6.d.ts +0 -1
- package/lib/functional/$is_ipv6.js +0 -7
- package/lib/functional/$is_ipv6.js.map +0 -1
- package/lib/functional/$is_url.d.ts +0 -1
- package/lib/functional/$is_url.js +0 -7
- package/lib/functional/$is_url.js.map +0 -1
- package/lib/functional/$is_uuid.d.ts +0 -1
- package/lib/functional/$is_uuid.js +0 -7
- package/lib/functional/$is_uuid.js.map +0 -1
- package/lib/programmers/IsPruneProgrammer.js.map +0 -1
- package/lib/programmers/internal/application_resolved.d.ts +0 -4
- package/lib/programmers/internal/application_resolved.js.map +0 -1
- package/lib/programmers/internal/check_array_tags.js +0 -39
- package/lib/programmers/internal/check_array_tags.js.map +0 -1
- package/lib/programmers/internal/check_string_tags.d.ts +0 -1
- package/lib/programmers/internal/check_string_tags.js +0 -89
- package/lib/programmers/internal/check_string_tags.js.map +0 -1
- package/lib/programmers/internal/get_comment_tags.d.ts +0 -1
- package/lib/programmers/internal/get_comment_tags.js +0 -25
- package/lib/programmers/internal/get_comment_tags.js.map +0 -1
- package/lib/schemas/metadata/ICommentTag.d.ts +0 -4
- package/lib/schemas/metadata/ICommentTag.js.map +0 -1
- package/lib/schemas/metadata/IMetadataCommentTag.d.ts +0 -63
- package/lib/schemas/metadata/IMetadataCommentTag.js.map +0 -1
- package/src/factories/MetadataTagFactory.ts +0 -365
- package/src/factories/internal/metadata/iterate_metadata_type_tags.ts +0 -183
- package/src/functional/$is_custom.ts +0 -14
- package/src/functional/$is_date.ts +0 -3
- package/src/functional/$is_datetime.ts +0 -2
- package/src/functional/$is_email.ts +0 -4
- package/src/functional/$is_ipv4.ts +0 -4
- package/src/functional/$is_ipv6.ts +0 -4
- package/src/functional/$is_url.ts +0 -4
- package/src/functional/$is_uuid.ts +0 -4
- package/src/programmers/internal/check_array_tags.ts +0 -45
- package/src/programmers/internal/check_string_tags.ts +0 -67
- package/src/programmers/internal/get_comment_tags.ts +0 -23
- package/src/schemas/metadata/ICommentTag.ts +0 -4
- package/src/schemas/metadata/IMetadataCommentTag.ts +0 -112
- /package/lib/{programmers/internal/check_array_tags.d.ts → factories/MetadataCommentTagFactory.d.ts} +0 -0
|
@@ -5,6 +5,10 @@ import { MetadataObject } from "../schemas/metadata/MetadataObject";
|
|
|
5
5
|
|
|
6
6
|
import { ProtobufUtil } from "../programmers/helpers/ProtobufUtil";
|
|
7
7
|
|
|
8
|
+
import { TransformerError } from "../transformers/TransformerError";
|
|
9
|
+
|
|
10
|
+
import { ValidationPipe } from "../typings/ValidationPipe";
|
|
11
|
+
|
|
8
12
|
import { Escaper } from "../utils/Escaper";
|
|
9
13
|
|
|
10
14
|
import { MetadataCollection } from "./MetadataCollection";
|
|
@@ -15,72 +19,95 @@ export namespace ProtobufFactory {
|
|
|
15
19
|
(method: string) =>
|
|
16
20
|
(checker: ts.TypeChecker) =>
|
|
17
21
|
(collection: MetadataCollection) =>
|
|
18
|
-
(type: ts.Type) => {
|
|
22
|
+
(type: ts.Type): Metadata => {
|
|
19
23
|
// COMPOSE METADATA WITH INDIVIDUAL VALIDATIONS
|
|
20
|
-
const
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
24
|
+
const result: ValidationPipe<Metadata, MetadataFactory.IError> =
|
|
25
|
+
MetadataFactory.analyze(checker)({
|
|
26
|
+
escape: false,
|
|
27
|
+
constant: true,
|
|
28
|
+
absorb: true,
|
|
29
|
+
validate,
|
|
30
|
+
})(collection)(type);
|
|
31
|
+
if (result.success === false)
|
|
32
|
+
throw TransformerError.from(`typia.protobuf.${method}`)(
|
|
33
|
+
result.errors,
|
|
34
|
+
);
|
|
35
|
+
return result.data;
|
|
36
|
+
};
|
|
26
37
|
|
|
27
|
-
|
|
38
|
+
const validate = (
|
|
39
|
+
meta: Metadata,
|
|
40
|
+
explore: MetadataFactory.IExplore,
|
|
41
|
+
): string[] => {
|
|
42
|
+
const errors: string[] = [];
|
|
43
|
+
const insert = (msg: string) => errors.push(msg);
|
|
44
|
+
|
|
45
|
+
if (explore.top === true) {
|
|
28
46
|
const onlyObject: boolean =
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
47
|
+
meta.size() === 1 &&
|
|
48
|
+
meta.objects.length === 1 &&
|
|
49
|
+
meta.objects[0]!.properties.every((p) =>
|
|
32
50
|
p.key.isSoleLiteral(),
|
|
33
51
|
) &&
|
|
34
|
-
|
|
35
|
-
|
|
52
|
+
meta.isRequired() === true &&
|
|
53
|
+
meta.nullable === false;
|
|
36
54
|
if (onlyObject === false)
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
)} target type must be a sole and static object.`,
|
|
41
|
-
);
|
|
42
|
-
|
|
43
|
-
return top;
|
|
44
|
-
};
|
|
55
|
+
insert("target type must be a sole and static object type");
|
|
56
|
+
return errors;
|
|
57
|
+
}
|
|
45
58
|
|
|
46
|
-
const validate = (method: string) => (meta: Metadata) => {
|
|
47
59
|
//----
|
|
48
60
|
// NOT SUPPORTED TYPES
|
|
49
61
|
//----
|
|
62
|
+
const noSupport = (msg: string) => insert(`does not support ${msg}`);
|
|
63
|
+
|
|
50
64
|
// PROHIBIT ANY TYPE
|
|
51
|
-
if (meta.any)
|
|
65
|
+
if (meta.any) noSupport("any type");
|
|
52
66
|
// PROHIBIT FUNCTIONAL TYPE
|
|
53
|
-
|
|
54
|
-
throw notSupportedError({ method })("functional type");
|
|
67
|
+
if (meta.functional) noSupport("functional type");
|
|
55
68
|
// PROHIBIT TUPLE TYPE
|
|
56
|
-
|
|
57
|
-
throw notSupportedError({ method })("tuple type");
|
|
69
|
+
if (meta.tuples.length) noSupport("tuple type");
|
|
58
70
|
// PROHIBIT SET TYPE
|
|
59
|
-
|
|
60
|
-
throw notSupportedError({ method })("Set type");
|
|
71
|
+
if (meta.sets.length) noSupport("Set type");
|
|
61
72
|
// NATIVE TYPE, BUT NOT Uint8Array
|
|
62
|
-
|
|
73
|
+
if (meta.natives.length) {
|
|
63
74
|
const banned = meta.natives
|
|
64
75
|
.map((n) => [n, BANNED_NATIVE_TYPES.get(n)] as const)
|
|
65
76
|
.filter(([_n, b]) => b !== undefined)[0];
|
|
66
77
|
if (banned !== undefined)
|
|
67
|
-
|
|
78
|
+
noSupport(
|
|
68
79
|
banned[1] === null
|
|
69
|
-
? banned[0]
|
|
70
|
-
:
|
|
80
|
+
? `${banned[0]} type`
|
|
81
|
+
: `does ${banned[0]} type. Use ${banned[1]} type instead.`,
|
|
71
82
|
);
|
|
72
83
|
}
|
|
73
84
|
//----
|
|
85
|
+
// ATOMIC CASES
|
|
86
|
+
//----
|
|
87
|
+
if (meta.atomics.length) {
|
|
88
|
+
const numbers = ProtobufUtil.getNumbers(meta);
|
|
89
|
+
const bigints = ProtobufUtil.getBigints(meta);
|
|
90
|
+
|
|
91
|
+
for (const type of ["int64", "uint64"])
|
|
92
|
+
if (
|
|
93
|
+
numbers.some((n) => n === type) &&
|
|
94
|
+
bigints.some((b) => b === type)
|
|
95
|
+
)
|
|
96
|
+
insert(
|
|
97
|
+
`tags.Type<"${type}"> cannot be used in both number and bigint types. Recommend to remove from number type`,
|
|
98
|
+
);
|
|
99
|
+
}
|
|
100
|
+
//----
|
|
74
101
|
// ARRRAY CASES
|
|
75
102
|
//----
|
|
76
103
|
// DO NOT ALLOW MULTI-DIMENTIONAL ARRAY
|
|
77
|
-
|
|
104
|
+
if (
|
|
78
105
|
meta.arrays.length &&
|
|
79
106
|
meta.arrays.some((array) => !!array.type.value.arrays.length)
|
|
80
107
|
)
|
|
81
|
-
|
|
108
|
+
noSupport("over two dimenstional array type");
|
|
82
109
|
// CHILD OF ARRAY TYPE MUST BE REQUIRED
|
|
83
|
-
|
|
110
|
+
if (
|
|
84
111
|
meta.arrays.length &&
|
|
85
112
|
meta.arrays.some(
|
|
86
113
|
(array) =>
|
|
@@ -88,15 +115,15 @@ export namespace ProtobufFactory {
|
|
|
88
115
|
array.type.value.nullable === true,
|
|
89
116
|
)
|
|
90
117
|
)
|
|
91
|
-
|
|
118
|
+
noSupport("optional type in array");
|
|
92
119
|
// UNION IN ARRAY
|
|
93
|
-
|
|
120
|
+
if (
|
|
94
121
|
meta.arrays.length &&
|
|
95
122
|
meta.arrays.some((a) => a.type.value.size() > 1)
|
|
96
123
|
)
|
|
97
|
-
|
|
124
|
+
noSupport("union type in array");
|
|
98
125
|
// DO DYNAMIC OBJECT IN ARRAY
|
|
99
|
-
|
|
126
|
+
if (
|
|
100
127
|
meta.arrays.length &&
|
|
101
128
|
meta.arrays.some(
|
|
102
129
|
(a) =>
|
|
@@ -107,21 +134,21 @@ export namespace ProtobufFactory {
|
|
|
107
134
|
)),
|
|
108
135
|
)
|
|
109
136
|
)
|
|
110
|
-
|
|
137
|
+
noSupport("dynamic object in array");
|
|
111
138
|
// UNION WITH ARRAY
|
|
112
|
-
|
|
113
|
-
|
|
139
|
+
if (meta.size() > 1 && meta.arrays.length)
|
|
140
|
+
noSupport("union type with array type");
|
|
114
141
|
//----
|
|
115
142
|
// OBJECT CASES
|
|
116
143
|
//----
|
|
117
144
|
// EMPTY PROPERTY
|
|
118
|
-
|
|
145
|
+
if (
|
|
119
146
|
meta.objects.length &&
|
|
120
147
|
meta.objects.some((obj) => obj.properties.length === 0)
|
|
121
148
|
)
|
|
122
|
-
|
|
149
|
+
noSupport("empty object type");
|
|
123
150
|
// MULTIPLE DYNAMIC KEY TYPED PROPERTIES
|
|
124
|
-
|
|
151
|
+
if (
|
|
125
152
|
meta.objects.length &&
|
|
126
153
|
meta.objects.some(
|
|
127
154
|
(obj) =>
|
|
@@ -129,11 +156,11 @@ export namespace ProtobufFactory {
|
|
|
129
156
|
.length > 1,
|
|
130
157
|
)
|
|
131
158
|
)
|
|
132
|
-
|
|
159
|
+
noSupport(
|
|
133
160
|
"object type with multiple dynamic key typed properties. Keep only one.",
|
|
134
161
|
);
|
|
135
162
|
// STATIC AND DYNAMIC PROPERTIES ARE COMPATIBLE
|
|
136
|
-
|
|
163
|
+
if (
|
|
137
164
|
meta.objects.length &&
|
|
138
165
|
meta.objects.some(
|
|
139
166
|
(obj) =>
|
|
@@ -141,11 +168,11 @@ export namespace ProtobufFactory {
|
|
|
141
168
|
obj.properties.some((p) => !p.key.isSoleLiteral()),
|
|
142
169
|
)
|
|
143
170
|
)
|
|
144
|
-
|
|
171
|
+
noSupport(
|
|
145
172
|
"object type with mixed static and dynamic key typed properties. Keep statics or dynamic only.",
|
|
146
173
|
);
|
|
147
174
|
// STATIC PROPERTY, BUT INVALID KEY NAME
|
|
148
|
-
|
|
175
|
+
if (
|
|
149
176
|
meta.objects.length &&
|
|
150
177
|
meta.objects.some((obj) =>
|
|
151
178
|
obj.properties.some(
|
|
@@ -155,91 +182,71 @@ export namespace ProtobufFactory {
|
|
|
155
182
|
),
|
|
156
183
|
)
|
|
157
184
|
)
|
|
158
|
-
throw
|
|
159
|
-
`object type with invalid static key name.`,
|
|
160
|
-
);
|
|
185
|
+
throw noSupport(`object type with invalid static key name.`);
|
|
161
186
|
// DYNAMIC OBJECT, BUT PROPERTY VALUE TYPE IS ARRAY
|
|
162
|
-
|
|
187
|
+
if (
|
|
163
188
|
meta.objects.length &&
|
|
164
189
|
isDynamicObject(meta.objects[0]!) &&
|
|
165
190
|
meta.objects[0]!.properties.some((p) => !!p.value.arrays.length)
|
|
166
191
|
)
|
|
167
|
-
|
|
168
|
-
"dynamic object with array value type",
|
|
169
|
-
);
|
|
192
|
+
noSupport("dynamic object with array value type");
|
|
170
193
|
// UNION WITH DYNAMIC OBJECT
|
|
171
|
-
|
|
194
|
+
if (
|
|
172
195
|
meta.size() > 1 &&
|
|
173
196
|
meta.objects.length &&
|
|
174
197
|
isDynamicObject(meta.objects[0]!)
|
|
175
198
|
)
|
|
176
|
-
|
|
177
|
-
"union type with dynamic object type",
|
|
178
|
-
);
|
|
199
|
+
noSupport("union type with dynamic object type");
|
|
179
200
|
// UNION IN DYNAMIC PROPERTY VALUE
|
|
180
|
-
|
|
201
|
+
if (
|
|
181
202
|
meta.objects.length &&
|
|
182
203
|
meta.objects.some(
|
|
183
204
|
(obj) =>
|
|
184
205
|
isDynamicObject(obj) &&
|
|
185
|
-
obj.properties.some((p) => p.value
|
|
206
|
+
obj.properties.some((p) => ProtobufUtil.isUnion(p.value)),
|
|
186
207
|
)
|
|
187
208
|
)
|
|
188
|
-
|
|
189
|
-
"union type in dynamic property",
|
|
190
|
-
);
|
|
209
|
+
noSupport("union type in dynamic property");
|
|
191
210
|
//----
|
|
192
211
|
// MAP CASES
|
|
193
212
|
//----
|
|
194
|
-
//
|
|
195
|
-
|
|
196
|
-
else if (
|
|
213
|
+
// KEY TYPE IS UNION
|
|
214
|
+
if (
|
|
197
215
|
meta.maps.length &&
|
|
198
|
-
meta.maps.some(
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
)
|
|
216
|
+
meta.maps.some((m) => ProtobufUtil.isUnion(m.key))
|
|
217
|
+
)
|
|
218
|
+
noSupport("union key typed map");
|
|
219
|
+
// KEY TYPE IS NOT ATOMIC
|
|
220
|
+
if (
|
|
221
|
+
meta.maps.length &&
|
|
222
|
+
meta.maps.some((m) => ProtobufUtil.getAtomics(m.key).length !== 1)
|
|
206
223
|
)
|
|
207
|
-
|
|
224
|
+
noSupport("non-atomic key typed map");
|
|
208
225
|
// MAP TYPE, BUT PROPERTY KEY TYPE IS OPTIONAL
|
|
209
|
-
|
|
226
|
+
if (
|
|
210
227
|
meta.maps.length &&
|
|
211
228
|
meta.maps.some(
|
|
212
229
|
(m) => m.key.isRequired() === false || m.key.nullable,
|
|
213
230
|
)
|
|
214
231
|
)
|
|
215
|
-
|
|
232
|
+
noSupport("optional key typed map");
|
|
216
233
|
// MAP TYPE, BUT VALUE TYPE IS ARRAY
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
meta.maps.some((m) => !!m.value.arrays.length)
|
|
220
|
-
)
|
|
221
|
-
throw notSupportedError({ method })(
|
|
222
|
-
"map type with array value type",
|
|
223
|
-
);
|
|
234
|
+
if (meta.maps.length && meta.maps.some((m) => !!m.value.arrays.length))
|
|
235
|
+
noSupport("map type with array value type");
|
|
224
236
|
// UNION WITH MAP
|
|
225
|
-
|
|
226
|
-
|
|
237
|
+
if (meta.size() > 1 && meta.maps.length)
|
|
238
|
+
noSupport("union type with map type");
|
|
227
239
|
// UNION IN MAP
|
|
228
|
-
|
|
240
|
+
if (
|
|
229
241
|
meta.maps.length &&
|
|
230
|
-
meta.maps.some((m) => m.value
|
|
242
|
+
meta.maps.some((m) => ProtobufUtil.isUnion(m.value))
|
|
231
243
|
)
|
|
232
|
-
|
|
244
|
+
noSupport("union type in map");
|
|
245
|
+
|
|
246
|
+
return errors;
|
|
233
247
|
};
|
|
234
248
|
}
|
|
235
249
|
|
|
236
|
-
const prefix = (method: string) => `Error on ${method}():`;
|
|
237
|
-
|
|
238
|
-
const notSupportedError = (p: { method: string }) => (title: string) =>
|
|
239
|
-
new Error(
|
|
240
|
-
`${prefix(p.method)}: protocol buffer does not support ${title}.`,
|
|
241
|
-
);
|
|
242
|
-
|
|
243
250
|
const isDynamicObject = (obj: MetadataObject): boolean =>
|
|
244
251
|
obj.properties[0]!.key.isSoleLiteral() === false;
|
|
245
252
|
|
|
@@ -1,11 +1,6 @@
|
|
|
1
1
|
import ts from "typescript";
|
|
2
2
|
|
|
3
3
|
export namespace TypeFactory {
|
|
4
|
-
export const resolve =
|
|
5
|
-
(checker: ts.TypeChecker) =>
|
|
6
|
-
(type: ts.Type): ts.Type | null =>
|
|
7
|
-
getReturnType(checker)(type)("toJSON");
|
|
8
|
-
|
|
9
4
|
export const isFunction = (type: ts.Type): boolean =>
|
|
10
5
|
getFunction(type) !== null;
|
|
11
6
|
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { Metadata } from "../../../schemas/metadata/Metadata";
|
|
2
|
+
import { MetadataAtomic } from "../../../schemas/metadata/MetadataAtomic";
|
|
2
3
|
|
|
3
4
|
import { ArrayUtil } from "../../../utils/ArrayUtil";
|
|
4
5
|
|
|
@@ -21,7 +22,11 @@ export const emend_metadata_atomics = (meta: Metadata) => {
|
|
|
21
22
|
ArrayUtil.take(
|
|
22
23
|
meta.atomics,
|
|
23
24
|
(a) => a.type === "boolean",
|
|
24
|
-
() =>
|
|
25
|
+
() =>
|
|
26
|
+
MetadataAtomic.create({
|
|
27
|
+
type: "boolean" as const,
|
|
28
|
+
tags: [],
|
|
29
|
+
}),
|
|
25
30
|
);
|
|
26
31
|
}
|
|
27
32
|
}
|
|
@@ -7,14 +7,18 @@ import { ArrayUtil } from "../../../utils/ArrayUtil";
|
|
|
7
7
|
|
|
8
8
|
import { MetadataCollection } from "../../MetadataCollection";
|
|
9
9
|
import { MetadataFactory } from "../../MetadataFactory";
|
|
10
|
-
import { MetadataTagFactory } from "../../MetadataTagFactory";
|
|
11
10
|
import { explore_metadata } from "./explore_metadata";
|
|
12
11
|
|
|
13
12
|
export const emplace_metadata_alias =
|
|
14
13
|
(checker: ts.TypeChecker) =>
|
|
15
14
|
(options: MetadataFactory.IOptions) =>
|
|
16
15
|
(collection: MetadataCollection) =>
|
|
17
|
-
(
|
|
16
|
+
(errors: MetadataFactory.IError[]) =>
|
|
17
|
+
(
|
|
18
|
+
type: ts.Type,
|
|
19
|
+
nullable: boolean,
|
|
20
|
+
explore: MetadataFactory.IExplore,
|
|
21
|
+
): MetadataAlias => {
|
|
18
22
|
// CHECK EXISTENCE
|
|
19
23
|
const [alias, newbie, closure] = collection.emplaceAlias(
|
|
20
24
|
checker,
|
|
@@ -26,15 +30,12 @@ export const emplace_metadata_alias =
|
|
|
26
30
|
|
|
27
31
|
// CONSTRUCT VALUE TYPE
|
|
28
32
|
const value: Metadata = explore_metadata(checker)(options)(collection)(
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
+
errors,
|
|
34
|
+
)(type, {
|
|
35
|
+
...explore,
|
|
36
|
+
escaped: false,
|
|
37
|
+
aliased: true,
|
|
38
|
+
});
|
|
33
39
|
closure(value);
|
|
34
|
-
alias.tags.push(
|
|
35
|
-
...MetadataTagFactory.generate(value)(alias.jsDocTags)(
|
|
36
|
-
() => alias.name,
|
|
37
|
-
),
|
|
38
|
-
);
|
|
39
40
|
return alias;
|
|
40
41
|
};
|
|
@@ -13,7 +13,12 @@ export const emplace_metadata_array_type =
|
|
|
13
13
|
(checker: ts.TypeChecker) =>
|
|
14
14
|
(options: MetadataFactory.IOptions) =>
|
|
15
15
|
(collection: MetadataCollection) =>
|
|
16
|
-
(
|
|
16
|
+
(errors: MetadataFactory.IError[]) =>
|
|
17
|
+
(
|
|
18
|
+
type: ts.Type,
|
|
19
|
+
nullable: boolean,
|
|
20
|
+
explore: MetadataFactory.IExplore,
|
|
21
|
+
): MetadataArrayType => {
|
|
17
22
|
// CHECK EXISTENCE
|
|
18
23
|
const [array, newbie, setValue] = collection.emplaceArray(
|
|
19
24
|
checker,
|
|
@@ -24,10 +29,12 @@ export const emplace_metadata_array_type =
|
|
|
24
29
|
|
|
25
30
|
// CONSTRUCT VALUE TYPE
|
|
26
31
|
const value: Metadata = explore_metadata(checker)(options)(collection)(
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
32
|
+
errors,
|
|
33
|
+
)(type.getNumberIndexType()!, {
|
|
34
|
+
...explore,
|
|
35
|
+
escaped: false,
|
|
36
|
+
aliased: false,
|
|
37
|
+
});
|
|
31
38
|
setValue(value);
|
|
32
39
|
|
|
33
40
|
return array;
|
|
@@ -18,6 +18,7 @@ export const emplace_metadata_object =
|
|
|
18
18
|
(checker: ts.TypeChecker) =>
|
|
19
19
|
(options: MetadataFactory.IOptions) =>
|
|
20
20
|
(collection: MetadataCollection) =>
|
|
21
|
+
(errors: MetadataFactory.IError[]) =>
|
|
21
22
|
(parent: ts.Type, nullable: boolean): MetadataObject => {
|
|
22
23
|
// EMPLACE OBJECT
|
|
23
24
|
const [obj, newbie] = collection.emplace(checker, parent);
|
|
@@ -61,7 +62,6 @@ export const emplace_metadata_object =
|
|
|
61
62
|
value,
|
|
62
63
|
description,
|
|
63
64
|
jsDocTags,
|
|
64
|
-
tags: [],
|
|
65
65
|
});
|
|
66
66
|
obj.properties.push(property);
|
|
67
67
|
return property;
|
|
@@ -100,7 +100,14 @@ export const emplace_metadata_object =
|
|
|
100
100
|
const key: Metadata = MetadataHelper.literal_to_metadata(prop.name);
|
|
101
101
|
const value: Metadata = explore_metadata(checker)(options)(
|
|
102
102
|
collection,
|
|
103
|
-
)(type,
|
|
103
|
+
)(errors)(type, {
|
|
104
|
+
top: false,
|
|
105
|
+
object: obj,
|
|
106
|
+
property: prop.name,
|
|
107
|
+
nested: null,
|
|
108
|
+
escaped: false,
|
|
109
|
+
aliased: false,
|
|
110
|
+
});
|
|
104
111
|
|
|
105
112
|
// OPTIONAL, BUT CAN BE RQUIRED BY `Required<T>` TYPE
|
|
106
113
|
if (node?.questionToken) Writable(value).optional = true;
|
|
@@ -112,10 +119,17 @@ export const emplace_metadata_object =
|
|
|
112
119
|
//----
|
|
113
120
|
for (const index of checker.getIndexInfosOfType(parent)) {
|
|
114
121
|
// GET EXACT TYPE
|
|
115
|
-
const analyzer = (type: ts.Type) =>
|
|
116
|
-
explore_metadata(checker)(options)(collection)(type,
|
|
117
|
-
|
|
118
|
-
|
|
122
|
+
const analyzer = (type: ts.Type) => (property: {} | null) =>
|
|
123
|
+
explore_metadata(checker)(options)(collection)(errors)(type, {
|
|
124
|
+
top: false,
|
|
125
|
+
object: obj,
|
|
126
|
+
property,
|
|
127
|
+
nested: null,
|
|
128
|
+
escaped: false,
|
|
129
|
+
aliased: false,
|
|
130
|
+
});
|
|
131
|
+
const key: Metadata = analyzer(index.keyType)(null);
|
|
132
|
+
const value: Metadata = analyzer(index.type)({});
|
|
119
133
|
|
|
120
134
|
// INSERT WITH REQUIRED CONFIGURATION
|
|
121
135
|
insert(key)(value)(
|
|
@@ -15,7 +15,12 @@ export const emplace_metadata_tuple =
|
|
|
15
15
|
(checker: ts.TypeChecker) =>
|
|
16
16
|
(options: MetadataFactory.IOptions) =>
|
|
17
17
|
(collection: MetadataCollection) =>
|
|
18
|
-
(
|
|
18
|
+
(errors: MetadataFactory.IError[]) =>
|
|
19
|
+
(
|
|
20
|
+
type: ts.TupleType,
|
|
21
|
+
nullable: boolean,
|
|
22
|
+
explore: MetadataFactory.IExplore,
|
|
23
|
+
): MetadataTupleType => {
|
|
19
24
|
// CHECK EXISTENCE
|
|
20
25
|
const [tuple, newbie, closure] = collection.emplaceTuple(checker, type);
|
|
21
26
|
ArrayUtil.add(tuple.nullables, nullable);
|
|
@@ -31,7 +36,12 @@ export const emplace_metadata_tuple =
|
|
|
31
36
|
.map((elem, i) => {
|
|
32
37
|
const child: Metadata = explore_metadata(checker)(options)(
|
|
33
38
|
collection,
|
|
34
|
-
)(elem,
|
|
39
|
+
)(errors)(elem, {
|
|
40
|
+
...explore,
|
|
41
|
+
nested: tuple,
|
|
42
|
+
aliased: false,
|
|
43
|
+
escaped: false,
|
|
44
|
+
});
|
|
35
45
|
|
|
36
46
|
// CHECK OPTIONAL
|
|
37
47
|
const flag: ts.ElementFlags | undefined = flagList[i];
|
|
@@ -11,23 +11,17 @@ export const explore_metadata =
|
|
|
11
11
|
(checker: ts.TypeChecker) =>
|
|
12
12
|
(options: MetadataFactory.IOptions) =>
|
|
13
13
|
(collection: MetadataCollection) =>
|
|
14
|
-
(
|
|
15
|
-
|
|
16
|
-
parentResolved: boolean,
|
|
17
|
-
aliased: boolean = false,
|
|
18
|
-
): Metadata => {
|
|
14
|
+
(errors: MetadataFactory.IError[]) =>
|
|
15
|
+
(type: ts.Type | null, explore: MetadataFactory.IExplore): Metadata => {
|
|
19
16
|
// CONSTRUCT METADATA
|
|
20
|
-
const meta: Metadata = Metadata.initialize(
|
|
21
|
-
collection.entire_.add(meta);
|
|
22
|
-
|
|
17
|
+
const meta: Metadata = Metadata.initialize(explore.escaped);
|
|
23
18
|
if (type === null) return meta;
|
|
24
19
|
|
|
25
20
|
// ITERATE TYPESCRIPT TYPES
|
|
26
|
-
iterate_metadata(checker)(options)(collection)(
|
|
21
|
+
iterate_metadata(checker)(options)(collection)(errors)(
|
|
27
22
|
meta,
|
|
28
23
|
type,
|
|
29
|
-
|
|
30
|
-
aliased,
|
|
24
|
+
explore,
|
|
31
25
|
);
|
|
32
26
|
emend_metadata_atomics(meta);
|
|
33
27
|
if (meta.escaped) {
|
|
@@ -2,9 +2,9 @@ import ts from "typescript";
|
|
|
2
2
|
|
|
3
3
|
import { Metadata } from "../../../schemas/metadata/Metadata";
|
|
4
4
|
|
|
5
|
-
// import { ArrayUtil } from "../../../utils/ArrayUtil";
|
|
6
5
|
import { MetadataCollection } from "../../MetadataCollection";
|
|
7
6
|
import { MetadataFactory } from "../../MetadataFactory";
|
|
7
|
+
import { TypeFactory } from "../../TypeFactory";
|
|
8
8
|
import { iterate_metadata_alias } from "./iterate_metadata_alias";
|
|
9
9
|
import { iterate_metadata_array } from "./iterate_metadata_array";
|
|
10
10
|
import { iterate_metadata_atomic } from "./iterate_metadata_atomic";
|
|
@@ -24,39 +24,42 @@ export const iterate_metadata =
|
|
|
24
24
|
(checker: ts.TypeChecker) =>
|
|
25
25
|
(options: MetadataFactory.IOptions) =>
|
|
26
26
|
(collection: MetadataCollection) =>
|
|
27
|
+
(errors: MetadataFactory.IError[]) =>
|
|
27
28
|
(
|
|
28
29
|
meta: Metadata,
|
|
29
30
|
type: ts.Type,
|
|
30
|
-
|
|
31
|
-
aliased: boolean,
|
|
31
|
+
explore: MetadataFactory.IExplore,
|
|
32
32
|
): void => {
|
|
33
|
-
if (type.isTypeParameter() === true)
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
33
|
+
if (type.isTypeParameter() === true) {
|
|
34
|
+
errors.push({
|
|
35
|
+
name: TypeFactory.getFullName(checker)(type),
|
|
36
|
+
explore: { ...explore },
|
|
37
|
+
messages: ["non-specified generic argument found."],
|
|
38
|
+
});
|
|
39
|
+
return;
|
|
40
|
+
}
|
|
37
41
|
// CHECK SPECIAL CASES
|
|
38
|
-
if (
|
|
39
|
-
(aliased !== true &&
|
|
40
|
-
iterate_metadata_alias(checker)(options)(collection)(
|
|
42
|
+
else if (
|
|
43
|
+
(explore.aliased !== true &&
|
|
44
|
+
iterate_metadata_alias(checker)(options)(collection)(errors)(
|
|
41
45
|
meta,
|
|
42
46
|
type,
|
|
47
|
+
explore,
|
|
43
48
|
)) ||
|
|
44
|
-
iterate_metadata_intersection(checker)(options)(collection)(
|
|
49
|
+
iterate_metadata_intersection(checker)(options)(collection)(errors)(
|
|
45
50
|
meta,
|
|
46
51
|
type,
|
|
47
|
-
|
|
48
|
-
aliased,
|
|
52
|
+
explore,
|
|
49
53
|
) ||
|
|
50
|
-
iterate_metadata_union(checker)(options)(collection)(
|
|
54
|
+
iterate_metadata_union(checker)(options)(collection)(errors)(
|
|
51
55
|
meta,
|
|
52
56
|
type,
|
|
53
|
-
|
|
57
|
+
explore,
|
|
54
58
|
) ||
|
|
55
|
-
iterate_metadata_resolve(checker)(options)(collection)(
|
|
59
|
+
iterate_metadata_resolve(checker)(options)(collection)(errors)(
|
|
56
60
|
meta,
|
|
57
61
|
type,
|
|
58
|
-
|
|
59
|
-
aliased,
|
|
62
|
+
explore,
|
|
60
63
|
)
|
|
61
64
|
)
|
|
62
65
|
return;
|
|
@@ -64,18 +67,35 @@ export const iterate_metadata =
|
|
|
64
67
|
// ITERATE CASES
|
|
65
68
|
iterate_metadata_coalesce(meta, type) ||
|
|
66
69
|
iterate_metadata_constant(checker)(options)(meta, type) ||
|
|
67
|
-
iterate_metadata_template(checker)(options)(collection)(
|
|
70
|
+
iterate_metadata_template(checker)(options)(collection)(errors)(
|
|
68
71
|
meta,
|
|
69
72
|
type,
|
|
73
|
+
explore,
|
|
70
74
|
) ||
|
|
71
75
|
iterate_metadata_atomic(meta, type) ||
|
|
72
|
-
iterate_metadata_tuple(checker)(options)(collection)(
|
|
76
|
+
iterate_metadata_tuple(checker)(options)(collection)(errors)(
|
|
73
77
|
meta,
|
|
74
78
|
type as ts.TupleType,
|
|
79
|
+
explore,
|
|
80
|
+
) ||
|
|
81
|
+
iterate_metadata_array(checker)(options)(collection)(errors)(
|
|
82
|
+
meta,
|
|
83
|
+
type,
|
|
84
|
+
explore,
|
|
75
85
|
) ||
|
|
76
|
-
iterate_metadata_array(checker)(options)(collection)(meta, type) ||
|
|
77
86
|
iterate_metadata_native(checker)(meta, type) ||
|
|
78
|
-
iterate_metadata_map(checker)(options)(collection)(
|
|
79
|
-
|
|
80
|
-
|
|
87
|
+
iterate_metadata_map(checker)(options)(collection)(errors)(
|
|
88
|
+
meta,
|
|
89
|
+
type,
|
|
90
|
+
explore,
|
|
91
|
+
) ||
|
|
92
|
+
iterate_metadata_set(checker)(options)(collection)(errors)(
|
|
93
|
+
meta,
|
|
94
|
+
type,
|
|
95
|
+
explore,
|
|
96
|
+
) ||
|
|
97
|
+
iterate_metadata_object(checker)(options)(collection)(errors)(
|
|
98
|
+
meta,
|
|
99
|
+
type,
|
|
100
|
+
);
|
|
81
101
|
};
|