typia 4.0.0-dev.20230502 → 4.0.0-dev.20230519
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 +2 -9
- package/lib/TypeGuardError.js +6 -2
- package/lib/TypeGuardError.js.map +1 -1
- package/lib/executable/TypiaGenerateWizard.js +25 -24
- package/lib/executable/TypiaGenerateWizard.js.map +1 -1
- package/lib/executable/TypiaSetupWizard.js +28 -21
- package/lib/executable/TypiaSetupWizard.js.map +1 -1
- package/lib/executable/setup/ArgumentParser.js +6 -6
- package/lib/executable/setup/ArgumentParser.js.map +1 -1
- package/lib/executable/setup/CommandExecutor.js +1 -1
- package/lib/executable/setup/CommandExecutor.js.map +1 -1
- package/lib/executable/setup/FileRetriever.js +1 -1
- package/lib/executable/setup/FileRetriever.js.map +1 -1
- package/lib/executable/setup/PackageManager.js +8 -8
- package/lib/executable/setup/PackageManager.js.map +1 -1
- package/lib/executable/setup/PluginConfigurator.js +6 -5
- package/lib/executable/setup/PluginConfigurator.js.map +1 -1
- package/lib/executable/typia.js +17 -17
- package/lib/executable/typia.js.map +1 -1
- package/lib/factories/CommentFactory.d.ts +3 -3
- package/lib/factories/CommentFactory.js +4 -1
- package/lib/factories/CommentFactory.js.map +1 -1
- package/lib/factories/ExpressionFactory.d.ts +6 -6
- package/lib/factories/ExpressionFactory.js +35 -29
- package/lib/factories/ExpressionFactory.js.map +1 -1
- package/lib/factories/IdentifierFactory.d.ts +4 -8
- package/lib/factories/IdentifierFactory.js +24 -27
- package/lib/factories/IdentifierFactory.js.map +1 -1
- package/lib/factories/LiteralFactory.d.ts +2 -2
- package/lib/factories/LiteralFactory.js +43 -37
- package/lib/factories/LiteralFactory.js.map +1 -1
- package/lib/factories/MetadataCollection.d.ts +3 -2
- package/lib/factories/MetadataCollection.js +16 -12
- package/lib/factories/MetadataCollection.js.map +1 -1
- package/lib/factories/MetadataFactory.d.ts +3 -6
- package/lib/factories/MetadataFactory.js +6 -4
- package/lib/factories/MetadataFactory.js.map +1 -1
- package/lib/factories/MetadataTagFactory.d.ts +2 -2
- package/lib/factories/MetadataTagFactory.js +25 -8
- package/lib/factories/MetadataTagFactory.js.map +1 -1
- package/lib/factories/StatementFactory.d.ts +2 -3
- package/lib/factories/StatementFactory.js +6 -13
- package/lib/factories/StatementFactory.js.map +1 -1
- package/lib/factories/TemplateFactory.d.ts +2 -2
- package/lib/factories/TemplateFactory.js +38 -36
- package/lib/factories/TemplateFactory.js.map +1 -1
- package/lib/factories/TypeFactory.d.ts +7 -6
- package/lib/factories/TypeFactory.js +75 -55
- package/lib/factories/TypeFactory.js.map +1 -1
- package/lib/factories/ValueFactory.d.ts +6 -6
- package/lib/factories/ValueFactory.js +15 -15
- package/lib/factories/ValueFactory.js.map +1 -1
- package/lib/factories/internal/metadata/MetadataHelper.js +1 -1
- package/lib/factories/internal/metadata/MetadataHelper.js.map +1 -1
- package/lib/factories/internal/metadata/emplace_metadata_object.d.ts +3 -2
- package/lib/factories/internal/metadata/emplace_metadata_object.js +55 -33
- package/lib/factories/internal/metadata/emplace_metadata_object.js.map +1 -1
- package/lib/factories/internal/metadata/explore_metadata.d.ts +3 -2
- package/lib/factories/internal/metadata/explore_metadata.js +69 -60
- package/lib/factories/internal/metadata/explore_metadata.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata.d.ts +3 -2
- package/lib/factories/internal/metadata/iterate_metadata.js +24 -17
- package/lib/factories/internal/metadata/iterate_metadata.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_array.d.ts +3 -2
- package/lib/factories/internal/metadata/iterate_metadata_array.js +11 -8
- package/lib/factories/internal/metadata/iterate_metadata_array.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_atomic.d.ts +2 -2
- package/lib/factories/internal/metadata/iterate_metadata_atomic.js +26 -24
- package/lib/factories/internal/metadata/iterate_metadata_atomic.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_coalesce.d.ts +2 -2
- package/lib/factories/internal/metadata/iterate_metadata_coalesce.js +26 -26
- package/lib/factories/internal/metadata/iterate_metadata_coalesce.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_constant.d.ts +3 -2
- package/lib/factories/internal/metadata/iterate_metadata_constant.js +29 -29
- package/lib/factories/internal/metadata/iterate_metadata_constant.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_map.d.ts +3 -2
- package/lib/factories/internal/metadata/iterate_metadata_map.js +18 -16
- package/lib/factories/internal/metadata/iterate_metadata_map.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_native.d.ts +3 -2
- package/lib/factories/internal/metadata/iterate_metadata_native.js +39 -37
- package/lib/factories/internal/metadata/iterate_metadata_native.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_object.d.ts +3 -2
- package/lib/factories/internal/metadata/iterate_metadata_object.js +25 -23
- package/lib/factories/internal/metadata/iterate_metadata_object.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_resolve.d.ts +3 -2
- package/lib/factories/internal/metadata/iterate_metadata_resolve.js +15 -10
- package/lib/factories/internal/metadata/iterate_metadata_resolve.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_set.d.ts +3 -2
- package/lib/factories/internal/metadata/iterate_metadata_set.js +14 -12
- package/lib/factories/internal/metadata/iterate_metadata_set.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_template.d.ts +3 -2
- package/lib/factories/internal/metadata/iterate_metadata_template.js +21 -20
- package/lib/factories/internal/metadata/iterate_metadata_template.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_tuple.d.ts +3 -2
- package/lib/factories/internal/metadata/iterate_metadata_tuple.js +26 -25
- package/lib/factories/internal/metadata/iterate_metadata_tuple.js.map +1 -1
- package/lib/factories/internal/metadata/iterate_metadata_union.d.ts +3 -2
- package/lib/factories/internal/metadata/iterate_metadata_union.js +55 -54
- package/lib/factories/internal/metadata/iterate_metadata_union.js.map +1 -1
- package/lib/functional/$dictionary.js +3 -0
- package/lib/functional/$dictionary.js.map +1 -1
- package/lib/functional/$guard.js +20 -0
- package/lib/functional/$guard.js.map +1 -1
- package/lib/functional/$string.js +5 -0
- package/lib/functional/$string.js.map +1 -1
- package/lib/functional/$tail.js +3 -0
- package/lib/functional/$tail.js.map +1 -1
- package/lib/functional/Namespace.js +6 -1
- package/lib/functional/Namespace.js.map +1 -1
- package/lib/metadata/IMetadataTag.d.ts +3 -3
- package/lib/metadata/Metadata.js +73 -4
- package/lib/metadata/Metadata.js.map +1 -1
- package/lib/metadata/MetadataObject.js +23 -3
- package/lib/metadata/MetadataObject.js.map +1 -1
- package/lib/metadata/MetadataProperty.js +13 -1
- package/lib/metadata/MetadataProperty.js.map +1 -1
- package/lib/module.d.ts +1 -5
- package/lib/module.js +187 -6
- package/lib/module.js.map +1 -1
- package/lib/programmers/ApplicationProgrammer.d.ts +1 -8
- package/lib/programmers/ApplicationProgrammer.js +6 -8
- package/lib/programmers/ApplicationProgrammer.js.map +1 -1
- package/lib/programmers/AssertCloneProgrammer.d.ts +2 -6
- package/lib/programmers/AssertCloneProgrammer.js +10 -19
- package/lib/programmers/AssertCloneProgrammer.js.map +1 -1
- package/lib/programmers/AssertParseProgrammer.d.ts +2 -6
- package/lib/programmers/AssertParseProgrammer.js +8 -17
- package/lib/programmers/AssertParseProgrammer.js.map +1 -1
- package/lib/programmers/AssertProgrammer.d.ts +2 -6
- package/lib/programmers/AssertProgrammer.js +103 -107
- package/lib/programmers/AssertProgrammer.js.map +1 -1
- package/lib/programmers/AssertPruneProgrammer.d.ts +2 -2
- package/lib/programmers/AssertPruneProgrammer.js +13 -14
- package/lib/programmers/AssertPruneProgrammer.js.map +1 -1
- package/lib/programmers/AssertStringifyProgrammer.d.ts +2 -6
- package/lib/programmers/AssertStringifyProgrammer.js +9 -18
- package/lib/programmers/AssertStringifyProgrammer.js.map +1 -1
- package/lib/programmers/CheckerProgrammer.d.ts +6 -5
- package/lib/programmers/CheckerProgrammer.js +203 -187
- package/lib/programmers/CheckerProgrammer.js.map +1 -1
- package/lib/programmers/CloneProgrammer.d.ts +2 -6
- package/lib/programmers/CloneProgrammer.js +234 -210
- package/lib/programmers/CloneProgrammer.js.map +1 -1
- package/lib/programmers/FeatureProgrammer.d.ts +9 -8
- package/lib/programmers/FeatureProgrammer.js +115 -97
- package/lib/programmers/FeatureProgrammer.js.map +1 -1
- package/lib/programmers/IsCloneProgrammer.d.ts +2 -6
- package/lib/programmers/IsCloneProgrammer.js +13 -22
- package/lib/programmers/IsCloneProgrammer.js.map +1 -1
- package/lib/programmers/IsParseProgrammer.d.ts +2 -6
- package/lib/programmers/IsParseProgrammer.js +8 -17
- package/lib/programmers/IsParseProgrammer.js.map +1 -1
- package/lib/programmers/IsProgrammer.d.ts +9 -9
- package/lib/programmers/IsProgrammer.js +102 -88
- package/lib/programmers/IsProgrammer.js.map +1 -1
- package/lib/programmers/IsPruneProgrammer.d.ts +2 -2
- package/lib/programmers/IsPruneProgrammer.js +13 -14
- package/lib/programmers/IsPruneProgrammer.js.map +1 -1
- package/lib/programmers/IsStringifyProgrammer.d.ts +2 -6
- package/lib/programmers/IsStringifyProgrammer.js +11 -20
- package/lib/programmers/IsStringifyProgrammer.js.map +1 -1
- package/lib/programmers/LiteralsProgrammer.d.ts +2 -2
- package/lib/programmers/LiteralsProgrammer.js +13 -14
- package/lib/programmers/LiteralsProgrammer.js.map +1 -1
- package/lib/programmers/PruneProgrammer.d.ts +2 -2
- package/lib/programmers/PruneProgrammer.js +100 -81
- package/lib/programmers/PruneProgrammer.js.map +1 -1
- package/lib/programmers/RandomProgrammer.d.ts +2 -6
- package/lib/programmers/RandomProgrammer.js +272 -254
- package/lib/programmers/RandomProgrammer.js.map +1 -1
- package/lib/programmers/StringifyProgrammer.d.ts +2 -6
- package/lib/programmers/StringifyProgrammer.js +398 -356
- package/lib/programmers/StringifyProgrammer.js.map +1 -1
- package/lib/programmers/TypiaProgrammer.js +57 -44
- package/lib/programmers/TypiaProgrammer.js.map +1 -1
- package/lib/programmers/ValidateCloneProgrammer.d.ts +2 -2
- package/lib/programmers/ValidateCloneProgrammer.js +13 -14
- package/lib/programmers/ValidateCloneProgrammer.js.map +1 -1
- package/lib/programmers/ValidateParseProgrammer.d.ts +2 -2
- package/lib/programmers/ValidateParseProgrammer.js +12 -13
- package/lib/programmers/ValidateParseProgrammer.js.map +1 -1
- package/lib/programmers/ValidateProgrammer.d.ts +2 -2
- package/lib/programmers/ValidateProgrammer.js +98 -93
- package/lib/programmers/ValidateProgrammer.js.map +1 -1
- package/lib/programmers/ValidatePruneProgrammer.d.ts +2 -2
- package/lib/programmers/ValidatePruneProgrammer.js +13 -14
- package/lib/programmers/ValidatePruneProgrammer.js.map +1 -1
- package/lib/programmers/ValidateStringifyProgrammer.d.ts +2 -2
- package/lib/programmers/ValidateStringifyProgrammer.js +13 -14
- package/lib/programmers/ValidateStringifyProgrammer.js.map +1 -1
- package/lib/programmers/helpers/AtomicPredicator.js +1 -1
- package/lib/programmers/helpers/AtomicPredicator.js.map +1 -1
- package/lib/programmers/helpers/CloneJoiner.d.ts +4 -4
- package/lib/programmers/helpers/CloneJoiner.js +44 -44
- package/lib/programmers/helpers/CloneJoiner.js.map +1 -1
- package/lib/programmers/helpers/FunctionImporeter.d.ts +3 -1
- package/lib/programmers/helpers/FunctionImporeter.js +6 -8
- package/lib/programmers/helpers/FunctionImporeter.js.map +1 -1
- package/lib/programmers/helpers/ICheckEntry.d.ts +1 -1
- package/lib/programmers/helpers/IExpressionEntry.d.ts +1 -1
- package/lib/programmers/helpers/OptionPredicator.js +1 -1
- package/lib/programmers/helpers/OptionPredicator.js.map +1 -1
- package/lib/programmers/helpers/PruneJoiner.d.ts +4 -4
- package/lib/programmers/helpers/PruneJoiner.js +55 -48
- package/lib/programmers/helpers/PruneJoiner.js.map +1 -1
- package/lib/programmers/helpers/RandomJoiner.d.ts +4 -4
- package/lib/programmers/helpers/RandomJoiner.js +66 -60
- package/lib/programmers/helpers/RandomJoiner.js.map +1 -1
- package/lib/programmers/helpers/RandomRanger.d.ts +3 -3
- package/lib/programmers/helpers/RandomRanger.js +92 -82
- package/lib/programmers/helpers/RandomRanger.js.map +1 -1
- package/lib/programmers/helpers/StringifyJoinder.d.ts +4 -4
- package/lib/programmers/helpers/StringifyJoinder.js +63 -55
- package/lib/programmers/helpers/StringifyJoinder.js.map +1 -1
- package/lib/programmers/helpers/StringifyPredicator.js +1 -1
- package/lib/programmers/helpers/StringifyPredicator.js.map +1 -1
- package/lib/programmers/helpers/UnionExplorer.d.ts +9 -8
- package/lib/programmers/helpers/UnionExplorer.js +104 -65
- package/lib/programmers/helpers/UnionExplorer.js.map +1 -1
- package/lib/programmers/helpers/UnionPredicator.js +6 -1
- package/lib/programmers/helpers/UnionPredicator.js.map +1 -1
- package/lib/programmers/helpers/disable_function_importer_declare.d.ts +2 -0
- package/lib/programmers/helpers/disable_function_importer_declare.js +15 -0
- package/lib/programmers/helpers/disable_function_importer_declare.js.map +1 -0
- package/lib/programmers/internal/JSON_SCHEMA_PREFIX.d.ts +1 -0
- package/lib/programmers/internal/JSON_SCHEMA_PREFIX.js +5 -0
- package/lib/programmers/internal/JSON_SCHEMA_PREFIX.js.map +1 -0
- package/lib/programmers/internal/application_array.js +11 -5
- package/lib/programmers/internal/application_array.js.map +1 -1
- package/lib/programmers/internal/application_boolean.js +4 -1
- package/lib/programmers/internal/application_boolean.js.map +1 -1
- package/lib/programmers/internal/application_constant.js +4 -1
- package/lib/programmers/internal/application_constant.js.map +1 -1
- package/lib/programmers/internal/application_default.js +6 -3
- package/lib/programmers/internal/application_default.js.map +1 -1
- package/lib/programmers/internal/application_default_string.js +5 -0
- package/lib/programmers/internal/application_default_string.js.map +1 -1
- package/lib/programmers/internal/application_native.js +18 -11
- package/lib/programmers/internal/application_native.js.map +1 -1
- package/lib/programmers/internal/application_number.js +17 -7
- package/lib/programmers/internal/application_number.js.map +1 -1
- package/lib/programmers/internal/application_object.js +27 -13
- package/lib/programmers/internal/application_object.js.map +1 -1
- package/lib/programmers/internal/application_schema.js +66 -63
- package/lib/programmers/internal/application_schema.js.map +1 -1
- package/lib/programmers/internal/application_string.js +38 -27
- package/lib/programmers/internal/application_string.js.map +1 -1
- package/lib/programmers/internal/application_templates.js +7 -1
- package/lib/programmers/internal/application_templates.js.map +1 -1
- package/lib/programmers/internal/application_tuple.js +6 -3
- package/lib/programmers/internal/application_tuple.js.map +1 -1
- package/lib/programmers/internal/check_array.js +12 -7
- package/lib/programmers/internal/check_array.js.map +1 -1
- package/lib/programmers/internal/check_array_length.js +8 -9
- package/lib/programmers/internal/check_array_length.js.map +1 -1
- package/lib/programmers/internal/check_bigint.js +71 -70
- package/lib/programmers/internal/check_bigint.js.map +1 -1
- package/lib/programmers/internal/check_custom.js +20 -19
- package/lib/programmers/internal/check_custom.js.map +1 -1
- package/lib/programmers/internal/check_dynamic_properties.js +82 -69
- package/lib/programmers/internal/check_dynamic_properties.js.map +1 -1
- package/lib/programmers/internal/check_everything.js +9 -10
- package/lib/programmers/internal/check_everything.js.map +1 -1
- package/lib/programmers/internal/check_native.js +7 -8
- package/lib/programmers/internal/check_native.js.map +1 -1
- package/lib/programmers/internal/check_number.js +27 -22
- package/lib/programmers/internal/check_number.js.map +1 -1
- package/lib/programmers/internal/check_object.js +32 -19
- package/lib/programmers/internal/check_object.js.map +1 -1
- package/lib/programmers/internal/check_string.js +12 -11
- package/lib/programmers/internal/check_string.js.map +1 -1
- package/lib/programmers/internal/check_string_tags.js +51 -50
- package/lib/programmers/internal/check_string_tags.js.map +1 -1
- package/lib/programmers/internal/check_template.js +27 -23
- package/lib/programmers/internal/check_template.js.map +1 -1
- package/lib/programmers/internal/check_union_array_like.js +61 -45
- package/lib/programmers/internal/check_union_array_like.js.map +1 -1
- package/lib/programmers/internal/check_union_tuple.js +4 -0
- package/lib/programmers/internal/check_union_tuple.js.map +1 -1
- package/lib/programmers/internal/decode_union_object.js +24 -21
- package/lib/programmers/internal/decode_union_object.js.map +1 -1
- package/lib/programmers/internal/feature_object_entries.js +33 -32
- package/lib/programmers/internal/feature_object_entries.js.map +1 -1
- package/lib/programmers/internal/get_comment_tags.js +3 -0
- package/lib/programmers/internal/get_comment_tags.js.map +1 -1
- package/lib/programmers/internal/metadata_to_pattern.js +3 -0
- package/lib/programmers/internal/metadata_to_pattern.js.map +1 -1
- package/lib/programmers/internal/prune_object_properties.js +15 -14
- package/lib/programmers/internal/prune_object_properties.js.map +1 -1
- package/lib/programmers/internal/random_custom.js +10 -9
- package/lib/programmers/internal/random_custom.js.map +1 -1
- package/lib/programmers/internal/stringify_dynamic_properties.js +65 -54
- package/lib/programmers/internal/stringify_dynamic_properties.js.map +1 -1
- package/lib/programmers/internal/stringify_native.js +5 -6
- package/lib/programmers/internal/stringify_native.js.map +1 -1
- package/lib/programmers/internal/stringify_regular_properties.js +46 -41
- package/lib/programmers/internal/stringify_regular_properties.js.map +1 -1
- package/lib/programmers/internal/template_to_pattern.js +3 -0
- package/lib/programmers/internal/template_to_pattern.js.map +1 -1
- package/lib/schemas/IJsonApplication.d.ts +3 -0
- package/lib/schemas/IJsonComponents.d.ts +7 -1
- package/lib/schemas/IJsonSchema.d.ts +5 -2
- package/lib/transform.d.ts +3 -4
- package/lib/transform.js +19 -15
- package/lib/transform.js.map +1 -1
- package/lib/transformers/CallExpressionTransformer.d.ts +1 -1
- package/lib/transformers/CallExpressionTransformer.js +36 -10
- package/lib/transformers/CallExpressionTransformer.js.map +1 -1
- package/lib/transformers/FileTransformer.d.ts +1 -1
- package/lib/transformers/FileTransformer.js +6 -9
- package/lib/transformers/FileTransformer.js.map +1 -1
- package/lib/transformers/IProject.d.ts +8 -1
- package/lib/transformers/ImportTransformer.d.ts +2 -2
- package/lib/transformers/ImportTransformer.js +47 -35
- package/lib/transformers/ImportTransformer.js.map +1 -1
- package/lib/transformers/NodeTransformer.d.ts +1 -1
- package/lib/transformers/NodeTransformer.js +2 -6
- package/lib/transformers/NodeTransformer.js.map +1 -1
- package/lib/transformers/features/miscellaneous/ApplicationTransformer.d.ts +2 -2
- package/lib/transformers/features/miscellaneous/ApplicationTransformer.js +31 -25
- package/lib/transformers/features/miscellaneous/ApplicationTransformer.js.map +1 -1
- package/lib/transformers/features/miscellaneous/AssertCloneTransformer.d.ts +1 -1
- package/lib/transformers/features/miscellaneous/AssertCloneTransformer.js +1 -1
- package/lib/transformers/features/miscellaneous/AssertCloneTransformer.js.map +1 -1
- package/lib/transformers/features/miscellaneous/AssertPruneTransformer.d.ts +1 -1
- package/lib/transformers/features/miscellaneous/AssertPruneTransformer.js +1 -1
- package/lib/transformers/features/miscellaneous/AssertPruneTransformer.js.map +1 -1
- package/lib/transformers/features/miscellaneous/CloneTransformer.d.ts +1 -1
- package/lib/transformers/features/miscellaneous/CloneTransformer.js +1 -1
- package/lib/transformers/features/miscellaneous/CloneTransformer.js.map +1 -1
- package/lib/transformers/features/miscellaneous/CreateAssertCloneTransformer.d.ts +1 -1
- package/lib/transformers/features/miscellaneous/CreateAssertCloneTransformer.js +1 -1
- package/lib/transformers/features/miscellaneous/CreateAssertCloneTransformer.js.map +1 -1
- package/lib/transformers/features/miscellaneous/CreateAssertPruneTransformer.d.ts +1 -1
- package/lib/transformers/features/miscellaneous/CreateAssertPruneTransformer.js +1 -1
- package/lib/transformers/features/miscellaneous/CreateAssertPruneTransformer.js.map +1 -1
- package/lib/transformers/features/miscellaneous/CreateCloneTransformer.d.ts +1 -1
- package/lib/transformers/features/miscellaneous/CreateCloneTransformer.js +1 -1
- package/lib/transformers/features/miscellaneous/CreateCloneTransformer.js.map +1 -1
- package/lib/transformers/features/miscellaneous/CreateIsCloneTransformer.d.ts +1 -1
- package/lib/transformers/features/miscellaneous/CreateIsCloneTransformer.js +1 -1
- package/lib/transformers/features/miscellaneous/CreateIsCloneTransformer.js.map +1 -1
- package/lib/transformers/features/miscellaneous/CreateIsPruneTransformer.d.ts +1 -1
- package/lib/transformers/features/miscellaneous/CreateIsPruneTransformer.js +1 -1
- package/lib/transformers/features/miscellaneous/CreateIsPruneTransformer.js.map +1 -1
- package/lib/transformers/features/miscellaneous/CreatePruneTransformer.d.ts +1 -1
- package/lib/transformers/features/miscellaneous/CreatePruneTransformer.js +1 -1
- package/lib/transformers/features/miscellaneous/CreatePruneTransformer.js.map +1 -1
- package/lib/transformers/features/miscellaneous/CreateRandomTransformer.d.ts +2 -2
- package/lib/transformers/features/miscellaneous/CreateRandomTransformer.js +10 -5
- package/lib/transformers/features/miscellaneous/CreateRandomTransformer.js.map +1 -1
- package/lib/transformers/features/miscellaneous/CreateValidateCloneTransformer.d.ts +1 -1
- package/lib/transformers/features/miscellaneous/CreateValidateCloneTransformer.js +1 -1
- package/lib/transformers/features/miscellaneous/CreateValidateCloneTransformer.js.map +1 -1
- package/lib/transformers/features/miscellaneous/CreateValidatePruneTransformer.d.ts +1 -1
- package/lib/transformers/features/miscellaneous/CreateValidatePruneTransformer.js +1 -1
- package/lib/transformers/features/miscellaneous/CreateValidatePruneTransformer.js.map +1 -1
- package/lib/transformers/features/miscellaneous/IsCloneTransformer.d.ts +1 -1
- package/lib/transformers/features/miscellaneous/IsCloneTransformer.js +1 -1
- package/lib/transformers/features/miscellaneous/IsCloneTransformer.js.map +1 -1
- package/lib/transformers/features/miscellaneous/IsPruneTransformer.d.ts +1 -1
- package/lib/transformers/features/miscellaneous/IsPruneTransformer.js +1 -1
- package/lib/transformers/features/miscellaneous/IsPruneTransformer.js.map +1 -1
- package/lib/transformers/features/miscellaneous/LiteralsTransformer.d.ts +2 -2
- package/lib/transformers/features/miscellaneous/LiteralsTransformer.js +9 -5
- package/lib/transformers/features/miscellaneous/LiteralsTransformer.js.map +1 -1
- package/lib/transformers/features/miscellaneous/MetadataTransformer.d.ts +2 -2
- package/lib/transformers/features/miscellaneous/MetadataTransformer.js +15 -15
- package/lib/transformers/features/miscellaneous/MetadataTransformer.js.map +1 -1
- package/lib/transformers/features/miscellaneous/PruneTransformer.d.ts +1 -1
- package/lib/transformers/features/miscellaneous/PruneTransformer.js +1 -1
- package/lib/transformers/features/miscellaneous/PruneTransformer.js.map +1 -1
- package/lib/transformers/features/miscellaneous/RandomTransformer.d.ts +2 -2
- package/lib/transformers/features/miscellaneous/RandomTransformer.js +10 -9
- package/lib/transformers/features/miscellaneous/RandomTransformer.js.map +1 -1
- package/lib/transformers/features/miscellaneous/ValidateCloneTransformer.d.ts +1 -1
- package/lib/transformers/features/miscellaneous/ValidateCloneTransformer.js +1 -1
- package/lib/transformers/features/miscellaneous/ValidateCloneTransformer.js.map +1 -1
- package/lib/transformers/features/miscellaneous/ValidatePruneTransformer.d.ts +1 -1
- package/lib/transformers/features/miscellaneous/ValidatePruneTransformer.js +1 -1
- package/lib/transformers/features/miscellaneous/ValidatePruneTransformer.js.map +1 -1
- package/lib/transformers/features/parsers/AssertParseTransformer.d.ts +1 -1
- package/lib/transformers/features/parsers/AssertParseTransformer.js +1 -1
- package/lib/transformers/features/parsers/AssertParseTransformer.js.map +1 -1
- package/lib/transformers/features/parsers/CreateAssertParseTransformer.d.ts +1 -1
- package/lib/transformers/features/parsers/CreateAssertParseTransformer.js +1 -1
- package/lib/transformers/features/parsers/CreateAssertParseTransformer.js.map +1 -1
- package/lib/transformers/features/parsers/CreateIsParseTransformer.d.ts +1 -1
- package/lib/transformers/features/parsers/CreateIsParseTransformer.js +1 -1
- package/lib/transformers/features/parsers/CreateIsParseTransformer.js.map +1 -1
- package/lib/transformers/features/parsers/CreateValidateParseTransformer.d.ts +1 -1
- package/lib/transformers/features/parsers/CreateValidateParseTransformer.js +1 -1
- package/lib/transformers/features/parsers/CreateValidateParseTransformer.js.map +1 -1
- package/lib/transformers/features/parsers/IsParseTransformer.d.ts +1 -1
- package/lib/transformers/features/parsers/IsParseTransformer.js +1 -1
- package/lib/transformers/features/parsers/IsParseTransformer.js.map +1 -1
- package/lib/transformers/features/parsers/ValidateParseTransformer.d.ts +1 -1
- package/lib/transformers/features/parsers/ValidateParseTransformer.js +1 -1
- package/lib/transformers/features/parsers/ValidateParseTransformer.js.map +1 -1
- package/lib/transformers/features/stringifiers/AssertStringifyTransformer.d.ts +1 -1
- package/lib/transformers/features/stringifiers/AssertStringifyTransformer.js +1 -1
- package/lib/transformers/features/stringifiers/AssertStringifyTransformer.js.map +1 -1
- package/lib/transformers/features/stringifiers/CreateAssertStringifyTransformer.d.ts +1 -1
- package/lib/transformers/features/stringifiers/CreateAssertStringifyTransformer.js +1 -1
- package/lib/transformers/features/stringifiers/CreateAssertStringifyTransformer.js.map +1 -1
- package/lib/transformers/features/stringifiers/CreateIsStringifyTransformer.d.ts +1 -1
- package/lib/transformers/features/stringifiers/CreateIsStringifyTransformer.js +1 -1
- package/lib/transformers/features/stringifiers/CreateIsStringifyTransformer.js.map +1 -1
- package/lib/transformers/features/stringifiers/CreateStringifyTransformer.d.ts +1 -1
- package/lib/transformers/features/stringifiers/CreateStringifyTransformer.js +1 -1
- package/lib/transformers/features/stringifiers/CreateStringifyTransformer.js.map +1 -1
- package/lib/transformers/features/stringifiers/CreateValidateStringifyProgrammer.d.ts +1 -1
- package/lib/transformers/features/stringifiers/CreateValidateStringifyProgrammer.js +1 -1
- package/lib/transformers/features/stringifiers/CreateValidateStringifyProgrammer.js.map +1 -1
- package/lib/transformers/features/stringifiers/IsStringifyTransformer.d.ts +1 -1
- package/lib/transformers/features/stringifiers/IsStringifyTransformer.js +1 -1
- package/lib/transformers/features/stringifiers/IsStringifyTransformer.js.map +1 -1
- package/lib/transformers/features/stringifiers/StringifyTransformer.d.ts +1 -1
- package/lib/transformers/features/stringifiers/StringifyTransformer.js +1 -1
- package/lib/transformers/features/stringifiers/StringifyTransformer.js.map +1 -1
- package/lib/transformers/features/stringifiers/ValidateStringifyTransformer.d.ts +1 -1
- package/lib/transformers/features/stringifiers/ValidateStringifyTransformer.js +1 -1
- package/lib/transformers/features/stringifiers/ValidateStringifyTransformer.js.map +1 -1
- package/lib/transformers/features/validators/AssertTransformer.d.ts +1 -1
- package/lib/transformers/features/validators/AssertTransformer.js +1 -1
- package/lib/transformers/features/validators/AssertTransformer.js.map +1 -1
- package/lib/transformers/features/validators/CreateAssertTransformer.d.ts +1 -1
- package/lib/transformers/features/validators/CreateAssertTransformer.js +1 -1
- package/lib/transformers/features/validators/CreateAssertTransformer.js.map +1 -1
- package/lib/transformers/features/validators/CreateIsTransformer.d.ts +1 -1
- package/lib/transformers/features/validators/CreateIsTransformer.js +1 -1
- package/lib/transformers/features/validators/CreateIsTransformer.js.map +1 -1
- package/lib/transformers/features/validators/CreateValidateTransformer.d.ts +1 -1
- package/lib/transformers/features/validators/CreateValidateTransformer.js +1 -1
- package/lib/transformers/features/validators/CreateValidateTransformer.js.map +1 -1
- package/lib/transformers/features/validators/IsTransformer.d.ts +1 -1
- package/lib/transformers/features/validators/IsTransformer.js +1 -1
- package/lib/transformers/features/validators/IsTransformer.js.map +1 -1
- package/lib/transformers/features/validators/ValidateTransformer.d.ts +1 -1
- package/lib/transformers/features/validators/ValidateTransformer.js +1 -1
- package/lib/transformers/features/validators/ValidateTransformer.js.map +1 -1
- package/lib/transformers/internal/GenericTransformer.d.ts +3 -3
- package/lib/transformers/internal/GenericTransformer.js +22 -18
- package/lib/transformers/internal/GenericTransformer.js.map +1 -1
- package/lib/utils/ArrayUtil.js +1 -1
- package/lib/utils/ArrayUtil.js.map +1 -1
- package/lib/utils/Escaper.js +1 -1
- package/lib/utils/Escaper.js.map +1 -1
- package/lib/utils/MapUtil.js +1 -1
- package/lib/utils/MapUtil.js.map +1 -1
- package/lib/utils/PatternUtil.js +1 -1
- package/lib/utils/PatternUtil.js.map +1 -1
- package/lib/utils/RandomGenerator.js +10 -1
- package/lib/utils/RandomGenerator.js.map +1 -1
- package/lib/utils/Singleton.js +1 -1
- package/lib/utils/TsNodeUtil.d.ts +5 -0
- package/lib/utils/TsNodeUtil.js +17 -0
- package/lib/utils/TsNodeUtil.js.map +1 -0
- package/lib/utils/TsSymbolUtil.d.ts +6 -0
- package/lib/utils/TsSymbolUtil.js +147 -0
- package/lib/utils/TsSymbolUtil.js.map +1 -0
- package/lib/utils/TsTypeUtil.d.ts +9 -0
- package/lib/utils/TsTypeUtil.js +40 -0
- package/lib/utils/TsTypeUtil.js.map +1 -0
- package/package.json +7 -10
- package/src/factories/CommentFactory.ts +2 -2
- package/src/factories/ExpressionFactory.ts +34 -27
- package/src/factories/IdentifierFactory.ts +41 -42
- package/src/factories/LiteralFactory.ts +47 -29
- package/src/factories/MetadataCollection.ts +15 -13
- package/src/factories/MetadataFactory.ts +6 -15
- package/src/factories/MetadataTagFactory.ts +9 -11
- package/src/factories/StatementFactory.ts +17 -21
- package/src/factories/TemplateFactory.ts +39 -33
- package/src/factories/TypeFactory.ts +80 -59
- package/src/factories/ValueFactory.ts +12 -9
- package/src/factories/internal/metadata/emplace_metadata_object.ts +55 -46
- package/src/factories/internal/metadata/explore_metadata.ts +8 -7
- package/src/factories/internal/metadata/iterate_metadata.ts +25 -29
- package/src/factories/internal/metadata/iterate_metadata_array.ts +12 -9
- package/src/factories/internal/metadata/iterate_metadata_atomic.ts +27 -27
- package/src/factories/internal/metadata/iterate_metadata_coalesce.ts +26 -26
- package/src/factories/internal/metadata/iterate_metadata_constant.ts +10 -6
- package/src/factories/internal/metadata/iterate_metadata_map.ts +11 -11
- package/src/factories/internal/metadata/iterate_metadata_native.ts +14 -16
- package/src/factories/internal/metadata/iterate_metadata_object.ts +17 -14
- package/src/factories/internal/metadata/iterate_metadata_resolve.ts +10 -7
- package/src/factories/internal/metadata/iterate_metadata_set.ts +10 -7
- package/src/factories/internal/metadata/iterate_metadata_template.ts +10 -8
- package/src/factories/internal/metadata/iterate_metadata_tuple.ts +12 -9
- package/src/factories/internal/metadata/iterate_metadata_union.ts +16 -14
- package/src/metadata/IMetadataTag.ts +3 -11
- package/src/metadata/Metadata.ts +1 -5
- package/src/module.ts +1 -17
- package/src/programmers/ApplicationProgrammer.ts +2 -16
- package/src/programmers/AssertCloneProgrammer.ts +23 -34
- package/src/programmers/AssertParseProgrammer.ts +24 -32
- package/src/programmers/AssertProgrammer.ts +98 -109
- package/src/programmers/AssertPruneProgrammer.ts +23 -26
- package/src/programmers/AssertStringifyProgrammer.ts +19 -27
- package/src/programmers/CheckerProgrammer.ts +203 -207
- package/src/programmers/CloneProgrammer.ts +130 -132
- package/src/programmers/FeatureProgrammer.ts +65 -55
- package/src/programmers/IsCloneProgrammer.ts +31 -38
- package/src/programmers/IsParseProgrammer.ts +27 -35
- package/src/programmers/IsProgrammer.ts +64 -53
- package/src/programmers/IsPruneProgrammer.ts +29 -27
- package/src/programmers/IsStringifyProgrammer.ts +27 -34
- package/src/programmers/LiteralsProgrammer.ts +11 -11
- package/src/programmers/PruneProgrammer.ts +80 -79
- package/src/programmers/RandomProgrammer.ts +149 -128
- package/src/programmers/StringifyProgrammer.ts +249 -289
- package/src/programmers/TypiaProgrammer.ts +24 -12
- package/src/programmers/ValidateCloneProgrammer.ts +31 -31
- package/src/programmers/ValidateParseProgrammer.ts +26 -26
- package/src/programmers/ValidateProgrammer.ts +125 -124
- package/src/programmers/ValidatePruneProgrammer.ts +26 -26
- package/src/programmers/ValidateStringifyProgrammer.ts +33 -32
- package/src/programmers/helpers/CloneJoiner.ts +113 -106
- package/src/programmers/helpers/FunctionImporeter.ts +9 -7
- package/src/programmers/helpers/ICheckEntry.ts +1 -1
- package/src/programmers/helpers/IExpressionEntry.ts +1 -1
- package/src/programmers/helpers/PruneJoiner.ts +85 -73
- package/src/programmers/helpers/RandomJoiner.ts +35 -31
- package/src/programmers/helpers/RandomRanger.ts +10 -8
- package/src/programmers/helpers/StringifyJoinder.ts +58 -53
- package/src/programmers/helpers/UnionExplorer.ts +60 -54
- package/src/programmers/helpers/disable_function_importer_declare.ts +21 -0
- package/src/programmers/internal/JSON_SCHEMA_PREFIX.ts +1 -0
- package/src/programmers/internal/application_array.ts +4 -8
- package/src/programmers/internal/application_boolean.ts +6 -8
- package/src/programmers/internal/application_constant.ts +3 -7
- package/src/programmers/internal/application_default.ts +1 -1
- package/src/programmers/internal/application_native.ts +16 -12
- package/src/programmers/internal/application_number.ts +7 -9
- package/src/programmers/internal/application_object.ts +13 -6
- package/src/programmers/internal/application_schema.ts +36 -51
- package/src/programmers/internal/application_string.ts +28 -29
- package/src/programmers/internal/application_templates.ts +0 -1
- package/src/programmers/internal/application_tuple.ts +3 -7
- package/src/programmers/internal/check_array.ts +6 -5
- package/src/programmers/internal/check_array_length.ts +8 -8
- package/src/programmers/internal/check_bigint.ts +31 -18
- package/src/programmers/internal/check_custom.ts +6 -5
- package/src/programmers/internal/check_dynamic_properties.ts +50 -46
- package/src/programmers/internal/check_everything.ts +8 -8
- package/src/programmers/internal/check_native.ts +14 -13
- package/src/programmers/internal/check_number.ts +37 -37
- package/src/programmers/internal/check_object.ts +20 -10
- package/src/programmers/internal/check_string.ts +9 -7
- package/src/programmers/internal/check_string_tags.ts +14 -13
- package/src/programmers/internal/check_template.ts +11 -10
- package/src/programmers/internal/check_union_array_like.ts +66 -64
- package/src/programmers/internal/check_union_tuple.ts +3 -2
- package/src/programmers/internal/decode_union_object.ts +9 -7
- package/src/programmers/internal/feature_object_entries.ts +7 -6
- package/src/programmers/internal/prune_object_properties.ts +45 -42
- package/src/programmers/internal/random_custom.ts +9 -8
- package/src/programmers/internal/stringify_dynamic_properties.ts +147 -141
- package/src/programmers/internal/stringify_native.ts +3 -3
- package/src/programmers/internal/stringify_regular_properties.ts +69 -63
- package/src/schemas/IJsonApplication.ts +4 -0
- package/src/schemas/IJsonComponents.ts +8 -1
- package/src/schemas/IJsonSchema.ts +6 -2
- package/src/transform.ts +17 -14
- package/src/transformers/CallExpressionTransformer.ts +21 -22
- package/src/transformers/FileTransformer.ts +10 -7
- package/src/transformers/IProject.ts +8 -1
- package/src/transformers/ImportTransformer.ts +18 -10
- package/src/transformers/NodeTransformer.ts +2 -2
- package/src/transformers/features/miscellaneous/ApplicationTransformer.ts +21 -26
- package/src/transformers/features/miscellaneous/CreateRandomTransformer.ts +11 -7
- package/src/transformers/features/miscellaneous/LiteralsTransformer.ts +8 -5
- package/src/transformers/features/miscellaneous/MetadataTransformer.ts +14 -10
- package/src/transformers/features/miscellaneous/RandomTransformer.ts +12 -8
- package/src/transformers/internal/GenericTransformer.ts +22 -18
- package/src/utils/TsNodeUtil.ts +17 -0
- package/src/utils/TsSymbolUtil.ts +146 -0
- package/src/utils/TsTypeUtil.ts +38 -0
- package/lib/factories/ProtocolFactory.d.ts +0 -8
- package/lib/factories/ProtocolFactory.js +0 -112
- package/lib/factories/ProtocolFactory.js.map +0 -1
- package/lib/factories/internal/protocols/ProtocolMetadataUtil.d.ts +0 -16
- package/lib/factories/internal/protocols/ProtocolMetadataUtil.js +0 -160
- package/lib/factories/internal/protocols/ProtocolMetadataUtil.js.map +0 -1
- package/lib/factories/internal/protocols/emplace_protocol_object.d.ts +0 -3
- package/lib/factories/internal/protocols/emplace_protocol_object.js +0 -47
- package/lib/factories/internal/protocols/emplace_protocol_object.js.map +0 -1
- package/lib/factories/internal/protocols/emplace_protocol_property.d.ts +0 -4
- package/lib/factories/internal/protocols/emplace_protocol_property.js +0 -20
- package/lib/factories/internal/protocols/emplace_protocol_property.js.map +0 -1
- package/lib/factories/internal/protocols/iterate_protocol_atomic.d.ts +0 -3
- package/lib/factories/internal/protocols/iterate_protocol_atomic.js +0 -69
- package/lib/factories/internal/protocols/iterate_protocol_atomic.js.map +0 -1
- package/lib/factories/internal/protocols/iterate_protocol_constant.d.ts +0 -2
- package/lib/factories/internal/protocols/iterate_protocol_constant.js +0 -30
- package/lib/factories/internal/protocols/iterate_protocol_constant.js.map +0 -1
- package/lib/factories/internal/protocols/iterate_protocol_main.d.ts +0 -3
- package/lib/factories/internal/protocols/iterate_protocol_main.js +0 -17
- package/lib/factories/internal/protocols/iterate_protocol_main.js.map +0 -1
- package/lib/factories/internal/protocols/iterate_protocol_map.d.ts +0 -4
- package/lib/factories/internal/protocols/iterate_protocol_map.js +0 -75
- package/lib/factories/internal/protocols/iterate_protocol_map.js.map +0 -1
- package/lib/factories/internal/protocols/iterate_protocol_metadata.d.ts +0 -5
- package/lib/factories/internal/protocols/iterate_protocol_metadata.js +0 -190
- package/lib/factories/internal/protocols/iterate_protocol_metadata.js.map +0 -1
- package/lib/factories/internal/protocols/iterate_protocol_native.d.ts +0 -2
- package/lib/factories/internal/protocols/iterate_protocol_native.js +0 -33
- package/lib/factories/internal/protocols/iterate_protocol_native.js.map +0 -1
- package/lib/factories/internal/protocols/iterate_protocol_never.d.ts +0 -1
- package/lib/factories/internal/protocols/iterate_protocol_never.js +0 -6
- package/lib/factories/internal/protocols/iterate_protocol_never.js.map +0 -1
- package/lib/factories/internal/protocols/iterate_protocol_object.d.ts +0 -4
- package/lib/factories/internal/protocols/iterate_protocol_object.js +0 -157
- package/lib/factories/internal/protocols/iterate_protocol_object.js.map +0 -1
- package/lib/factories/internal/protocols/iterate_protocol_repeated.d.ts +0 -5
- package/lib/factories/internal/protocols/iterate_protocol_repeated.js +0 -25
- package/lib/factories/internal/protocols/iterate_protocol_repeated.js.map +0 -1
- package/lib/factories/internal/protocols/iterate_protocol_tuple.d.ts +0 -3
- package/lib/factories/internal/protocols/iterate_protocol_tuple.js +0 -46
- package/lib/factories/internal/protocols/iterate_protocol_tuple.js.map +0 -1
- package/lib/functional/$proto_bytes.d.ts +0 -2
- package/lib/functional/$proto_bytes.js +0 -37
- package/lib/functional/$proto_bytes.js.map +0 -1
- package/lib/functional/$proto_field.d.ts +0 -10
- package/lib/functional/$proto_field.js +0 -42
- package/lib/functional/$proto_field.js.map +0 -1
- package/lib/functional/$proto_float.d.ts +0 -4
- package/lib/functional/$proto_float.js +0 -28
- package/lib/functional/$proto_float.js.map +0 -1
- package/lib/functional/$proto_i32.d.ts +0 -2
- package/lib/functional/$proto_i32.js +0 -23
- package/lib/functional/$proto_i32.js.map +0 -1
- package/lib/functional/$proto_i64.d.ts +0 -2
- package/lib/functional/$proto_i64.js +0 -31
- package/lib/functional/$proto_i64.js.map +0 -1
- package/lib/functional/$proto_size.d.ts +0 -6
- package/lib/functional/$proto_size.js +0 -76
- package/lib/functional/$proto_size.js.map +0 -1
- package/lib/functional/$proto_string.d.ts +0 -2
- package/lib/functional/$proto_string.js +0 -34
- package/lib/functional/$proto_string.js.map +0 -1
- package/lib/functional/$varint.d.ts +0 -6
- package/lib/functional/$varint.js +0 -99
- package/lib/functional/$varint.js.map +0 -1
- package/lib/functional/$zigzag.d.ts +0 -4
- package/lib/functional/$zigzag.js +0 -34
- package/lib/functional/$zigzag.js.map +0 -1
- package/lib/messages/IProtocolMap.d.ts +0 -5
- package/lib/messages/IProtocolMap.js +0 -3
- package/lib/messages/IProtocolMap.js.map +0 -1
- package/lib/messages/IProtocolMessage.d.ts +0 -5
- package/lib/messages/IProtocolMessage.js +0 -3
- package/lib/messages/IProtocolMessage.js.map +0 -1
- package/lib/messages/IProtocolProperty.d.ts +0 -12
- package/lib/messages/IProtocolProperty.js +0 -3
- package/lib/messages/IProtocolProperty.js.map +0 -1
- package/lib/programmers/MessageProgrammer.d.ts +0 -5
- package/lib/programmers/MessageProgrammer.js +0 -141
- package/lib/programmers/MessageProgrammer.js.map +0 -1
- package/lib/transformers/features/protocols/MessageTransformer.d.ts +0 -5
- package/lib/transformers/features/protocols/MessageTransformer.js +0 -20
- package/lib/transformers/features/protocols/MessageTransformer.js.map +0 -1
- package/lib/utils/NameEncoder.d.ts +0 -4
- package/lib/utils/NameEncoder.js +0 -89
- package/lib/utils/NameEncoder.js.map +0 -1
- package/src/factories/ProtocolFactory.ts +0 -79
- package/src/factories/internal/protocols/ProtocolMetadataUtil.ts +0 -167
- package/src/factories/internal/protocols/emplace_protocol_object.ts +0 -25
- package/src/factories/internal/protocols/emplace_protocol_property.ts +0 -12
- package/src/factories/internal/protocols/iterate_protocol_atomic.ts +0 -34
- package/src/factories/internal/protocols/iterate_protocol_constant.ts +0 -27
- package/src/factories/internal/protocols/iterate_protocol_main.ts +0 -19
- package/src/factories/internal/protocols/iterate_protocol_map.ts +0 -58
- package/src/factories/internal/protocols/iterate_protocol_metadata.ts +0 -96
- package/src/factories/internal/protocols/iterate_protocol_native.ts +0 -34
- package/src/factories/internal/protocols/iterate_protocol_never.ts +0 -1
- package/src/factories/internal/protocols/iterate_protocol_object.ts +0 -110
- package/src/factories/internal/protocols/iterate_protocol_repeated.ts +0 -34
- package/src/factories/internal/protocols/iterate_protocol_tuple.ts +0 -29
- package/src/functional/$proto_bytes.ts +0 -25
- package/src/functional/$proto_field.ts +0 -30
- package/src/functional/$proto_float.ts +0 -37
- package/src/functional/$proto_i32.ts +0 -29
- package/src/functional/$proto_i64.ts +0 -37
- package/src/functional/$proto_size.ts +0 -82
- package/src/functional/$proto_string.ts +0 -24
- package/src/functional/$varint.ts +0 -130
- package/src/functional/$zigzag.ts +0 -39
- package/src/messages/IProtocolMap.ts +0 -5
- package/src/messages/IProtocolMessage.ts +0 -6
- package/src/messages/IProtocolProperty.ts +0 -13
- package/src/programmers/MessageProgrammer.ts +0 -126
- package/src/transformers/features/protocols/MessageTransformer.ts +0 -31
- package/src/utils/NameEncoder.ts +0 -32
|
@@ -46,12 +46,8 @@ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
|
|
|
46
46
|
}
|
|
47
47
|
return to.concat(ar || Array.prototype.slice.call(from));
|
|
48
48
|
};
|
|
49
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
50
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
51
|
-
};
|
|
52
49
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
53
50
|
exports.CheckerProgrammer = void 0;
|
|
54
|
-
var typescript_1 = __importDefault(require("typescript"));
|
|
55
51
|
var ExpressionFactory_1 = require("../factories/ExpressionFactory");
|
|
56
52
|
var IdentifierFactory_1 = require("../factories/IdentifierFactory");
|
|
57
53
|
var MetadataCollection_1 = require("../factories/MetadataCollection");
|
|
@@ -74,6 +70,9 @@ var check_union_tuple_1 = require("./internal/check_union_tuple");
|
|
|
74
70
|
var decode_union_object_1 = require("./internal/decode_union_object");
|
|
75
71
|
var CheckerProgrammer;
|
|
76
72
|
(function (CheckerProgrammer) {
|
|
73
|
+
/* -----------------------------------------------------------
|
|
74
|
+
WRITERS
|
|
75
|
+
----------------------------------------------------------- */
|
|
77
76
|
CheckerProgrammer.write = function (project) {
|
|
78
77
|
return function (config) {
|
|
79
78
|
return function (importer) {
|
|
@@ -81,78 +80,77 @@ var CheckerProgrammer;
|
|
|
81
80
|
};
|
|
82
81
|
};
|
|
83
82
|
};
|
|
84
|
-
CheckerProgrammer.write_functors = function (
|
|
85
|
-
return
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
};
|
|
90
|
-
};
|
|
91
|
-
CheckerProgrammer.write_unioners = function (project, config, importer) {
|
|
92
|
-
return FeatureProgrammer_1.FeatureProgrammer.write_unioners(configure(project)(__assign(__assign({}, config), { numeric: false }))(importer))(importer);
|
|
83
|
+
CheckerProgrammer.write_functors = function (p) { return function (config) { return function (importer) {
|
|
84
|
+
return FeatureProgrammer_1.FeatureProgrammer.write_functors(p.tsc)(configure(p)(config)(importer))(importer);
|
|
85
|
+
}; }; };
|
|
86
|
+
CheckerProgrammer.write_unioners = function (p, config, importer) {
|
|
87
|
+
return FeatureProgrammer_1.FeatureProgrammer.write_unioners(p.tsc)(configure(p)(__assign(__assign({}, config), { numeric: false }))(importer))(importer);
|
|
93
88
|
};
|
|
94
|
-
var configure = function (
|
|
89
|
+
var configure = function (p) {
|
|
95
90
|
return function (config) {
|
|
96
91
|
return function (importer) {
|
|
97
92
|
var _a, _b, _c;
|
|
98
93
|
var output = {
|
|
99
94
|
types: {
|
|
100
|
-
input: function () { return TypeFactory_1.TypeFactory.keyword("any"); },
|
|
95
|
+
input: function () { return TypeFactory_1.TypeFactory.keyword(p.tsc)("any"); },
|
|
101
96
|
output: function (type, name) {
|
|
102
|
-
return
|
|
97
|
+
return p.tsc.factory.createTypePredicateNode(undefined, "input", p.tsc.factory.createTypeReferenceNode(name !== null && name !== void 0 ? name : TypeFactory_1.TypeFactory.getFullName(p)(type)));
|
|
103
98
|
},
|
|
104
99
|
},
|
|
105
100
|
trace: config.trace,
|
|
106
101
|
path: config.path,
|
|
107
102
|
functors: config.functors,
|
|
108
103
|
unioners: config.unioners,
|
|
109
|
-
initializer: function (
|
|
110
|
-
var
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
return [collection, meta];
|
|
118
|
-
};
|
|
119
|
-
},
|
|
104
|
+
initializer: function (p) { return function (type) {
|
|
105
|
+
var collection = new MetadataCollection_1.MetadataCollection();
|
|
106
|
+
var meta = MetadataFactory_1.MetadataFactory.analyze(p)({
|
|
107
|
+
resolve: false,
|
|
108
|
+
constant: true,
|
|
109
|
+
})(collection)(type);
|
|
110
|
+
return [collection, meta];
|
|
111
|
+
}; },
|
|
120
112
|
addition: config.addition,
|
|
121
|
-
decoder: (_a = config.decoder) !== null && _a !== void 0 ? _a : CheckerProgrammer.decode(
|
|
113
|
+
decoder: (_a = config.decoder) !== null && _a !== void 0 ? _a : CheckerProgrammer.decode(p)(config)(importer),
|
|
122
114
|
objector: {
|
|
123
|
-
checker: (_b = config.decoder) !== null && _b !== void 0 ? _b : CheckerProgrammer.decode(
|
|
124
|
-
decoder: CheckerProgrammer.decode_object(config)(importer),
|
|
115
|
+
checker: (_b = config.decoder) !== null && _b !== void 0 ? _b : CheckerProgrammer.decode(p)(config)(importer),
|
|
116
|
+
decoder: CheckerProgrammer.decode_object(p.tsc)(config)(importer),
|
|
125
117
|
joiner: config.joiner.object,
|
|
126
118
|
unionizer: config.equals
|
|
127
|
-
? (0, decode_union_object_1.decode_union_object)(CheckerProgrammer.decode_object(config)(importer))(function (input, obj, explore) {
|
|
128
|
-
return CheckerProgrammer.decode_object(config)(importer)(input, obj, __assign(__assign({}, explore), { tracable: true }));
|
|
119
|
+
? (0, decode_union_object_1.decode_union_object)(p.tsc)(CheckerProgrammer.decode_object(p.tsc)(config)(importer))(function (input, obj, explore) {
|
|
120
|
+
return CheckerProgrammer.decode_object(p.tsc)(config)(importer)(input, obj, __assign(__assign({}, explore), { tracable: true }));
|
|
129
121
|
})((_c = config.joiner.is) !== null && _c !== void 0 ? _c : (function (expr) { return expr; }))(function (value, expected) {
|
|
130
|
-
return
|
|
122
|
+
return p.tsc.factory.createReturnStatement(config.joiner.failure(value, expected));
|
|
131
123
|
})
|
|
132
124
|
: function (input, targets, explore) {
|
|
133
125
|
return config.combiner(explore)("or")(input, targets.map(function (obj) { return ({
|
|
134
|
-
expression: CheckerProgrammer.decode_object(config)(importer)(input, obj, explore),
|
|
126
|
+
expression: CheckerProgrammer.decode_object(p.tsc)(config)(importer)(input, obj, explore),
|
|
135
127
|
combined: true,
|
|
136
128
|
}); }), "(".concat(targets.map(function (t) { return t.name; }).join(" | "), ")"));
|
|
137
129
|
},
|
|
138
130
|
failure: function (value, expected) {
|
|
139
|
-
return
|
|
131
|
+
return p.tsc.factory.createReturnStatement(config.joiner.failure(value, expected));
|
|
140
132
|
},
|
|
141
133
|
is: config.joiner.is,
|
|
142
134
|
required: config.joiner.required,
|
|
143
135
|
full: config.joiner.full,
|
|
144
|
-
type: TypeFactory_1.TypeFactory.keyword("boolean"),
|
|
136
|
+
type: TypeFactory_1.TypeFactory.keyword(p.tsc)("boolean"),
|
|
145
137
|
},
|
|
146
138
|
};
|
|
147
139
|
if (config.numeric === true)
|
|
148
140
|
output.generator = {
|
|
149
|
-
unioners: FeatureProgrammer_1.FeatureProgrammer.write_unioners(configure(
|
|
141
|
+
unioners: FeatureProgrammer_1.FeatureProgrammer.write_unioners(p.tsc)(configure(p)(__assign(__assign({}, config), { numeric: false }))(importer))(importer),
|
|
150
142
|
};
|
|
151
143
|
return output;
|
|
152
144
|
};
|
|
153
145
|
};
|
|
154
146
|
};
|
|
155
|
-
|
|
147
|
+
/* -----------------------------------------------------------
|
|
148
|
+
DECODERS
|
|
149
|
+
----------------------------------------------------------- */
|
|
150
|
+
/**
|
|
151
|
+
* @internal
|
|
152
|
+
*/
|
|
153
|
+
CheckerProgrammer.decode = function (p) {
|
|
156
154
|
return function (config) {
|
|
157
155
|
return function (importer) {
|
|
158
156
|
return function (input, meta, explore, metaTags, jsDocTags) {
|
|
@@ -161,28 +159,40 @@ var CheckerProgrammer;
|
|
|
161
159
|
return config.success;
|
|
162
160
|
var top = [];
|
|
163
161
|
var binaries = [];
|
|
164
|
-
var add = create_add(binaries)(input);
|
|
162
|
+
var add = create_add(p.tsc)(binaries)(input);
|
|
165
163
|
var getConstantValue = function (value) {
|
|
166
164
|
return typeof value === "string"
|
|
167
|
-
?
|
|
168
|
-
:
|
|
165
|
+
? p.tsc.factory.createStringLiteral(value)
|
|
166
|
+
: p.tsc.factory.createIdentifier(value.toString());
|
|
169
167
|
};
|
|
168
|
+
//----
|
|
169
|
+
// CHECK OPTIONAL
|
|
170
|
+
//----
|
|
171
|
+
// @todo -> should be elaborated
|
|
170
172
|
var checkOptional = meta.empty() || meta.isUnionBucket();
|
|
173
|
+
// NULLABLE
|
|
171
174
|
if (checkOptional ||
|
|
172
|
-
meta.nullable
|
|
173
|
-
|
|
175
|
+
meta.nullable
|
|
176
|
+
// || (meta.objects.length && meta.size() !== meta.objects.length)
|
|
177
|
+
)
|
|
178
|
+
(meta.nullable ? add : create_add(p.tsc)(top)(input))(meta.nullable, ValueFactory_1.ValueFactory.NULL(p.tsc));
|
|
179
|
+
// UNDEFINDABLE
|
|
174
180
|
if (checkOptional || !meta.required)
|
|
175
|
-
(meta.required ? create_add(top)(input) : add)(!meta.required, ValueFactory_1.ValueFactory.UNDEFINED());
|
|
181
|
+
(meta.required ? create_add(p.tsc)(top)(input) : add)(!meta.required, ValueFactory_1.ValueFactory.UNDEFINED(p.tsc));
|
|
182
|
+
// FUNCTIONAL
|
|
176
183
|
if (meta.functional === true)
|
|
177
|
-
if (OptionPredicator_1.OptionPredicator.functional(
|
|
178
|
-
|
|
179
|
-
add(true, typescript_1.default.factory.createStringLiteral("function"), ValueFactory_1.ValueFactory.TYPEOF(input));
|
|
184
|
+
if (OptionPredicator_1.OptionPredicator.functional(p.options) || meta.size() !== 1)
|
|
185
|
+
add(true, p.tsc.factory.createStringLiteral("function"), ValueFactory_1.ValueFactory.TYPEOF(p.tsc)(input));
|
|
180
186
|
else
|
|
181
187
|
binaries.push({
|
|
182
188
|
combined: false,
|
|
183
189
|
expression: config.success,
|
|
184
190
|
});
|
|
185
191
|
try {
|
|
192
|
+
//----
|
|
193
|
+
// VALUES
|
|
194
|
+
//----
|
|
195
|
+
// CONSTANT VALUES
|
|
186
196
|
for (var _e = __values(meta.constants), _f = _e.next(); !_f.done; _f = _e.next()) {
|
|
187
197
|
var constant = _f.value;
|
|
188
198
|
if (AtomicPredicator_1.AtomicPredicator.constant(meta)(constant.type))
|
|
@@ -209,27 +219,28 @@ var CheckerProgrammer;
|
|
|
209
219
|
finally { if (e_1) throw e_1.error; }
|
|
210
220
|
}
|
|
211
221
|
try {
|
|
222
|
+
// ATOMIC VALUES
|
|
212
223
|
for (var _j = __values(meta.atomics), _k = _j.next(); !_k.done; _k = _j.next()) {
|
|
213
224
|
var type = _k.value;
|
|
214
225
|
if (AtomicPredicator_1.AtomicPredicator.atomic(meta)(type) === false)
|
|
215
226
|
continue;
|
|
216
227
|
else if (type === "number")
|
|
217
228
|
binaries.push({
|
|
218
|
-
expression: config.atomist(explore)((0, check_number_1.check_number)(
|
|
229
|
+
expression: config.atomist(explore)((0, check_number_1.check_number)(p, config.numeric)(importer)(metaTags)(jsDocTags)(input))(input),
|
|
219
230
|
combined: false,
|
|
220
231
|
});
|
|
221
232
|
else if (type === "bigint")
|
|
222
233
|
binaries.push({
|
|
223
|
-
expression: config.atomist(explore)((0, check_bigint_1.check_bigint)(importer)(metaTags)(jsDocTags)(input))(input),
|
|
234
|
+
expression: config.atomist(explore)((0, check_bigint_1.check_bigint)(p.tsc)(importer)(metaTags)(jsDocTags)(input))(input),
|
|
224
235
|
combined: false,
|
|
225
236
|
});
|
|
226
237
|
else if (type === "string")
|
|
227
238
|
binaries.push({
|
|
228
|
-
expression: config.atomist(explore)((0, check_string_1.check_string)(importer)(metaTags)(jsDocTags)(input))(input),
|
|
239
|
+
expression: config.atomist(explore)((0, check_string_1.check_string)(p.tsc)(importer)(metaTags)(jsDocTags)(input))(input),
|
|
229
240
|
combined: false,
|
|
230
241
|
});
|
|
231
242
|
else
|
|
232
|
-
add(true,
|
|
243
|
+
add(true, p.tsc.factory.createStringLiteral(type), ValueFactory_1.ValueFactory.TYPEOF(p.tsc)(input));
|
|
233
244
|
}
|
|
234
245
|
}
|
|
235
246
|
catch (e_3_1) { e_3 = { error: e_3_1 }; }
|
|
@@ -239,17 +250,19 @@ var CheckerProgrammer;
|
|
|
239
250
|
}
|
|
240
251
|
finally { if (e_3) throw e_3.error; }
|
|
241
252
|
}
|
|
253
|
+
// TEMPLATE LITERAL VALUES
|
|
242
254
|
if (meta.templates.length)
|
|
243
255
|
if (AtomicPredicator_1.AtomicPredicator.template(meta))
|
|
244
256
|
binaries.push({
|
|
245
|
-
expression: config.atomist(explore)((0, check_template_1.check_template)(importer)(metaTags)(jsDocTags)(meta.templates)(input))(input),
|
|
257
|
+
expression: config.atomist(explore)((0, check_template_1.check_template)(p.tsc)(importer)(metaTags)(jsDocTags)(meta.templates)(input))(input),
|
|
246
258
|
combined: false,
|
|
247
259
|
});
|
|
248
260
|
try {
|
|
261
|
+
// NATIVE CLASSES
|
|
249
262
|
for (var _l = __values(meta.natives), _m = _l.next(); !_m.done; _m = _l.next()) {
|
|
250
263
|
var native = _m.value;
|
|
251
264
|
binaries.push({
|
|
252
|
-
expression: (0, check_native_1.check_native)(native)(input),
|
|
265
|
+
expression: (0, check_native_1.check_native)(p.tsc)(native)(input),
|
|
253
266
|
combined: false,
|
|
254
267
|
});
|
|
255
268
|
}
|
|
@@ -271,17 +284,19 @@ var CheckerProgrammer;
|
|
|
271
284
|
});
|
|
272
285
|
};
|
|
273
286
|
};
|
|
287
|
+
// SETS
|
|
274
288
|
if (meta.sets.length) {
|
|
275
|
-
var install = prepare((0, check_native_1.check_native)("Set")(input), meta.sets
|
|
289
|
+
var install = prepare((0, check_native_1.check_native)(p.tsc)("Set")(input), meta.sets
|
|
276
290
|
.map(function (elem) { return "Set<".concat(elem.getName(), ">"); })
|
|
277
291
|
.join(" | "));
|
|
278
292
|
if (meta.sets.some(function (elem) { return elem.any; }))
|
|
279
293
|
install(null);
|
|
280
294
|
else
|
|
281
|
-
install(explore_sets(
|
|
295
|
+
install(explore_sets(p)(config)(importer)(input, meta.sets, __assign(__assign({}, explore), { from: "array" }), [], []));
|
|
282
296
|
}
|
|
297
|
+
// MAPS
|
|
283
298
|
if (meta.maps.length) {
|
|
284
|
-
var install = prepare((0, check_native_1.check_native)("Map")(input), meta.maps
|
|
299
|
+
var install = prepare((0, check_native_1.check_native)(p.tsc)("Map")(input), meta.maps
|
|
285
300
|
.map(function (_a) {
|
|
286
301
|
var key = _a.key, value = _a.value;
|
|
287
302
|
return "Map<".concat(key, ", ").concat(value, ">");
|
|
@@ -290,10 +305,11 @@ var CheckerProgrammer;
|
|
|
290
305
|
if (meta.maps.some(function (elem) { return elem.key.any && elem.value.any; }))
|
|
291
306
|
install(null);
|
|
292
307
|
else
|
|
293
|
-
install(explore_maps(
|
|
308
|
+
install(explore_maps(p)(config)(importer)(input, meta.maps.map(function (m) { return [m.key, m.value]; }), __assign(__assign({}, explore), { from: "array" }), [], []));
|
|
294
309
|
}
|
|
310
|
+
// ARRAYS AND TUPLES
|
|
295
311
|
if (meta.tuples.length + meta.arrays.length > 0) {
|
|
296
|
-
var install = prepare(config.atomist(explore)((0, check_array_1.check_array)(importer)(meta.tuples.length === 0 ? metaTags : [])(jsDocTags)(input))(input), __spreadArray(__spreadArray([], __read(meta.tuples), false), __read(meta.arrays), false).map(function (elem) {
|
|
312
|
+
var install = prepare(config.atomist(explore)((0, check_array_1.check_array)(p.tsc)(importer)(meta.tuples.length === 0 ? metaTags : [])(jsDocTags)(input))(input), __spreadArray(__spreadArray([], __read(meta.tuples), false), __read(meta.arrays), false).map(function (elem) {
|
|
297
313
|
return Array.isArray(elem)
|
|
298
314
|
? "[".concat(elem
|
|
299
315
|
.map(function (elem) { return elem.getName(); })
|
|
@@ -302,16 +318,18 @@ var CheckerProgrammer;
|
|
|
302
318
|
})
|
|
303
319
|
.join(" | "));
|
|
304
320
|
if (meta.arrays.length === 0)
|
|
305
|
-
install(explore_tuples(
|
|
321
|
+
install(explore_tuples(p)(config)(importer)(input, meta.tuples, __assign(__assign({}, explore), { from: "array" }), metaTags, jsDocTags));
|
|
306
322
|
else if (meta.arrays.some(function (elem) { return elem.any; }))
|
|
307
323
|
install(null);
|
|
308
324
|
else if (meta.tuples.length === 0)
|
|
309
|
-
|
|
325
|
+
// ARRAY ONLY
|
|
326
|
+
install(explore_arrays(p)(config)(importer)(input, meta.arrays, __assign(__assign({}, explore), { from: "array" }), metaTags, jsDocTags));
|
|
310
327
|
else
|
|
311
|
-
install(explore_arrays_and_tuples(
|
|
328
|
+
install(explore_arrays_and_tuples(p)(config)(importer)(input, __spreadArray(__spreadArray([], __read(meta.tuples), false), __read(meta.arrays), false), explore, metaTags, jsDocTags));
|
|
312
329
|
}
|
|
330
|
+
// OBJECT
|
|
313
331
|
if (meta.objects.length > 0)
|
|
314
|
-
prepare(ExpressionFactory_1.ExpressionFactory.isObject({
|
|
332
|
+
prepare(ExpressionFactory_1.ExpressionFactory.isObject(p.tsc)({
|
|
315
333
|
checkNull: true,
|
|
316
334
|
checkArray: meta.objects.some(function (obj) {
|
|
317
335
|
return obj.properties.every(function (prop) {
|
|
@@ -319,7 +337,7 @@ var CheckerProgrammer;
|
|
|
319
337
|
!prop.value.required;
|
|
320
338
|
});
|
|
321
339
|
}),
|
|
322
|
-
})(input), meta.objects.map(function (obj) { return obj.name; }).join(" | "))(explore_objects(config)(importer)(input, meta, __assign(__assign({}, explore), { from: "object" })));
|
|
340
|
+
})(input), meta.objects.map(function (obj) { return obj.name; }).join(" | "))(explore_objects(p.tsc)(config)(importer)(input, meta, __assign(__assign({}, explore), { from: "object" })));
|
|
323
341
|
if (instances.length) {
|
|
324
342
|
var transformer = function (merger) {
|
|
325
343
|
return function (ins) {
|
|
@@ -343,10 +361,13 @@ var CheckerProgrammer;
|
|
|
343
361
|
})(instances[0]));
|
|
344
362
|
else
|
|
345
363
|
binaries.push({
|
|
346
|
-
expression: config.combiner(explore)("or")(input, instances.map(transformer(
|
|
364
|
+
expression: config.combiner(explore)("or")(input, instances.map(transformer(p.tsc.factory.createLogicalAnd)), meta.getName()),
|
|
347
365
|
combined: true,
|
|
348
366
|
});
|
|
349
367
|
}
|
|
368
|
+
//----
|
|
369
|
+
// COMBINE CONDITIONS
|
|
370
|
+
//----
|
|
350
371
|
return top.length && binaries.length
|
|
351
372
|
? config.combiner(explore)("and")(input, __spreadArray(__spreadArray([], __read(top), false), [
|
|
352
373
|
{
|
|
@@ -361,7 +382,7 @@ var CheckerProgrammer;
|
|
|
361
382
|
};
|
|
362
383
|
};
|
|
363
384
|
};
|
|
364
|
-
CheckerProgrammer.decode_tuple = function (
|
|
385
|
+
CheckerProgrammer.decode_tuple = function (p) {
|
|
365
386
|
return function (config) {
|
|
366
387
|
return function (importer) {
|
|
367
388
|
return function (checkLength) {
|
|
@@ -369,34 +390,35 @@ var CheckerProgrammer;
|
|
|
369
390
|
var binaries = tuple
|
|
370
391
|
.filter(function (meta) { return meta.rest === null; })
|
|
371
392
|
.map(function (meta, index) {
|
|
372
|
-
return CheckerProgrammer.decode(
|
|
393
|
+
return CheckerProgrammer.decode(p)(config)(importer)(p.tsc.factory.createElementAccessExpression(input, index), meta, __assign(__assign({}, explore), { from: "array", postfix: explore.postfix.length
|
|
373
394
|
? "".concat(explore.postfix.slice(0, -1), "[").concat(index, "]\"")
|
|
374
395
|
: "[".concat(index, "]") }), tagList, jsDocTags);
|
|
375
396
|
});
|
|
376
397
|
var rest = tuple.length && tuple[tuple.length - 1].rest !== null
|
|
377
|
-
? CheckerProgrammer.decode(
|
|
378
|
-
|
|
398
|
+
? CheckerProgrammer.decode(p)(config)(importer)(p.tsc.factory.createCallExpression(IdentifierFactory_1.IdentifierFactory.access(p.tsc)(input)("slice"), undefined, [
|
|
399
|
+
p.tsc.factory.createNumericLiteral(tuple.length - 1),
|
|
379
400
|
]), (function () {
|
|
380
401
|
var wrapper = Metadata_1.Metadata.initialize();
|
|
381
402
|
wrapper.arrays.push(tuple[tuple.length - 1].rest);
|
|
382
403
|
return wrapper;
|
|
383
404
|
})(), __assign(__assign({}, explore), { start: tuple.length - 1 }), tagList, jsDocTags)
|
|
384
405
|
: null;
|
|
385
|
-
var arrayLength =
|
|
406
|
+
var arrayLength = p.tsc.factory.createPropertyAccessExpression(input, "length");
|
|
386
407
|
return config.combiner(explore)("and")(input, __spreadArray(__spreadArray(__spreadArray([], __read((checkLength && rest === null
|
|
387
408
|
? tuple.every(function (t) { return t.optional === false; })
|
|
388
409
|
? [
|
|
389
410
|
{
|
|
390
411
|
combined: false,
|
|
391
|
-
expression:
|
|
412
|
+
expression: p.tsc.factory.createStrictEquality(arrayLength, p.tsc.factory.createNumericLiteral(tuple.length)),
|
|
392
413
|
},
|
|
393
414
|
]
|
|
394
415
|
: [
|
|
395
416
|
{
|
|
396
417
|
combined: false,
|
|
397
|
-
expression:
|
|
398
|
-
return t.optional ===
|
|
399
|
-
|
|
418
|
+
expression: p.tsc.factory.createLogicalAnd(p.tsc.factory.createLessThanEquals(p.tsc.factory.createNumericLiteral(tuple.filter(function (t) {
|
|
419
|
+
return t.optional ===
|
|
420
|
+
false;
|
|
421
|
+
}).length), arrayLength), p.tsc.factory.createGreaterThanEquals(p.tsc.factory.createNumericLiteral(tuple.length), arrayLength)),
|
|
400
422
|
},
|
|
401
423
|
]
|
|
402
424
|
: [])), false), __read((config.joiner.tuple
|
|
@@ -422,144 +444,138 @@ var CheckerProgrammer;
|
|
|
422
444
|
};
|
|
423
445
|
};
|
|
424
446
|
};
|
|
425
|
-
var decode_array = function (
|
|
426
|
-
return
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
};
|
|
434
|
-
};
|
|
435
|
-
};
|
|
436
|
-
CheckerProgrammer.decode_object = function (config) { return function (importer) {
|
|
437
|
-
var func = FeatureProgrammer_1.FeatureProgrammer.decode_object(config)(importer);
|
|
438
|
-
return function (input, obj, explore) {
|
|
439
|
-
obj.validated = true;
|
|
440
|
-
return func(input, obj, explore);
|
|
441
|
-
};
|
|
442
|
-
}; };
|
|
443
|
-
var explore_sets = function (project) {
|
|
447
|
+
var decode_array = function (p) { return function (config) { return function (importer) {
|
|
448
|
+
return FeatureProgrammer_1.FeatureProgrammer.decode_array(p.tsc)({
|
|
449
|
+
trace: config.trace,
|
|
450
|
+
path: config.path,
|
|
451
|
+
decoder: CheckerProgrammer.decode(p)(config)(importer),
|
|
452
|
+
})(importer)(config.joiner.array);
|
|
453
|
+
}; }; };
|
|
454
|
+
CheckerProgrammer.decode_object = function (tsc) {
|
|
444
455
|
return function (config) {
|
|
445
456
|
return function (importer) {
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
failure: function (input, expected, explore) {
|
|
452
|
-
return typescript_1.default.factory.createReturnStatement(config.joiner.failure(input, expected, explore));
|
|
453
|
-
},
|
|
454
|
-
});
|
|
455
|
-
};
|
|
456
|
-
};
|
|
457
|
-
};
|
|
458
|
-
var explore_maps = function (project) {
|
|
459
|
-
return function (config) {
|
|
460
|
-
return function (importer) {
|
|
461
|
-
return UnionExplorer_1.UnionExplorer.map({
|
|
462
|
-
checker: function (input, entry, explore) {
|
|
463
|
-
var func = CheckerProgrammer.decode(project)(config)(importer);
|
|
464
|
-
return typescript_1.default.factory.createLogicalAnd(func(typescript_1.default.factory.createElementAccessExpression(input, 0), entry[0], __assign(__assign({}, explore), { postfix: "".concat(explore.postfix, "[0]") }), [], []), func(typescript_1.default.factory.createElementAccessExpression(input, 1), entry[1], __assign(__assign({}, explore), { postfix: "".concat(explore.postfix, "[1]") }), [], []));
|
|
465
|
-
},
|
|
466
|
-
decoder: function (input, target, explore) {
|
|
467
|
-
return decode_array(project)(config)(importer)(input, Metadata_1.Metadata.create({
|
|
468
|
-
any: false,
|
|
469
|
-
nullable: false,
|
|
470
|
-
required: true,
|
|
471
|
-
optional: false,
|
|
472
|
-
functional: false,
|
|
473
|
-
resolved: null,
|
|
474
|
-
constants: [],
|
|
475
|
-
atomics: [],
|
|
476
|
-
templates: [],
|
|
477
|
-
rest: null,
|
|
478
|
-
arrays: [],
|
|
479
|
-
tuples: [target],
|
|
480
|
-
objects: [],
|
|
481
|
-
natives: [],
|
|
482
|
-
sets: [],
|
|
483
|
-
maps: [],
|
|
484
|
-
}), explore, [], []);
|
|
485
|
-
},
|
|
486
|
-
empty: config.success,
|
|
487
|
-
success: config.success,
|
|
488
|
-
failure: function (input, expected, explore) {
|
|
489
|
-
return typescript_1.default.factory.createReturnStatement(config.joiner.failure(input, expected, explore));
|
|
490
|
-
},
|
|
491
|
-
});
|
|
492
|
-
};
|
|
493
|
-
};
|
|
494
|
-
};
|
|
495
|
-
var explore_tuples = function (project) {
|
|
496
|
-
return function (config) {
|
|
497
|
-
return function (importer) {
|
|
498
|
-
return UnionExplorer_1.UnionExplorer.tuple({
|
|
499
|
-
checker: (0, check_union_tuple_1.check_union_tuple)(project)(config)(importer),
|
|
500
|
-
decoder: CheckerProgrammer.decode_tuple(project)(config)(importer)(true),
|
|
501
|
-
empty: config.success,
|
|
502
|
-
success: config.success,
|
|
503
|
-
failure: function (input, expected, explore) {
|
|
504
|
-
return typescript_1.default.factory.createReturnStatement(config.joiner.failure(input, expected, explore));
|
|
505
|
-
},
|
|
506
|
-
});
|
|
457
|
+
var func = FeatureProgrammer_1.FeatureProgrammer.decode_object(tsc)(config)(importer);
|
|
458
|
+
return function (input, obj, explore) {
|
|
459
|
+
obj.validated = true;
|
|
460
|
+
return func(input, obj, explore);
|
|
461
|
+
};
|
|
507
462
|
};
|
|
508
463
|
};
|
|
509
464
|
};
|
|
510
|
-
var
|
|
511
|
-
return UnionExplorer_1.UnionExplorer.
|
|
512
|
-
checker: CheckerProgrammer.decode(
|
|
513
|
-
decoder: decode_array(
|
|
465
|
+
var explore_sets = function (p) { return function (config) { return function (importer) {
|
|
466
|
+
return UnionExplorer_1.UnionExplorer.set(p.tsc)({
|
|
467
|
+
checker: CheckerProgrammer.decode(p)(config)(importer),
|
|
468
|
+
decoder: decode_array(p)(config)(importer),
|
|
514
469
|
empty: config.success,
|
|
515
470
|
success: config.success,
|
|
516
471
|
failure: function (input, expected, explore) {
|
|
517
|
-
return
|
|
472
|
+
return p.tsc.factory.createReturnStatement(config.joiner.failure(input, expected, explore));
|
|
518
473
|
},
|
|
519
474
|
});
|
|
520
|
-
};
|
|
521
|
-
var
|
|
522
|
-
return UnionExplorer_1.UnionExplorer.
|
|
475
|
+
}; }; };
|
|
476
|
+
var explore_maps = function (p) { return function (config) { return function (importer) {
|
|
477
|
+
return UnionExplorer_1.UnionExplorer.map(p.tsc)({
|
|
478
|
+
checker: function (input, entry, explore) {
|
|
479
|
+
var func = CheckerProgrammer.decode(p)(config)(importer);
|
|
480
|
+
return p.tsc.factory.createLogicalAnd(func(p.tsc.factory.createElementAccessExpression(input, 0), entry[0], __assign(__assign({}, explore), { postfix: "".concat(explore.postfix, "[0]") }), [], []), func(p.tsc.factory.createElementAccessExpression(input, 1), entry[1], __assign(__assign({}, explore), { postfix: "".concat(explore.postfix, "[1]") }), [], []));
|
|
481
|
+
},
|
|
482
|
+
decoder: function (input, target, explore) {
|
|
483
|
+
return decode_array(p)(config)(importer)(input, Metadata_1.Metadata.create({
|
|
484
|
+
any: false,
|
|
485
|
+
nullable: false,
|
|
486
|
+
required: true,
|
|
487
|
+
optional: false,
|
|
488
|
+
functional: false,
|
|
489
|
+
resolved: null,
|
|
490
|
+
constants: [],
|
|
491
|
+
atomics: [],
|
|
492
|
+
templates: [],
|
|
493
|
+
rest: null,
|
|
494
|
+
arrays: [],
|
|
495
|
+
tuples: [target],
|
|
496
|
+
objects: [],
|
|
497
|
+
natives: [],
|
|
498
|
+
sets: [],
|
|
499
|
+
maps: [],
|
|
500
|
+
}), explore, [], []);
|
|
501
|
+
},
|
|
502
|
+
empty: config.success,
|
|
503
|
+
success: config.success,
|
|
504
|
+
failure: function (input, expected, explore) {
|
|
505
|
+
return p.tsc.factory.createReturnStatement(config.joiner.failure(input, expected, explore));
|
|
506
|
+
},
|
|
507
|
+
});
|
|
508
|
+
}; }; };
|
|
509
|
+
var explore_tuples = function (p) { return function (config) { return function (importer) {
|
|
510
|
+
return UnionExplorer_1.UnionExplorer.tuple(p.tsc)({
|
|
511
|
+
checker: (0, check_union_tuple_1.check_union_tuple)(p)(config)(importer),
|
|
512
|
+
decoder: CheckerProgrammer.decode_tuple(p)(config)(importer)(true),
|
|
513
|
+
empty: config.success,
|
|
514
|
+
success: config.success,
|
|
515
|
+
failure: function (input, expected, explore) {
|
|
516
|
+
return p.tsc.factory.createReturnStatement(config.joiner.failure(input, expected, explore));
|
|
517
|
+
},
|
|
518
|
+
});
|
|
519
|
+
}; }; };
|
|
520
|
+
var explore_arrays = function (p) { return function (config) { return function (importer) {
|
|
521
|
+
return UnionExplorer_1.UnionExplorer.array(p.tsc)({
|
|
522
|
+
checker: CheckerProgrammer.decode(p)(config)(importer),
|
|
523
|
+
decoder: decode_array(p)(config)(importer),
|
|
524
|
+
empty: config.success,
|
|
525
|
+
success: config.success,
|
|
526
|
+
failure: function (input, expected, explore) {
|
|
527
|
+
return p.tsc.factory.createReturnStatement(config.joiner.failure(input, expected, explore));
|
|
528
|
+
},
|
|
529
|
+
});
|
|
530
|
+
}; }; };
|
|
531
|
+
var explore_arrays_and_tuples = function (p) { return function (config) { return function (importer) {
|
|
532
|
+
return UnionExplorer_1.UnionExplorer.array_or_tuple(p.tsc)({
|
|
523
533
|
checker: function (front, target, explore, tags, jsDocTags, array) {
|
|
524
534
|
return Array.isArray(target)
|
|
525
|
-
? (0, check_union_tuple_1.check_union_tuple)(
|
|
535
|
+
? (0, check_union_tuple_1.check_union_tuple)(p)(config)(importer)(front, target, explore, tags, jsDocTags, array)
|
|
526
536
|
: config.atomist(explore)({
|
|
527
|
-
expression: CheckerProgrammer.decode(
|
|
528
|
-
tags: (0, check_array_length_1.check_array_length)(tags)(array),
|
|
537
|
+
expression: CheckerProgrammer.decode(p)(config)(importer)(front, target, explore, tags, jsDocTags),
|
|
538
|
+
tags: (0, check_array_length_1.check_array_length)(p.tsc)(tags)(array),
|
|
529
539
|
})(array);
|
|
530
540
|
},
|
|
531
541
|
decoder: function (input, target, explore, tags, jsDocTags) {
|
|
532
542
|
return Array.isArray(target)
|
|
533
|
-
? CheckerProgrammer.decode_tuple(
|
|
534
|
-
: decode_array(
|
|
543
|
+
? CheckerProgrammer.decode_tuple(p)(config)(importer)(true)(input, target, explore, tags, jsDocTags)
|
|
544
|
+
: decode_array(p)(config)(importer)(input, target, explore, tags, jsDocTags);
|
|
535
545
|
},
|
|
536
546
|
empty: config.success,
|
|
537
547
|
success: config.success,
|
|
538
548
|
failure: function (input, expected, explore) {
|
|
539
|
-
return
|
|
549
|
+
return p.tsc.factory.createReturnStatement(config.joiner.failure(input, expected, explore));
|
|
540
550
|
},
|
|
541
551
|
});
|
|
542
|
-
};
|
|
543
|
-
var explore_objects = function (
|
|
544
|
-
|
|
545
|
-
|
|
546
|
-
|
|
547
|
-
return
|
|
548
|
-
|
|
552
|
+
}; }; };
|
|
553
|
+
var explore_objects = function (tsc) {
|
|
554
|
+
return function (config) {
|
|
555
|
+
return function (importer) {
|
|
556
|
+
var objector = CheckerProgrammer.decode_object(tsc)(config)(importer);
|
|
557
|
+
return function (input, meta, explore) {
|
|
558
|
+
if (meta.objects.length === 1)
|
|
559
|
+
return objector(input, meta.objects[0], explore);
|
|
560
|
+
return tsc.factory.createCallExpression(tsc.factory.createIdentifier(importer.useLocal("".concat(config.unioners).concat(meta.union_index))), undefined, FeatureProgrammer_1.FeatureProgrammer.get_object_arguments(tsc)(config)(explore)(input));
|
|
561
|
+
};
|
|
562
|
+
};
|
|
549
563
|
};
|
|
550
|
-
};
|
|
551
|
-
})(CheckerProgrammer
|
|
552
|
-
var create_add = function (
|
|
553
|
-
return function (
|
|
554
|
-
return function (
|
|
555
|
-
|
|
556
|
-
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
|
|
561
|
-
|
|
562
|
-
|
|
564
|
+
};
|
|
565
|
+
})(CheckerProgrammer || (exports.CheckerProgrammer = CheckerProgrammer = {}));
|
|
566
|
+
var create_add = function (tsc) {
|
|
567
|
+
return function (binaries) {
|
|
568
|
+
return function (defaultInput) {
|
|
569
|
+
return function (exact, left, right) {
|
|
570
|
+
if (right === void 0) { right = defaultInput; }
|
|
571
|
+
var factory = exact
|
|
572
|
+
? tsc.factory.createStrictEquality
|
|
573
|
+
: tsc.factory.createStrictInequality;
|
|
574
|
+
binaries.push({
|
|
575
|
+
expression: factory(left, right),
|
|
576
|
+
combined: false,
|
|
577
|
+
});
|
|
578
|
+
};
|
|
563
579
|
};
|
|
564
580
|
};
|
|
565
581
|
};
|