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
package/src/tags/TagBase.ts
CHANGED
|
@@ -1,17 +1,22 @@
|
|
|
1
|
-
export type TagBase<
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
| string
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
1
|
+
export type TagBase<Props extends TagBase.IProps<any, any, any, any, any>> = {
|
|
2
|
+
"typia.tag"?: Props;
|
|
3
|
+
};
|
|
4
|
+
export namespace TagBase {
|
|
5
|
+
export interface IProps<
|
|
6
|
+
Target extends "bigint" | "number" | "string" | "array",
|
|
7
|
+
Kind extends string,
|
|
8
|
+
Value extends boolean | bigint | number | string | undefined,
|
|
9
|
+
Validate extends
|
|
10
|
+
| string
|
|
11
|
+
| {
|
|
12
|
+
[key in Target]?: string;
|
|
13
|
+
},
|
|
14
|
+
Exclusive extends boolean | string[],
|
|
15
|
+
> {
|
|
12
16
|
target: Target;
|
|
13
17
|
kind: Kind;
|
|
14
18
|
value: Value;
|
|
15
19
|
validate: Validate;
|
|
16
|
-
|
|
17
|
-
}
|
|
20
|
+
exclusive?: Exclusive | string[];
|
|
21
|
+
}
|
|
22
|
+
}
|
package/src/tags/Type.ts
CHANGED
|
@@ -1,30 +1,27 @@
|
|
|
1
|
+
import { TagBase } from "./TagBase";
|
|
2
|
+
|
|
1
3
|
export type Type<
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
bigint: `BigInt(0) <= $input && $input <= BigInt(18446744073709551615)`;
|
|
27
|
-
}
|
|
28
|
-
: `-1.175494351e38 <= $input <= 3.4028235e38`;
|
|
29
|
-
};
|
|
30
|
-
};
|
|
4
|
+
Value extends "int32" | "uint32" | "int64" | "uint64" | "float" | "double",
|
|
5
|
+
> = TagBase<{
|
|
6
|
+
target: Value extends "int64" | "uint64" ? "bigint" | "number" : "number";
|
|
7
|
+
kind: "type";
|
|
8
|
+
value: Value;
|
|
9
|
+
validate: Value extends "int32"
|
|
10
|
+
? `Math.floor($input) === $input && -2147483648 <= $input && $input <= 2147483647`
|
|
11
|
+
: Value extends "uint32"
|
|
12
|
+
? `Math.floor($input) === $input && 0 <= $input && $input <= 4294967295`
|
|
13
|
+
: Value extends "int64"
|
|
14
|
+
? {
|
|
15
|
+
number: `Math.floor($input) === $input && -9223372036854775808 <= $input && $input <= 9223372036854775807`;
|
|
16
|
+
bigint: `true`;
|
|
17
|
+
}
|
|
18
|
+
: Value extends "uint64"
|
|
19
|
+
? {
|
|
20
|
+
number: `Math.floor($input) === $input && 0 <= $input && $input <= 18446744073709551615`;
|
|
21
|
+
bigint: `BigInt(0) <= $input`;
|
|
22
|
+
}
|
|
23
|
+
: Value extends "float"
|
|
24
|
+
? `-1.175494351e38 <= $input && $input <= 3.4028235e38`
|
|
25
|
+
: `true`;
|
|
26
|
+
exclusive: true;
|
|
27
|
+
}>;
|
package/src/tags/index.ts
CHANGED
package/src/transform.ts
CHANGED
|
@@ -1,11 +1,13 @@
|
|
|
1
1
|
import ts from "typescript";
|
|
2
2
|
|
|
3
3
|
import { FileTransformer } from "./transformers/FileTransformer";
|
|
4
|
+
import { IProject } from "./transformers/IProject";
|
|
4
5
|
import { ITransformOptions } from "./transformers/ITransformOptions";
|
|
5
6
|
|
|
6
7
|
export const transform = (
|
|
7
8
|
program: ts.Program,
|
|
8
|
-
options
|
|
9
|
+
options: ITransformOptions | undefined,
|
|
10
|
+
extras: IProject["extras"],
|
|
9
11
|
): ts.TransformerFactory<ts.SourceFile> => {
|
|
10
12
|
const compilerOptions: ts.CompilerOptions = program.getCompilerOptions();
|
|
11
13
|
const strict: boolean =
|
|
@@ -13,15 +15,21 @@ export const transform = (
|
|
|
13
15
|
? !!compilerOptions.strictNullChecks
|
|
14
16
|
: !!compilerOptions.strict;
|
|
15
17
|
if (strict === false)
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
18
|
+
extras.addDiagnostic({
|
|
19
|
+
category: ts.DiagnosticCategory.Error,
|
|
20
|
+
code: "(typia)" as any,
|
|
21
|
+
file: undefined,
|
|
22
|
+
start: undefined,
|
|
23
|
+
length: undefined,
|
|
24
|
+
messageText: "strict mode is required.",
|
|
25
|
+
});
|
|
19
26
|
return FileTransformer.transform({
|
|
20
27
|
program,
|
|
21
28
|
compilerOptions,
|
|
22
29
|
checker: program.getTypeChecker(),
|
|
23
30
|
printer: ts.createPrinter(),
|
|
24
|
-
options: options
|
|
31
|
+
options: options ?? {},
|
|
32
|
+
extras,
|
|
25
33
|
});
|
|
26
34
|
};
|
|
27
35
|
export default transform;
|
|
@@ -64,7 +64,7 @@ import { ProtobufValidateEncodeTransformer } from "./features/protobuf/ProtobufV
|
|
|
64
64
|
export namespace CallExpressionTransformer {
|
|
65
65
|
export const transform =
|
|
66
66
|
(project: IProject) =>
|
|
67
|
-
(expression: ts.CallExpression): ts.Expression => {
|
|
67
|
+
(expression: ts.CallExpression): ts.Expression | null => {
|
|
68
68
|
//----
|
|
69
69
|
// VALIDATIONS
|
|
70
70
|
//----
|
|
@@ -95,7 +95,10 @@ export namespace CallExpressionTransformer {
|
|
|
95
95
|
if (functor === undefined) return expression;
|
|
96
96
|
|
|
97
97
|
// RETURNS WITH TRANSFORMATION
|
|
98
|
-
|
|
98
|
+
const result: ts.Expression | null = functor()(project)(
|
|
99
|
+
expression.expression,
|
|
100
|
+
)(expression);
|
|
101
|
+
return result ?? expression;
|
|
99
102
|
};
|
|
100
103
|
|
|
101
104
|
const isTarget = (location: string): boolean => {
|
|
@@ -126,7 +129,7 @@ type Task = (
|
|
|
126
129
|
project: IProject,
|
|
127
130
|
) => (
|
|
128
131
|
modulo: ts.LeftHandSideExpression,
|
|
129
|
-
) => (expression: ts.CallExpression) => ts.Expression;
|
|
132
|
+
) => (expression: ts.CallExpression) => ts.Expression | null;
|
|
130
133
|
|
|
131
134
|
const FUNCTORS: Record<string, Record<string, () => Task>> = {
|
|
132
135
|
module: {
|
|
@@ -2,6 +2,7 @@ import ts from "typescript";
|
|
|
2
2
|
|
|
3
3
|
import { IProject } from "./IProject";
|
|
4
4
|
import { NodeTransformer } from "./NodeTransformer";
|
|
5
|
+
import { TransformerError } from "./TransformerError";
|
|
5
6
|
|
|
6
7
|
export namespace FileTransformer {
|
|
7
8
|
export const transform =
|
|
@@ -19,29 +20,40 @@ export namespace FileTransformer {
|
|
|
19
20
|
const iterate_node =
|
|
20
21
|
(project: IProject) =>
|
|
21
22
|
(context: ts.TransformationContext) =>
|
|
22
|
-
(node: ts.Node): ts.Node =>
|
|
23
|
-
ts.
|
|
24
|
-
|
|
23
|
+
(node: ts.Node): ts.Node => {
|
|
24
|
+
const changed: ts.Node | null = try_transform_node(project)(node);
|
|
25
|
+
return ts.visitEachChild(
|
|
26
|
+
changed ?? node,
|
|
25
27
|
(child) => iterate_node(project)(context)(child),
|
|
26
28
|
context,
|
|
27
29
|
);
|
|
30
|
+
};
|
|
28
31
|
|
|
29
32
|
const try_transform_node =
|
|
30
33
|
(project: IProject) =>
|
|
31
|
-
(node: ts.Node): ts.Node => {
|
|
34
|
+
(node: ts.Node): ts.Node | null => {
|
|
32
35
|
try {
|
|
33
36
|
return NodeTransformer.transform(project)(node);
|
|
34
37
|
} catch (exp) {
|
|
35
|
-
|
|
38
|
+
// ONLY ACCEPT TRANSFORMER-ERROR
|
|
39
|
+
if (!isTransformerError(exp)) throw exp;
|
|
36
40
|
|
|
37
|
-
|
|
38
|
-
const
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
}
|
|
44
|
-
|
|
41
|
+
// REPORT DIAGNOSTIC
|
|
42
|
+
const diagnostic = ts.createDiagnosticForNode(node, {
|
|
43
|
+
key: exp.code,
|
|
44
|
+
category: ts.DiagnosticCategory.Error,
|
|
45
|
+
message: exp.message,
|
|
46
|
+
code: `(${exp.code})` as any,
|
|
47
|
+
});
|
|
48
|
+
project.extras.addDiagnostic(diagnostic);
|
|
49
|
+
return null;
|
|
45
50
|
}
|
|
46
51
|
};
|
|
47
52
|
}
|
|
53
|
+
|
|
54
|
+
const isTransformerError = (error: any): error is TransformerError =>
|
|
55
|
+
typeof error === "object" &&
|
|
56
|
+
error !== null &&
|
|
57
|
+
error.constructor.name === "TransformerError" &&
|
|
58
|
+
typeof error.code === "string" &&
|
|
59
|
+
typeof error.message === "string";
|
|
@@ -6,7 +6,7 @@ import { IProject } from "./IProject";
|
|
|
6
6
|
export namespace NodeTransformer {
|
|
7
7
|
export const transform =
|
|
8
8
|
(project: IProject) =>
|
|
9
|
-
(expression: ts.Node): ts.Node =>
|
|
9
|
+
(expression: ts.Node): ts.Node | null =>
|
|
10
10
|
ts.isCallExpression(expression)
|
|
11
11
|
? CallExpressionTransformer.transform(project)(expression)
|
|
12
12
|
: expression;
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { MetadataFactory } from "../factories/MetadataFactory";
|
|
2
|
+
|
|
3
|
+
import { MetadataObject } from "../schemas/metadata/MetadataObject";
|
|
4
|
+
|
|
5
|
+
import { Escaper } from "../utils/Escaper";
|
|
6
|
+
|
|
7
|
+
export class TransformerError extends Error {
|
|
8
|
+
public readonly code: string;
|
|
9
|
+
|
|
10
|
+
public constructor(props: TransformerError.IProps) {
|
|
11
|
+
super(props.message);
|
|
12
|
+
this.code = props.code;
|
|
13
|
+
|
|
14
|
+
// INHERITANCE POLYFILL
|
|
15
|
+
const proto = new.target.prototype;
|
|
16
|
+
if (Object.setPrototypeOf) Object.setPrototypeOf(this, proto);
|
|
17
|
+
else (this as any).__proto__ = proto;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
export namespace TransformerError {
|
|
21
|
+
export interface IProps {
|
|
22
|
+
code: string;
|
|
23
|
+
message: string;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
export const from =
|
|
27
|
+
(method: string) =>
|
|
28
|
+
(errors: MetadataFactory.IError[]): TransformerError => {
|
|
29
|
+
const body: string = errors
|
|
30
|
+
.map((e) => {
|
|
31
|
+
const subject: string =
|
|
32
|
+
e.explore.object === null
|
|
33
|
+
? ""
|
|
34
|
+
: join(e.explore.object)(e.explore.property);
|
|
35
|
+
const type: string = `${
|
|
36
|
+
subject.length ? `${subject}: ` : ""
|
|
37
|
+
}${e.name}`;
|
|
38
|
+
return `- ${type}\n${e.messages
|
|
39
|
+
.map((msg) => ` - ${msg}`)
|
|
40
|
+
.join("\n")}`;
|
|
41
|
+
})
|
|
42
|
+
.join("\n\n");
|
|
43
|
+
return new TransformerError({
|
|
44
|
+
code: method,
|
|
45
|
+
message: `unsupported type detected\n\n${body}`,
|
|
46
|
+
});
|
|
47
|
+
};
|
|
48
|
+
|
|
49
|
+
const join = (object: MetadataObject) => (key: string | object | null) => {
|
|
50
|
+
if (key === null) return object.name;
|
|
51
|
+
else if (typeof key === "object") return `${object.name}[key]`;
|
|
52
|
+
else if (Escaper.variable(key)) return `${object.name}.${key}`;
|
|
53
|
+
return `${object.name}[${JSON.stringify(key)}]`;
|
|
54
|
+
};
|
|
55
|
+
}
|
|
@@ -3,6 +3,7 @@ import ts from "typescript";
|
|
|
3
3
|
import { RandomProgrammer } from "../../programmers/RandomProgrammer";
|
|
4
4
|
|
|
5
5
|
import { IProject } from "../IProject";
|
|
6
|
+
import { TransformerError } from "../TransformerError";
|
|
6
7
|
|
|
7
8
|
export namespace CreateRandomTransformer {
|
|
8
9
|
export const transform =
|
|
@@ -10,13 +11,21 @@ export namespace CreateRandomTransformer {
|
|
|
10
11
|
(modulo: ts.LeftHandSideExpression) =>
|
|
11
12
|
(expression: ts.CallExpression): ts.Expression => {
|
|
12
13
|
// CHECK GENERIC ARGUMENT EXISTENCE
|
|
13
|
-
if (!expression.typeArguments?.[0])
|
|
14
|
+
if (!expression.typeArguments?.[0])
|
|
15
|
+
throw new TransformerError({
|
|
16
|
+
code: "typia.createRandom",
|
|
17
|
+
message: "generic argument is not specified.",
|
|
18
|
+
});
|
|
14
19
|
|
|
15
20
|
// GET TYPE INFO
|
|
16
21
|
const node: ts.TypeNode = expression.typeArguments[0];
|
|
17
22
|
const type: ts.Type = project.checker.getTypeFromTypeNode(node);
|
|
18
23
|
|
|
19
|
-
if (type.isTypeParameter())
|
|
24
|
+
if (type.isTypeParameter())
|
|
25
|
+
throw new TransformerError({
|
|
26
|
+
code: "typia.createRandom",
|
|
27
|
+
message: "non-specified generic argument.",
|
|
28
|
+
});
|
|
20
29
|
|
|
21
30
|
// DO TRANSFORM
|
|
22
31
|
return RandomProgrammer.write({
|
|
@@ -32,8 +41,3 @@ export namespace CreateRandomTransformer {
|
|
|
32
41
|
);
|
|
33
42
|
};
|
|
34
43
|
}
|
|
35
|
-
|
|
36
|
-
const NOT_SPECIFIED =
|
|
37
|
-
"Error on typia.createRandom(): generic argument is not specified.";
|
|
38
|
-
const NO_GENERIC_ARGUMENT =
|
|
39
|
-
"Error on typia.createRandom(): non-specified generic argument.";
|
|
@@ -3,6 +3,7 @@ import ts from "typescript";
|
|
|
3
3
|
import { RandomProgrammer } from "../../programmers/RandomProgrammer";
|
|
4
4
|
|
|
5
5
|
import { IProject } from "../IProject";
|
|
6
|
+
import { TransformerError } from "../TransformerError";
|
|
6
7
|
|
|
7
8
|
export namespace RandomTransformer {
|
|
8
9
|
export const transform =
|
|
@@ -10,13 +11,21 @@ export namespace RandomTransformer {
|
|
|
10
11
|
(modulo: ts.LeftHandSideExpression) =>
|
|
11
12
|
(expression: ts.CallExpression): ts.Expression => {
|
|
12
13
|
// CHECK GENERIC ARGUMENT EXISTENCE
|
|
13
|
-
if (!expression.typeArguments?.[0])
|
|
14
|
+
if (!expression.typeArguments?.[0])
|
|
15
|
+
throw new TransformerError({
|
|
16
|
+
code: `typia.${modulo.getText()}`,
|
|
17
|
+
message: "generic argument is not specified.",
|
|
18
|
+
});
|
|
14
19
|
|
|
15
20
|
// GET TYPE INFO
|
|
16
21
|
const node: ts.TypeNode = expression.typeArguments[0];
|
|
17
22
|
const type: ts.Type = project.checker.getTypeFromTypeNode(node);
|
|
18
23
|
|
|
19
|
-
if (type.isTypeParameter())
|
|
24
|
+
if (type.isTypeParameter())
|
|
25
|
+
throw new TransformerError({
|
|
26
|
+
code: `typia.${modulo.getText()}`,
|
|
27
|
+
message: "non-specified generic argument.",
|
|
28
|
+
});
|
|
20
29
|
|
|
21
30
|
// DO TRANSFORM
|
|
22
31
|
return ts.factory.createCallExpression(
|
|
@@ -35,8 +44,3 @@ export namespace RandomTransformer {
|
|
|
35
44
|
);
|
|
36
45
|
};
|
|
37
46
|
}
|
|
38
|
-
|
|
39
|
-
const NOT_SPECIFIED =
|
|
40
|
-
"Error on typia.random(): generic argument is not specified.";
|
|
41
|
-
const NO_GENERIC_ARGUMENT =
|
|
42
|
-
"Error on typia.random(): non-specified generic argument.";
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import ts from "typescript";
|
|
2
2
|
|
|
3
|
+
import { JsonMetadataFactory } from "../../../factories/JsonMetadataFactory";
|
|
3
4
|
import { LiteralFactory } from "../../../factories/LiteralFactory";
|
|
4
5
|
import { MetadataCollection } from "../../../factories/MetadataCollection";
|
|
5
6
|
import { MetadataFactory } from "../../../factories/MetadataFactory";
|
|
@@ -9,14 +10,20 @@ import { Metadata } from "../../../schemas/metadata/Metadata";
|
|
|
9
10
|
|
|
10
11
|
import { JsonApplicationProgrammer } from "../../../programmers/json/JsonApplicationProgrammer";
|
|
11
12
|
|
|
13
|
+
import { ValidationPipe } from "../../../typings/ValidationPipe";
|
|
14
|
+
|
|
12
15
|
import { IProject } from "../../IProject";
|
|
16
|
+
import { TransformerError } from "../../TransformerError";
|
|
13
17
|
|
|
14
18
|
export namespace JsonApplicationTransformer {
|
|
15
19
|
export const transform =
|
|
16
20
|
({ checker }: IProject) =>
|
|
17
21
|
(expression: ts.CallExpression): ts.Expression => {
|
|
18
22
|
if (!expression.typeArguments?.length)
|
|
19
|
-
throw new
|
|
23
|
+
throw new TransformerError({
|
|
24
|
+
code: "typia.json.application",
|
|
25
|
+
message: "no generic argument.",
|
|
26
|
+
});
|
|
20
27
|
|
|
21
28
|
//----
|
|
22
29
|
// GET ARGUMENTS
|
|
@@ -32,7 +39,10 @@ export namespace JsonApplicationTransformer {
|
|
|
32
39
|
checker.getTypeFromTypeNode(child as ts.TypeNode),
|
|
33
40
|
);
|
|
34
41
|
if (types.some((t) => t.isTypeParameter()))
|
|
35
|
-
throw new
|
|
42
|
+
throw new TransformerError({
|
|
43
|
+
code: "typia.json.application",
|
|
44
|
+
message: "non-specified generic argument(s).",
|
|
45
|
+
});
|
|
36
46
|
|
|
37
47
|
// ADDITIONAL PARAMETERS
|
|
38
48
|
const purpose: "swagger" | "ajv" = get_parameter(
|
|
@@ -48,24 +58,25 @@ export namespace JsonApplicationTransformer {
|
|
|
48
58
|
//----
|
|
49
59
|
// METADATA
|
|
50
60
|
const collection: MetadataCollection = new MetadataCollection();
|
|
51
|
-
const
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
)
|
|
61
|
+
const results: ValidationPipe<Metadata, MetadataFactory.IError>[] =
|
|
62
|
+
types.map((type) =>
|
|
63
|
+
MetadataFactory.analyze(checker)({
|
|
64
|
+
escape: true,
|
|
65
|
+
constant: true,
|
|
66
|
+
absorb: false,
|
|
67
|
+
validate: JsonMetadataFactory.validate,
|
|
68
|
+
})(collection)(type),
|
|
69
|
+
);
|
|
70
|
+
|
|
71
|
+
// REPORT BUG IF REQUIRED
|
|
72
|
+
const metadatas: Metadata[] = [];
|
|
73
|
+
const errors: MetadataFactory.IError[] = [];
|
|
74
|
+
for (const r of results) {
|
|
75
|
+
if (r.success === false) errors.push(...r.errors);
|
|
76
|
+
else metadatas.push(r.data);
|
|
77
|
+
}
|
|
78
|
+
if (errors.length)
|
|
79
|
+
throw TransformerError.from("typia.json.application")(errors);
|
|
69
80
|
|
|
70
81
|
// APPLICATION
|
|
71
82
|
const app: IJsonApplication = JsonApplicationProgrammer.write({
|
|
@@ -88,25 +99,18 @@ export namespace JsonApplicationTransformer {
|
|
|
88
99
|
// CHECK LITERAL TYPE
|
|
89
100
|
const type: ts.Type = checker.getTypeFromTypeNode(node);
|
|
90
101
|
if (!type.isLiteral())
|
|
91
|
-
throw new
|
|
92
|
-
|
|
93
|
-
|
|
102
|
+
throw new TransformerError({
|
|
103
|
+
code: "typia.json.application",
|
|
104
|
+
message: `generic argument "${name}" must be constant.`,
|
|
105
|
+
});
|
|
94
106
|
|
|
95
107
|
// GET VALUE AND VALIDATE IT
|
|
96
108
|
const value = type.value;
|
|
97
109
|
if (typeof value !== "string" || predicator(value) === false)
|
|
98
|
-
throw new
|
|
99
|
-
|
|
100
|
-
|
|
110
|
+
throw new TransformerError({
|
|
111
|
+
code: "typia.json.application",
|
|
112
|
+
message: `invalid value on generic argument "${name}".`,
|
|
113
|
+
});
|
|
101
114
|
return value as T;
|
|
102
115
|
};
|
|
103
116
|
}
|
|
104
|
-
|
|
105
|
-
const NO_GENERIC_ARGUMENT =
|
|
106
|
-
"Error on typia.json.application(): no generic argument.";
|
|
107
|
-
const GENERIC_ARGUMENT =
|
|
108
|
-
"Error on typia.json.application(): non-specified generic argument(s).";
|
|
109
|
-
const NO_BIGIT =
|
|
110
|
-
"Error on typia.json.application(): does not allow bigint type.";
|
|
111
|
-
const NO_UNDEFINED_IN_ARRAY =
|
|
112
|
-
"Error on typia.json.application(): does not allow undefined type in array.";
|
|
@@ -8,13 +8,17 @@ import { IMetadataApplication } from "../../../schemas/metadata/IMetadataApplica
|
|
|
8
8
|
import { Metadata } from "../../../schemas/metadata/Metadata";
|
|
9
9
|
|
|
10
10
|
import { IProject } from "../../IProject";
|
|
11
|
+
import { TransformerError } from "../../TransformerError";
|
|
11
12
|
|
|
12
13
|
export namespace MetadataTransformer {
|
|
13
14
|
export const transform =
|
|
14
15
|
({ checker }: IProject) =>
|
|
15
16
|
(expression: ts.CallExpression): ts.Expression => {
|
|
16
17
|
if (!expression.typeArguments?.length)
|
|
17
|
-
throw new
|
|
18
|
+
throw new TransformerError({
|
|
19
|
+
code: "typia.metadata",
|
|
20
|
+
message: "no generic argument.",
|
|
21
|
+
});
|
|
18
22
|
|
|
19
23
|
// VALIDATE TUPLE ARGUMENTS
|
|
20
24
|
const top: ts.Node = expression.typeArguments[0]!;
|
|
@@ -27,17 +31,25 @@ export namespace MetadataTransformer {
|
|
|
27
31
|
checker.getTypeFromTypeNode(child as ts.TypeNode),
|
|
28
32
|
);
|
|
29
33
|
if (types.some((t) => t.isTypeParameter()))
|
|
30
|
-
throw new
|
|
34
|
+
throw new TransformerError({
|
|
35
|
+
code: "typia.metadata",
|
|
36
|
+
message: "non-specified generic argument(s).",
|
|
37
|
+
});
|
|
31
38
|
|
|
32
39
|
// METADATA
|
|
33
40
|
const collection: MetadataCollection = new MetadataCollection();
|
|
34
|
-
const metadatas: Array<Metadata> = types.map((type) =>
|
|
35
|
-
MetadataFactory.analyze(checker)({
|
|
41
|
+
const metadatas: Array<Metadata> = types.map((type) => {
|
|
42
|
+
const result = MetadataFactory.analyze(checker)({
|
|
36
43
|
escape: true,
|
|
37
44
|
constant: true,
|
|
38
45
|
absorb: true,
|
|
39
|
-
})(collection)(type)
|
|
40
|
-
|
|
46
|
+
})(collection)(type);
|
|
47
|
+
if (result.success === false)
|
|
48
|
+
throw TransformerError.from("typia.metadata")(
|
|
49
|
+
result.errors,
|
|
50
|
+
);
|
|
51
|
+
return result.data;
|
|
52
|
+
});
|
|
41
53
|
|
|
42
54
|
// CONVERT TO PRIMITIVE TYPE
|
|
43
55
|
const app: IMetadataApplication = {
|
|
@@ -47,7 +59,3 @@ export namespace MetadataTransformer {
|
|
|
47
59
|
return LiteralFactory.generate(app);
|
|
48
60
|
};
|
|
49
61
|
}
|
|
50
|
-
|
|
51
|
-
const NO_GENERIC_ARGUMENT = "Error on typia.metadata(): no generic argument.";
|
|
52
|
-
const GENERIC_ARGUMENT =
|
|
53
|
-
"Error on typia.metadata(): non-specified generic argument(s).";
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { MiscIsPruneProgrammer } from "../../../programmers/misc/MiscIsPruneProgrammer";
|
|
2
2
|
|
|
3
3
|
import { GenericTransformer } from "../../internal/GenericTransformer";
|
|
4
4
|
|
|
5
5
|
export namespace MiscCreateIsPruneTransformer {
|
|
6
6
|
export const transform = GenericTransformer.factory("createIsPrune")(
|
|
7
|
-
(project) => (modulo) =>
|
|
7
|
+
(project) => (modulo) => MiscIsPruneProgrammer.write(project)(modulo),
|
|
8
8
|
);
|
|
9
9
|
}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { MiscIsPruneProgrammer } from "../../../programmers/misc/MiscIsPruneProgrammer";
|
|
2
2
|
|
|
3
3
|
import { GenericTransformer } from "../../internal/GenericTransformer";
|
|
4
4
|
|
|
5
5
|
export namespace MiscIsPruneTransformer {
|
|
6
6
|
export const transform = GenericTransformer.scalar("isPrune")(
|
|
7
|
-
(project) => (modulo) =>
|
|
7
|
+
(project) => (modulo) => MiscIsPruneProgrammer.write(project)(modulo),
|
|
8
8
|
);
|
|
9
9
|
}
|
|
@@ -3,26 +3,30 @@ import ts from "typescript";
|
|
|
3
3
|
import { MiscLiteralsProgrammer } from "../../../programmers/misc/MiscLiteralsProgrammer";
|
|
4
4
|
|
|
5
5
|
import { IProject } from "../../IProject";
|
|
6
|
+
import { TransformerError } from "../../TransformerError";
|
|
6
7
|
|
|
7
8
|
export namespace MiscLiteralsTransformer {
|
|
8
9
|
export const transform =
|
|
9
10
|
(project: IProject) =>
|
|
10
11
|
(expression: ts.CallExpression): ts.Expression => {
|
|
11
12
|
// CHECK GENERIC ARGUMENT EXISTENCE
|
|
12
|
-
if (!expression.typeArguments?.[0])
|
|
13
|
+
if (!expression.typeArguments?.[0])
|
|
14
|
+
throw new TransformerError({
|
|
15
|
+
code: "typia.misc.literals",
|
|
16
|
+
message: "generic argument is not specified.",
|
|
17
|
+
});
|
|
13
18
|
|
|
14
19
|
// GET TYPE INFO
|
|
15
20
|
const node: ts.TypeNode = expression.typeArguments[0];
|
|
16
21
|
const type: ts.Type = project.checker.getTypeFromTypeNode(node);
|
|
17
22
|
|
|
18
|
-
if (type.isTypeParameter())
|
|
23
|
+
if (type.isTypeParameter())
|
|
24
|
+
throw new TransformerError({
|
|
25
|
+
code: "typia.misc.literals",
|
|
26
|
+
message: "non-specified generic argument.",
|
|
27
|
+
});
|
|
19
28
|
|
|
20
29
|
// DO TRANSFORM
|
|
21
30
|
return MiscLiteralsProgrammer.write(project)(type);
|
|
22
31
|
};
|
|
23
32
|
}
|
|
24
|
-
|
|
25
|
-
const NOT_SPECIFIED =
|
|
26
|
-
"Error on typia.literals(): generic argument is not specified.";
|
|
27
|
-
const NO_GENERIC_ARGUMENT =
|
|
28
|
-
"Error on typia.literals(): non-specified generic argument.";
|