1 | ;
|
2 |
|
3 | Object.defineProperty(exports, "__esModule", {
|
4 | value: true
|
5 | });
|
6 | exports.Parser = void 0;
|
7 |
|
8 | var _util = require("@glimmer/util");
|
9 |
|
10 | var _simpleHtmlTokenizer = require("simple-html-tokenizer");
|
11 |
|
12 | function _defineProperties(target, props) {
|
13 | for (var i = 0; i < props.length; i++) {
|
14 | var descriptor = props[i];
|
15 | descriptor.enumerable = descriptor.enumerable || false;
|
16 | descriptor.configurable = true;
|
17 | if ("value" in descriptor) descriptor.writable = true;
|
18 | Object.defineProperty(target, descriptor.key, descriptor);
|
19 | }
|
20 | }
|
21 |
|
22 | function _createClass(Constructor, protoProps, staticProps) {
|
23 | if (protoProps) _defineProperties(Constructor.prototype, protoProps);
|
24 | if (staticProps) _defineProperties(Constructor, staticProps);
|
25 | return Constructor;
|
26 | }
|
27 |
|
28 | var Parser = /*#__PURE__*/function () {
|
29 | function Parser(source, entityParser, mode) {
|
30 | if (entityParser === void 0) {
|
31 | entityParser = new _simpleHtmlTokenizer.EntityParser(_simpleHtmlTokenizer.HTML5NamedCharRefs);
|
32 | }
|
33 |
|
34 | if (mode === void 0) {
|
35 | mode = 'precompile';
|
36 | }
|
37 |
|
38 | this.elementStack = [];
|
39 | this.currentAttribute = null;
|
40 | this.currentNode = null;
|
41 | this.source = source;
|
42 | this.lines = source.source.split(/(?:\r\n?|\n)/g);
|
43 | this.tokenizer = new _simpleHtmlTokenizer.EventedTokenizer(this, entityParser, mode);
|
44 | }
|
45 |
|
46 | var _proto = Parser.prototype;
|
47 |
|
48 | _proto.offset = function offset() {
|
49 | var _this$tokenizer = this.tokenizer,
|
50 | line = _this$tokenizer.line,
|
51 | column = _this$tokenizer.column;
|
52 | return this.source.offsetFor(line, column);
|
53 | };
|
54 |
|
55 | _proto.pos = function pos(_ref) {
|
56 | var line = _ref.line,
|
57 | column = _ref.column;
|
58 | return this.source.offsetFor(line, column);
|
59 | };
|
60 |
|
61 | _proto.finish = function finish(node) {
|
62 | return (0, _util.assign)({}, node, {
|
63 | loc: node.loc.until(this.offset())
|
64 | }); // node.loc = node.loc.withEnd(end);
|
65 | };
|
66 |
|
67 | _proto.acceptTemplate = function acceptTemplate(node) {
|
68 | return this[node.type](node);
|
69 | };
|
70 |
|
71 | _proto.acceptNode = function acceptNode(node) {
|
72 | return this[node.type](node);
|
73 | };
|
74 |
|
75 | _proto.currentElement = function currentElement() {
|
76 | return this.elementStack[this.elementStack.length - 1];
|
77 | };
|
78 |
|
79 | _proto.sourceForNode = function sourceForNode(node, endNode) {
|
80 | var firstLine = node.loc.start.line - 1;
|
81 | var currentLine = firstLine - 1;
|
82 | var firstColumn = node.loc.start.column;
|
83 | var string = [];
|
84 | var line;
|
85 | var lastLine;
|
86 | var lastColumn;
|
87 |
|
88 | if (endNode) {
|
89 | lastLine = endNode.loc.end.line - 1;
|
90 | lastColumn = endNode.loc.end.column;
|
91 | } else {
|
92 | lastLine = node.loc.end.line - 1;
|
93 | lastColumn = node.loc.end.column;
|
94 | }
|
95 |
|
96 | while (currentLine < lastLine) {
|
97 | currentLine++;
|
98 | line = this.lines[currentLine];
|
99 |
|
100 | if (currentLine === firstLine) {
|
101 | if (firstLine === lastLine) {
|
102 | string.push(line.slice(firstColumn, lastColumn));
|
103 | } else {
|
104 | string.push(line.slice(firstColumn));
|
105 | }
|
106 | } else if (currentLine === lastLine) {
|
107 | string.push(line.slice(0, lastColumn));
|
108 | } else {
|
109 | string.push(line);
|
110 | }
|
111 | }
|
112 |
|
113 | return string.join('\n');
|
114 | };
|
115 |
|
116 | _createClass(Parser, [{
|
117 | key: "currentAttr",
|
118 | get: function get() {
|
119 | return this.currentAttribute;
|
120 | }
|
121 | }, {
|
122 | key: "currentTag",
|
123 | get: function get() {
|
124 | var node = this.currentNode;
|
125 | false && (0, _util.assert)(node && (node.type === 'StartTag' || node.type === 'EndTag'), 'expected tag');
|
126 | return node;
|
127 | }
|
128 | }, {
|
129 | key: "currentStartTag",
|
130 | get: function get() {
|
131 | var node = this.currentNode;
|
132 | false && (0, _util.assert)(node && node.type === 'StartTag', 'expected start tag');
|
133 | return node;
|
134 | }
|
135 | }, {
|
136 | key: "currentEndTag",
|
137 | get: function get() {
|
138 | var node = this.currentNode;
|
139 | false && (0, _util.assert)(node && node.type === 'EndTag', 'expected end tag');
|
140 | return node;
|
141 | }
|
142 | }, {
|
143 | key: "currentComment",
|
144 | get: function get() {
|
145 | var node = this.currentNode;
|
146 | false && (0, _util.assert)(node && node.type === 'CommentStatement', 'expected a comment');
|
147 | return node;
|
148 | }
|
149 | }, {
|
150 | key: "currentData",
|
151 | get: function get() {
|
152 | var node = this.currentNode;
|
153 | false && (0, _util.assert)(node && node.type === 'TextNode', 'expected a text node');
|
154 | return node;
|
155 | }
|
156 | }]);
|
157 |
|
158 | return Parser;
|
159 | }();
|
160 |
|
161 | exports.Parser = Parser;
|
162 | //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../packages/@glimmer/syntax/lib/parser.ts"],"names":[],"mappings":"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","sourcesContent":["import { Option } from '@glimmer/interfaces';\nimport { assert, assign, expect } from '@glimmer/util';\nimport {\n  EntityParser,\n  EventedTokenizer,\n  HTML5NamedCharRefs as namedCharRefs,\n} from 'simple-html-tokenizer';\n\nimport { SourcePosition } from './source/location';\nimport { Source } from './source/source';\nimport { SourceOffset, SourceSpan } from './source/span';\nimport * as ASTv1 from './v1/api';\nimport * as HBS from './v1/handlebars-ast';\n\nexport type ParserNodeBuilder<N extends { loc: SourceSpan }> = Omit<N, 'loc'> & {\n  loc: SourceOffset;\n};\n\nexport type Element = ASTv1.Template | ASTv1.Block | ASTv1.ElementNode;\n\nexport interface Tag<T extends 'StartTag' | 'EndTag'> {\n  readonly type: T;\n  name: string;\n  readonly attributes: ASTv1.AttrNode[];\n  readonly modifiers: ASTv1.ElementModifierStatement[];\n  readonly comments: ASTv1.MustacheCommentStatement[];\n  selfClosing: boolean;\n  readonly loc: SourceSpan;\n}\n\nexport interface Attribute {\n  name: string;\n  currentPart: ASTv1.TextNode | null;\n  parts: (ASTv1.MustacheStatement | ASTv1.TextNode)[];\n  isQuoted: boolean;\n  isDynamic: boolean;\n  start: SourceOffset;\n  valueSpan: SourceSpan;\n}\n\nexport abstract class Parser {\n  protected elementStack: Element[] = [];\n  private lines: string[];\n  readonly source: Source;\n  public currentAttribute: Option<Attribute> = null;\n  public currentNode: Option<\n    Readonly<\n      | ParserNodeBuilder<ASTv1.CommentStatement>\n      | ASTv1.TextNode\n      | ParserNodeBuilder<Tag<'StartTag'>>\n      | ParserNodeBuilder<Tag<'EndTag'>>\n    >\n  > = null;\n  public tokenizer: EventedTokenizer;\n\n  constructor(\n    source: Source,\n    entityParser = new EntityParser(namedCharRefs),\n    mode: 'precompile' | 'codemod' = 'precompile'\n  ) {\n    this.source = source;\n    this.lines = source.source.split(/(?:\\r\\n?|\\n)/g);\n    this.tokenizer = new EventedTokenizer(this, entityParser, mode);\n  }\n\n  offset(): SourceOffset {\n    let { line, column } = this.tokenizer;\n    return this.source.offsetFor(line, column);\n  }\n\n  pos({ line, column }: SourcePosition): SourceOffset {\n    return this.source.offsetFor(line, column);\n  }\n\n  finish<T extends { loc: SourceSpan }>(node: ParserNodeBuilder<T>): T {\n    return (assign({}, node, {\n      loc: node.loc.until(this.offset()),\n    } as const) as unknown) as T;\n\n    // node.loc = node.loc.withEnd(end);\n  }\n\n  abstract Program(node: HBS.Program): HBS.Output<'Program'>;\n  abstract MustacheStatement(node: HBS.MustacheStatement): HBS.Output<'MustacheStatement'>;\n  abstract Decorator(node: HBS.Decorator): HBS.Output<'Decorator'>;\n  abstract BlockStatement(node: HBS.BlockStatement): HBS.Output<'BlockStatement'>;\n  abstract DecoratorBlock(node: HBS.DecoratorBlock): HBS.Output<'DecoratorBlock'>;\n  abstract PartialStatement(node: HBS.PartialStatement): HBS.Output<'PartialStatement'>;\n  abstract PartialBlockStatement(\n    node: HBS.PartialBlockStatement\n  ): HBS.Output<'PartialBlockStatement'>;\n  abstract ContentStatement(node: HBS.ContentStatement): HBS.Output<'ContentStatement'>;\n  abstract CommentStatement(node: HBS.CommentStatement): HBS.Output<'CommentStatement'>;\n  abstract SubExpression(node: HBS.SubExpression): HBS.Output<'SubExpression'>;\n  abstract PathExpression(node: HBS.PathExpression): HBS.Output<'PathExpression'>;\n  abstract StringLiteral(node: HBS.StringLiteral): HBS.Output<'StringLiteral'>;\n  abstract BooleanLiteral(node: HBS.BooleanLiteral): HBS.Output<'BooleanLiteral'>;\n  abstract NumberLiteral(node: HBS.NumberLiteral): HBS.Output<'NumberLiteral'>;\n  abstract UndefinedLiteral(node: HBS.UndefinedLiteral): HBS.Output<'UndefinedLiteral'>;\n  abstract NullLiteral(node: HBS.NullLiteral): HBS.Output<'NullLiteral'>;\n\n  abstract reset(): void;\n  abstract finishData(): void;\n  abstract tagOpen(): void;\n  abstract beginData(): void;\n  abstract appendToData(char: string): void;\n  abstract beginStartTag(): void;\n  abstract appendToTagName(char: string): void;\n  abstract beginAttribute(): void;\n  abstract appendToAttributeName(char: string): void;\n  abstract beginAttributeValue(quoted: boolean): void;\n  abstract appendToAttributeValue(char: string): void;\n  abstract finishAttributeValue(): void;\n  abstract markTagAsSelfClosing(): void;\n  abstract beginEndTag(): void;\n  abstract finishTag(): void;\n  abstract beginComment(): void;\n  abstract appendToCommentData(char: string): void;\n  abstract finishComment(): void;\n  abstract reportSyntaxError(error: string): void;\n\n  get currentAttr(): Attribute {\n    return expect(this.currentAttribute, 'expected attribute');\n  }\n\n  get currentTag(): ParserNodeBuilder<Tag<'StartTag' | 'EndTag'>> {\n    let node = this.currentNode;\n    assert(node && (node.type === 'StartTag' || node.type === 'EndTag'), 'expected tag');\n    return node;\n  }\n\n  get currentStartTag(): ParserNodeBuilder<Tag<'StartTag'>> {\n    let node = this.currentNode;\n    assert(node && node.type === 'StartTag', 'expected start tag');\n    return node;\n  }\n\n  get currentEndTag(): ParserNodeBuilder<Tag<'EndTag'>> {\n    let node = this.currentNode;\n    assert(node && node.type === 'EndTag', 'expected end tag');\n    return node;\n  }\n\n  get currentComment(): ParserNodeBuilder<ASTv1.CommentStatement> {\n    let node = this.currentNode;\n    assert(node && node.type === 'CommentStatement', 'expected a comment');\n    return node;\n  }\n\n  get currentData(): ASTv1.TextNode {\n    let node = this.currentNode;\n    assert(node && node.type === 'TextNode', 'expected a text node');\n    return node;\n  }\n\n  acceptTemplate(node: HBS.Program): ASTv1.Template {\n    return this[node.type as 'Program'](node) as ASTv1.Template;\n  }\n\n  acceptNode(node: HBS.Program): ASTv1.Block | ASTv1.Template;\n  acceptNode<U extends HBS.Node | ASTv1.Node>(node: HBS.Node): U;\n  acceptNode<T extends HBS.NodeType>(node: HBS.Node<T>): HBS.Output<T> {\n    return (this[node.type as T] as (node: HBS.Node<T>) => HBS.Output<T>)(node);\n  }\n\n  currentElement(): Element {\n    return this.elementStack[this.elementStack.length - 1];\n  }\n\n  sourceForNode(node: HBS.Node, endNode?: { loc: HBS.SourceLocation }): string {\n    let firstLine = node.loc.start.line - 1;\n    let currentLine = firstLine - 1;\n    let firstColumn = node.loc.start.column;\n    let string = [];\n    let line;\n\n    let lastLine: number;\n    let lastColumn: number;\n\n    if (endNode) {\n      lastLine = endNode.loc.end.line - 1;\n      lastColumn = endNode.loc.end.column;\n    } else {\n      lastLine = node.loc.end.line - 1;\n      lastColumn = node.loc.end.column;\n    }\n\n    while (currentLine < lastLine) {\n      currentLine++;\n      line = this.lines[currentLine];\n\n      if (currentLine === firstLine) {\n        if (firstLine === lastLine) {\n          string.push(line.slice(firstColumn, lastColumn));\n        } else {\n          string.push(line.slice(firstColumn));\n        }\n      } else if (currentLine === lastLine) {\n        string.push(line.slice(0, lastColumn));\n      } else {\n        string.push(line);\n      }\n    }\n\n    return string.join('\\n');\n  }\n}\n"],"sourceRoot":""} |
\ | No newline at end of file |