UNPKG

typia

Version:

Superfast runtime validators with only one line

98 lines (92 loc) 2.97 kB
import ts from "typescript"; import { IdentifierFactory } from "../../factories/IdentifierFactory"; import { StatementFactory } from "../../factories/StatementFactory"; import { TypeFactory } from "../../factories/TypeFactory"; import { IProgrammerProps } from "../../transformers/IProgrammerProps"; import { ITypiaContext } from "../../transformers/ITypiaContext"; import { FeatureProgrammer } from "../FeatureProgrammer"; import { IsProgrammer } from "../IsProgrammer"; import { FunctionProgrammer } from "../helpers/FunctionProgrammer"; import { MiscPruneProgrammer } from "./MiscPruneProgrammer"; export namespace MiscIsPruneProgrammer { export const decompose = (props: { context: ITypiaContext; functor: FunctionProgrammer; type: ts.Type; name: string | undefined; }): FeatureProgrammer.IDecomposed => { const is: FeatureProgrammer.IDecomposed = IsProgrammer.decompose({ ...props, config: { equals: false, }, }); const prune: FeatureProgrammer.IDecomposed = MiscPruneProgrammer.decompose({ ...props, validated: true, }); return { functions: { ...is.functions, ...prune.functions, }, statements: [ ...is.statements, ...prune.statements, StatementFactory.constant({ name: "__is", value: is.arrow, }), StatementFactory.constant({ name: "__prune", value: prune.arrow, }), ], arrow: ts.factory.createArrowFunction( undefined, undefined, [IdentifierFactory.parameter("input", TypeFactory.keyword("any"))], is.arrow.type, undefined, ts.factory.createBlock( [ ts.factory.createIfStatement( ts.factory.createEquality( ts.factory.createFalse(), ts.factory.createCallExpression( ts.factory.createIdentifier("__is"), undefined, [ts.factory.createIdentifier("input")], ), ), ts.factory.createReturnStatement(ts.factory.createFalse()), ), ts.factory.createExpressionStatement( ts.factory.createCallExpression( ts.factory.createIdentifier("__prune"), undefined, [ts.factory.createIdentifier("input")], ), ), ts.factory.createReturnStatement(ts.factory.createTrue()), ], true, ), ), }; }; export const write = (props: IProgrammerProps): ts.CallExpression => { const functor: FunctionProgrammer = new FunctionProgrammer( props.modulo.getText(), ); const result: FeatureProgrammer.IDecomposed = decompose({ ...props, functor, }); return FeatureProgrammer.writeDecomposed({ modulo: props.modulo, functor, result, }); }; }