UNPKG

@matatbread/typia

Version:

Superfast runtime validators with only one line

72 lines (69 loc) 3.21 kB
import ts from 'typescript'; import { IdentifierFactory } from '../../factories/IdentifierFactory.mjs'; import { StatementFactory } from '../../factories/StatementFactory.mjs'; import { TypeFactory } from '../../factories/TypeFactory.mjs'; import { FeatureProgrammer } from '../FeatureProgrammer.mjs'; import { IsProgrammer } from '../IsProgrammer.mjs'; import { FunctionProgrammer } from '../helpers/FunctionProgrammer.mjs'; var JsonIsParseProgrammer; (function (JsonIsParseProgrammer) { JsonIsParseProgrammer.decompose = (props) => { const is = IsProgrammer.decompose({ ...props, context: { ...props.context, options: { ...props.context.options, functional: false, numeric: false, }, }, config: { equals: false, }, }); return { functions: is.functions, statements: [ ...is.statements, StatementFactory.constant({ name: "__is", value: is.arrow, }), ], arrow: ts.factory.createArrowFunction(undefined, undefined, [IdentifierFactory.parameter("input", TypeFactory.keyword("string"))], ts.factory.createUnionTypeNode([ props.context.importer.type({ file: "typia", name: "Primitive", arguments: [ ts.factory.createTypeReferenceNode(props.name ?? TypeFactory.getFullName({ checker: props.context.checker, type: props.type, })), ], }), ts.factory.createTypeReferenceNode("null"), ]), undefined, ts.factory.createBlock([ ts.factory.createExpressionStatement(ts.factory.createBinaryExpression(ts.factory.createIdentifier("input"), ts.SyntaxKind.EqualsToken, ts.factory.createCallExpression(ts.factory.createIdentifier("JSON.parse"), undefined, [ts.factory.createIdentifier("input")]))), ts.factory.createReturnStatement(ts.factory.createConditionalExpression(ts.factory.createCallExpression(ts.factory.createIdentifier("__is"), undefined, [ts.factory.createIdentifier("input")]), undefined, ts.factory.createAsExpression(ts.factory.createIdentifier("input"), TypeFactory.keyword("any")), undefined, ts.factory.createNull())), ])), }; }; JsonIsParseProgrammer.write = (props) => { const functor = new FunctionProgrammer(props.modulo.getText()); const result = JsonIsParseProgrammer.decompose({ context: props.context, functor, type: props.type, name: props.name, }); return FeatureProgrammer.writeDecomposed({ modulo: props.modulo, functor, result, }); }; })(JsonIsParseProgrammer || (JsonIsParseProgrammer = {})); export { JsonIsParseProgrammer }; //# sourceMappingURL=JsonIsParseProgrammer.mjs.map