UNPKG

@glimmer/compiler

Version:
139 lines (127 loc) 15.5 kB
import { ASTv2, generateSyntaxError, SourceSpan } from '@glimmer/syntax'; import { Err, Ok, Result } from '../../../shared/result'; import * as mir from '../../2-encoding/mir'; import { VISIT_EXPRS } from '../visitors/expressions'; import { keywords } from './impl'; import { toAppend } from './utils/call-to-append'; import { assertCurryKeyword } from './utils/curry'; import { getDynamicVarKeyword } from './utils/dynamic-vars'; import { hasBlockKeyword } from './utils/has-block'; import { ifUnlessInlineKeyword } from './utils/if-unless'; import { logKeyword } from './utils/log'; export const APPEND_KEYWORDS = keywords('Append').kw('has-block', toAppend(hasBlockKeyword('has-block'))).kw('has-block-params', toAppend(hasBlockKeyword('has-block-params'))).kw('-get-dynamic-var', toAppend(getDynamicVarKeyword)).kw('log', toAppend(logKeyword)).kw('if', toAppend(ifUnlessInlineKeyword('if'))).kw('unless', toAppend(ifUnlessInlineKeyword('unless'))).kw('yield', { assert(node) { let { args } = node; if (args.named.isEmpty()) { return Ok({ target: SourceSpan.synthetic('default').toSlice(), positional: args.positional }); } else { let target = args.named.get('to'); if (args.named.size > 1 || target === null) { return Err(generateSyntaxError(`yield only takes a single named argument: 'to'`, args.named.loc)); } if (ASTv2.isLiteral(target, 'string')) { return Ok({ target: target.toSlice(), positional: args.positional }); } else { return Err(generateSyntaxError(`you can only yield to a literal string value`, target.loc)); } } }, translate({ node, state }, { target, positional }) { return VISIT_EXPRS.Positional(positional, state).mapOk(positional => new mir.Yield({ loc: node.loc, target, to: state.scope.allocateBlock(target.chars), positional })); } }).kw('debugger', { assert(node) { let { args } = node; let { positional } = args; if (args.isEmpty()) { return Ok(undefined); } else { if (positional.isEmpty()) { return Err(generateSyntaxError(`debugger does not take any named arguments`, node.loc)); } else { return Err(generateSyntaxError(`debugger does not take any positional arguments`, node.loc)); } } }, translate({ node, state: { scope } }) { scope.setHasEval(); return Ok(new mir.Debugger({ loc: node.loc, scope })); } }).kw('component', { assert: assertCurryKeyword(0 /* Component */ ), translate({ node, state }, { definition, args }) { let definitionResult = VISIT_EXPRS.visit(definition, state); let argsResult = VISIT_EXPRS.Args(args, state); return Result.all(definitionResult, argsResult).mapOk(([definition, args]) => new mir.InvokeComponent({ loc: node.loc, definition, args, blocks: null })); } }).kw('helper', { assert: assertCurryKeyword(1 /* Helper */ ), translate({ node, state }, { definition, args }) { let definitionResult = VISIT_EXPRS.visit(definition, state); let argsResult = VISIT_EXPRS.Args(args, state); return Result.all(definitionResult, argsResult).mapOk(([definition, args]) => { let text = new mir.CallExpression({ callee: definition, args, loc: node.loc }); return new mir.AppendTextNode({ loc: node.loc, text }); }); } }); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../../../packages/@glimmer/compiler/lib/passes/1-normalization/keywords/append.ts"],"names":[],"mappings":"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","sourcesContent":["import { CurriedType } from '@glimmer/interfaces';\nimport { ASTv2, generateSyntaxError, SourceSlice, SourceSpan } from '@glimmer/syntax';\n\nimport { Err, Ok, Result } from '../../../shared/result';\nimport * as mir from '../../2-encoding/mir';\nimport { NormalizationState } from '../context';\nimport { VISIT_EXPRS } from '../visitors/expressions';\nimport { keywords } from './impl';\nimport { toAppend } from './utils/call-to-append';\nimport { assertCurryKeyword } from './utils/curry';\nimport { getDynamicVarKeyword } from './utils/dynamic-vars';\nimport { hasBlockKeyword } from './utils/has-block';\nimport { ifUnlessInlineKeyword } from './utils/if-unless';\nimport { logKeyword } from './utils/log';\n\nexport const APPEND_KEYWORDS = keywords('Append')\n  .kw('has-block', toAppend(hasBlockKeyword('has-block')))\n  .kw('has-block-params', toAppend(hasBlockKeyword('has-block-params')))\n  .kw('-get-dynamic-var', toAppend(getDynamicVarKeyword))\n  .kw('log', toAppend(logKeyword))\n  .kw('if', toAppend(ifUnlessInlineKeyword('if')))\n  .kw('unless', toAppend(ifUnlessInlineKeyword('unless')))\n  .kw('yield', {\n    assert(\n      node: ASTv2.AppendContent\n    ): Result<{\n      target: SourceSlice;\n      positional: ASTv2.PositionalArguments;\n    }> {\n      let { args } = node;\n\n      if (args.named.isEmpty()) {\n        return Ok({\n          target: SourceSpan.synthetic('default').toSlice(),\n          positional: args.positional,\n        });\n      } else {\n        let target = args.named.get('to');\n\n        if (args.named.size > 1 || target === null) {\n          return Err(\n            generateSyntaxError(`yield only takes a single named argument: 'to'`, args.named.loc)\n          );\n        }\n\n        if (ASTv2.isLiteral(target, 'string')) {\n          return Ok({ target: target.toSlice(), positional: args.positional });\n        } else {\n          return Err(\n            generateSyntaxError(`you can only yield to a literal string value`, target.loc)\n          );\n        }\n      }\n    },\n\n    translate(\n      { node, state }: { node: ASTv2.AppendContent; state: NormalizationState },\n      {\n        target,\n        positional,\n      }: {\n        target: SourceSlice;\n        positional: ASTv2.PositionalArguments;\n      }\n    ): Result<mir.Statement> {\n      return VISIT_EXPRS.Positional(positional, state).mapOk(\n        (positional) =>\n          new mir.Yield({\n            loc: node.loc,\n            target,\n            to: state.scope.allocateBlock(target.chars),\n            positional,\n          })\n      );\n    },\n  })\n  .kw('debugger', {\n    assert(node: ASTv2.AppendContent): Result<void> {\n      let { args } = node;\n      let { positional } = args;\n\n      if (args.isEmpty()) {\n        return Ok(undefined);\n      } else {\n        if (positional.isEmpty()) {\n          return Err(generateSyntaxError(`debugger does not take any named arguments`, node.loc));\n        } else {\n          return Err(\n            generateSyntaxError(`debugger does not take any positional arguments`, node.loc)\n          );\n        }\n      }\n    },\n\n    translate({\n      node,\n      state: { scope },\n    }: {\n      node: ASTv2.AppendContent;\n      state: NormalizationState;\n    }): Result<mir.Statement> {\n      scope.setHasEval();\n      return Ok(new mir.Debugger({ loc: node.loc, scope }));\n    },\n  })\n  .kw('component', {\n    assert: assertCurryKeyword(CurriedType.Component),\n\n    translate(\n      { node, state }: { node: ASTv2.AppendContent; state: NormalizationState },\n      { definition, args }: { definition: ASTv2.ExpressionNode; args: ASTv2.Args }\n    ): Result<mir.InvokeComponent> {\n      let definitionResult = VISIT_EXPRS.visit(definition, state);\n      let argsResult = VISIT_EXPRS.Args(args, state);\n\n      return Result.all(definitionResult, argsResult).mapOk(\n        ([definition, args]) =>\n          new mir.InvokeComponent({\n            loc: node.loc,\n            definition,\n            args,\n            blocks: null,\n          })\n      );\n    },\n  })\n  .kw('helper', {\n    assert: assertCurryKeyword(CurriedType.Helper),\n\n    translate(\n      { node, state }: { node: ASTv2.AppendContent; state: NormalizationState },\n      { definition, args }: { definition: ASTv2.ExpressionNode; args: ASTv2.Args }\n    ): Result<mir.AppendTextNode> {\n      let definitionResult = VISIT_EXPRS.visit(definition, state);\n      let argsResult = VISIT_EXPRS.Args(args, state);\n\n      return Result.all(definitionResult, argsResult).mapOk(([definition, args]) => {\n        let text = new mir.CallExpression({ callee: definition, args, loc: node.loc });\n\n        return new mir.AppendTextNode({\n          loc: node.loc,\n          text,\n        });\n      });\n    },\n  });\n"],"sourceRoot":""}