@angular/compiler 18.2.0 → 18.2.2
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 +1 -1
- package/esm2022/src/i18n/digest.mjs +18 -8
- package/esm2022/src/i18n/extractor_merger.mjs +10 -5
- package/esm2022/src/i18n/i18n_html_parser.mjs +2 -2
- package/esm2022/src/i18n/i18n_parser.mjs +34 -6
- package/esm2022/src/i18n/message_bundle.mjs +14 -5
- package/esm2022/src/i18n/serializers/xliff2.mjs +2 -2
- package/esm2022/src/i18n/serializers/xmb.mjs +8 -4
- package/esm2022/src/i18n/serializers/xtb.mjs +2 -2
- package/esm2022/src/ml_parser/html_whitespaces.mjs +102 -12
- package/esm2022/src/render3/partial/class_metadata.mjs +2 -2
- package/esm2022/src/render3/partial/directive.mjs +1 -1
- package/esm2022/src/render3/partial/factory.mjs +1 -1
- package/esm2022/src/render3/partial/injectable.mjs +1 -1
- package/esm2022/src/render3/partial/injector.mjs +1 -1
- package/esm2022/src/render3/partial/ng_module.mjs +1 -1
- package/esm2022/src/render3/partial/pipe.mjs +1 -1
- package/esm2022/src/render3/view/i18n/meta.mjs +56 -17
- package/esm2022/src/render3/view/t2_binder.mjs +65 -1
- package/esm2022/src/render3/view/template.mjs +28 -4
- package/esm2022/src/version.mjs +1 -1
- package/fesm2022/compiler.mjs +4742 -4473
- package/fesm2022/compiler.mjs.map +1 -1
- package/index.d.ts +35 -3
- package/package.json +2 -2
|
@@ -52,12 +52,18 @@ export function parseTemplate(template, templateUrl, options = {}) {
|
|
|
52
52
|
return parsedTemplate;
|
|
53
53
|
}
|
|
54
54
|
let rootNodes = parseResult.rootNodes;
|
|
55
|
+
// We need to use the same `retainEmptyTokens` value for both parses to avoid
|
|
56
|
+
// causing a mismatch when reusing source spans, even if the
|
|
57
|
+
// `preserveSignificantWhitespace` behavior is different between the two
|
|
58
|
+
// parses.
|
|
59
|
+
const retainEmptyTokens = !(options.preserveSignificantWhitespace ?? true);
|
|
55
60
|
// process i18n meta information (scan attributes, generate ids)
|
|
56
61
|
// before we run whitespace removal process, because existing i18n
|
|
57
62
|
// extraction process (ng extract-i18n) relies on a raw content to generate
|
|
58
63
|
// message ids
|
|
59
64
|
const i18nMetaVisitor = new I18nMetaVisitor(interpolationConfig,
|
|
60
|
-
/* keepI18nAttrs */ !preserveWhitespaces, enableI18nLegacyMessageIdFormat
|
|
65
|
+
/* keepI18nAttrs */ !preserveWhitespaces, enableI18nLegacyMessageIdFormat,
|
|
66
|
+
/* containerBlocks */ undefined, options.preserveSignificantWhitespace, retainEmptyTokens);
|
|
61
67
|
const i18nMetaResult = i18nMetaVisitor.visitAllWithErrors(rootNodes);
|
|
62
68
|
if (!options.alwaysAttemptHtmlToR3AstConversion &&
|
|
63
69
|
i18nMetaResult.errors &&
|
|
@@ -78,13 +84,31 @@ export function parseTemplate(template, templateUrl, options = {}) {
|
|
|
78
84
|
}
|
|
79
85
|
rootNodes = i18nMetaResult.rootNodes;
|
|
80
86
|
if (!preserveWhitespaces) {
|
|
81
|
-
|
|
87
|
+
// Always preserve significant whitespace here because this is used to generate the `goog.getMsg`
|
|
88
|
+
// and `$localize` calls which should retain significant whitespace in order to render the
|
|
89
|
+
// correct output. We let this diverge from the message IDs generated earlier which might not
|
|
90
|
+
// have preserved significant whitespace.
|
|
91
|
+
//
|
|
92
|
+
// This should use `visitAllWithSiblings` to set `WhitespaceVisitor` context correctly, however
|
|
93
|
+
// there is an existing bug where significant whitespace is not properly retained in the JS
|
|
94
|
+
// output of leading/trailing whitespace for ICU messages due to the existing lack of context\
|
|
95
|
+
// in `WhitespaceVisitor`. Using `visitAllWithSiblings` here would fix that bug and retain the
|
|
96
|
+
// whitespace, however it would also change the runtime representation which we don't want to do
|
|
97
|
+
// right now.
|
|
98
|
+
rootNodes = html.visitAll(new WhitespaceVisitor(
|
|
99
|
+
/* preserveSignificantWhitespace */ true,
|
|
100
|
+
/* originalNodeMap */ undefined,
|
|
101
|
+
/* requireContext */ false), rootNodes);
|
|
82
102
|
// run i18n meta visitor again in case whitespaces are removed (because that might affect
|
|
83
103
|
// generated i18n message content) and first pass indicated that i18n content is present in a
|
|
84
104
|
// template. During this pass i18n IDs generated at the first pass will be preserved, so we can
|
|
85
105
|
// mimic existing extraction process (ng extract-i18n)
|
|
86
106
|
if (i18nMetaVisitor.hasI18nMeta) {
|
|
87
|
-
rootNodes = html.visitAll(new I18nMetaVisitor(interpolationConfig,
|
|
107
|
+
rootNodes = html.visitAll(new I18nMetaVisitor(interpolationConfig,
|
|
108
|
+
/* keepI18nAttrs */ false,
|
|
109
|
+
/* enableI18nLegacyMessageIdFormat */ undefined,
|
|
110
|
+
/* containerBlocks */ undefined,
|
|
111
|
+
/* preserveSignificantWhitespace */ true, retainEmptyTokens), rootNodes);
|
|
88
112
|
}
|
|
89
113
|
}
|
|
90
114
|
const { nodes, errors, styleUrls, styles, ngContentSelectors, commentNodes } = htmlAstToRender3Ast(rootNodes, bindingParser, { collectCommentNodes: !!options.collectCommentNodes });
|
|
@@ -110,4 +134,4 @@ const elementRegistry = new DomElementSchemaRegistry();
|
|
|
110
134
|
export function makeBindingParser(interpolationConfig = DEFAULT_INTERPOLATION_CONFIG, allowInvalidAssignmentEvents = false) {
|
|
111
135
|
return new BindingParser(new Parser(new Lexer()), interpolationConfig, elementRegistry, [], allowInvalidAssignmentEvents);
|
|
112
136
|
}
|
|
113
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"template.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler/src/render3/view/template.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAC,KAAK,EAAC,MAAM,+BAA+B,CAAC;AACpD,OAAO,EAAC,MAAM,EAAC,MAAM,gCAAgC,CAAC;AACtD,OAAO,KAAK,IAAI,MAAM,qBAAqB,CAAC;AAC5C,OAAO,EAAC,4BAA4B,EAAsB,MAAM,0BAA0B,CAAC;AAC3F,OAAO,EAAC,UAAU,EAAC,MAAM,6BAA6B,CAAC;AACvD,OAAO,EAAC,iBAAiB,EAAC,MAAM,kCAAkC,CAAC;AAGnE,OAAO,EAAC,wBAAwB,EAAC,MAAM,0CAA0C,CAAC;AAClF,OAAO,EAAC,aAAa,EAAC,MAAM,sCAAsC,CAAC;AAEnE,OAAO,EAAC,mBAAmB,EAAC,MAAM,0BAA0B,CAAC;AAE7D,OAAO,EAAC,eAAe,EAAC,MAAM,aAAa,CAAC;AAE5C,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAC,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;AAmH5D;;;;;;GAMG;AACH,MAAM,UAAU,aAAa,CAC3B,QAAgB,EAChB,WAAmB,EACnB,UAAgC,EAAE;IAElC,MAAM,EACJ,mBAAmB,EACnB,mBAAmB,EACnB,+BAA+B,EAC/B,4BAA4B,GAC7B,GAAG,OAAO,CAAC;IACZ,MAAM,aAAa,GAAG,iBAAiB,CAAC,mBAAmB,EAAE,4BAA4B,CAAC,CAAC;IAC3F,MAAM,UAAU,GAAG,IAAI,UAAU,EAAE,CAAC;IACpC,MAAM,WAAW,GAAG,UAAU,CAAC,KAAK,CAAC,QAAQ,EAAE,WAAW,EAAE;QAC1D,kBAAkB,EAAE,oBAAoB;QACxC,GAAG,OAAO;QACV,sBAAsB,EAAE,IAAI;QAC5B,cAAc,EAAE,OAAO,CAAC,iBAAiB,IAAI,IAAI;QACjD,WAAW,EAAE,OAAO,CAAC,eAAe,IAAI,IAAI;KAC7C,CAAC,CAAC;IAEH,IACE,CAAC,OAAO,CAAC,kCAAkC;QAC3C,WAAW,CAAC,MAAM;QAClB,WAAW,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAC7B,CAAC;QACD,MAAM,cAAc,GAAmB;YACrC,mBAAmB;YACnB,mBAAmB;YACnB,MAAM,EAAE,WAAW,CAAC,MAAM;YAC1B,KAAK,EAAE,EAAE;YACT,SAAS,EAAE,EAAE;YACb,MAAM,EAAE,EAAE;YACV,kBAAkB,EAAE,EAAE;SACvB,CAAC;QACF,IAAI,OAAO,CAAC,mBAAmB,EAAE,CAAC;YAChC,cAAc,CAAC,YAAY,GAAG,EAAE,CAAC;QACnC,CAAC;QACD,OAAO,cAAc,CAAC;IACxB,CAAC;IAED,IAAI,SAAS,GAAgB,WAAW,CAAC,SAAS,CAAC;IAEnD,gEAAgE;IAChE,kEAAkE;IAClE,2EAA2E;IAC3E,cAAc;IACd,MAAM,eAAe,GAAG,IAAI,eAAe,CACzC,mBAAmB;IACnB,mBAAmB,CAAC,CAAC,mBAAmB,EACxC,+BAA+B,CAChC,CAAC;IACF,MAAM,cAAc,GAAG,eAAe,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC;IAErE,IACE,CAAC,OAAO,CAAC,kCAAkC;QAC3C,cAAc,CAAC,MAAM;QACrB,cAAc,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAChC,CAAC;QACD,MAAM,cAAc,GAAmB;YACrC,mBAAmB;YACnB,mBAAmB;YACnB,MAAM,EAAE,cAAc,CAAC,MAAM;YAC7B,KAAK,EAAE,EAAE;YACT,SAAS,EAAE,EAAE;YACb,MAAM,EAAE,EAAE;YACV,kBAAkB,EAAE,EAAE;SACvB,CAAC;QACF,IAAI,OAAO,CAAC,mBAAmB,EAAE,CAAC;YAChC,cAAc,CAAC,YAAY,GAAG,EAAE,CAAC;QACnC,CAAC;QACD,OAAO,cAAc,CAAC;IACxB,CAAC;IAED,SAAS,GAAG,cAAc,CAAC,SAAS,CAAC;IAErC,IAAI,CAAC,mBAAmB,EAAE,CAAC;QACzB,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,iBAAiB,EAAE,EAAE,SAAS,CAAC,CAAC;QAE9D,yFAAyF;QACzF,6FAA6F;QAC7F,+FAA+F;QAC/F,sDAAsD;QACtD,IAAI,eAAe,CAAC,WAAW,EAAE,CAAC;YAChC,SAAS,GAAG,IAAI,CAAC,QAAQ,CACvB,IAAI,eAAe,CAAC,mBAAmB,EAAE,mBAAmB,CAAC,KAAK,CAAC,EACnE,SAAS,CACV,CAAC;QACJ,CAAC;IACH,CAAC;IAED,MAAM,EAAC,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,kBAAkB,EAAE,YAAY,EAAC,GAAG,mBAAmB,CAC9F,SAAS,EACT,aAAa,EACb,EAAC,mBAAmB,EAAE,CAAC,CAAC,OAAO,CAAC,mBAAmB,EAAC,CACrD,CAAC;IACF,MAAM,CAAC,IAAI,CAAC,GAAG,WAAW,CAAC,MAAM,EAAE,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC;IAE7D,MAAM,cAAc,GAAmB;QACrC,mBAAmB;QACnB,mBAAmB;QACnB,MAAM,EAAE,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI;QACzC,KAAK;QACL,SAAS;QACT,MAAM;QACN,kBAAkB;KACnB,CAAC;IAEF,IAAI,OAAO,CAAC,mBAAmB,EAAE,CAAC;QAChC,cAAc,CAAC,YAAY,GAAG,YAAY,CAAC;IAC7C,CAAC;IACD,OAAO,cAAc,CAAC;AACxB,CAAC;AAED,MAAM,eAAe,GAAG,IAAI,wBAAwB,EAAE,CAAC;AAEvD;;GAEG;AACH,MAAM,UAAU,iBAAiB,CAC/B,sBAA2C,4BAA4B,EACvE,4BAA4B,GAAG,KAAK;IAEpC,OAAO,IAAI,aAAa,CACtB,IAAI,MAAM,CAAC,IAAI,KAAK,EAAE,CAAC,EACvB,mBAAmB,EACnB,eAAe,EACf,EAAE,EACF,4BAA4B,CAC7B,CAAC;AACJ,CAAC","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {Lexer} from '../../expression_parser/lexer';\nimport {Parser} from '../../expression_parser/parser';\nimport * as html from '../../ml_parser/ast';\nimport {DEFAULT_INTERPOLATION_CONFIG, InterpolationConfig} from '../../ml_parser/defaults';\nimport {HtmlParser} from '../../ml_parser/html_parser';\nimport {WhitespaceVisitor} from '../../ml_parser/html_whitespaces';\nimport {LexerRange} from '../../ml_parser/lexer';\nimport {ParseError} from '../../parse_util';\nimport {DomElementSchemaRegistry} from '../../schema/dom_element_schema_registry';\nimport {BindingParser} from '../../template_parser/binding_parser';\nimport * as t from '../r3_ast';\nimport {htmlAstToRender3Ast} from '../r3_template_transform';\n\nimport {I18nMetaVisitor} from './i18n/meta';\n\nexport const LEADING_TRIVIA_CHARS = [' ', '\\n', '\\r', '\\t'];\n\n/**\n * Options that can be used to modify how a template is parsed by `parseTemplate()`.\n */\nexport interface ParseTemplateOptions {\n  /**\n   * Include whitespace nodes in the parsed output.\n   */\n  preserveWhitespaces?: boolean;\n  /**\n   * Preserve original line endings instead of normalizing '\\r\\n' endings to '\\n'.\n   */\n  preserveLineEndings?: boolean;\n  /**\n   * How to parse interpolation markers.\n   */\n  interpolationConfig?: InterpolationConfig;\n  /**\n   * The start and end point of the text to parse within the `source` string.\n   * The entire `source` string is parsed if this is not provided.\n   * */\n  range?: LexerRange;\n  /**\n   * If this text is stored in a JavaScript string, then we have to deal with escape sequences.\n   *\n   * **Example 1:**\n   *\n   * ```\n   * \"abc\\\"def\\nghi\"\n   * ```\n   *\n   * - The `\\\"` must be converted to `\"`.\n   * - The `\\n` must be converted to a new line character in a token,\n   *   but it should not increment the current line for source mapping.\n   *\n   * **Example 2:**\n   *\n   * ```\n   * \"abc\\\n   *  def\"\n   * ```\n   *\n   * The line continuation (`\\` followed by a newline) should be removed from a token\n   * but the new line should increment the current line for source mapping.\n   */\n  escapedString?: boolean;\n  /**\n   * An array of characters that should be considered as leading trivia.\n   * Leading trivia are characters that are not important to the developer, and so should not be\n   * included in source-map segments.  A common example is whitespace.\n   */\n  leadingTriviaChars?: string[];\n\n  /**\n   * Render `$localize` message ids with additional legacy message ids.\n   *\n   * This option defaults to `true` but in the future the default will be flipped.\n   *\n   * For now set this option to false if you have migrated the translation files to use the new\n   * `$localize` message id format and you are not using compile time translation merging.\n   */\n  enableI18nLegacyMessageIdFormat?: boolean;\n\n  /**\n   * If this text is stored in an external template (e.g. via `templateUrl`) then we need to decide\n   * whether or not to normalize the line-endings (from `\\r\\n` to `\\n`) when processing ICU\n   * expressions.\n   *\n   * If `true` then we will normalize ICU expression line endings.\n   * The default is `false`, but this will be switched in a future major release.\n   */\n  i18nNormalizeLineEndingsInICUs?: boolean;\n\n  /**\n   * Whether to always attempt to convert the parsed HTML AST to an R3 AST, despite HTML or i18n\n   * Meta parse errors.\n   *\n   *\n   * This option is useful in the context of the language service, where we want to get as much\n   * information as possible, despite any errors in the HTML. As an example, a user may be adding\n   * a new tag and expecting autocomplete on that tag. In this scenario, the HTML is in an errored\n   * state, as there is an incomplete open tag. However, we're still able to convert the HTML AST\n   * nodes to R3 AST nodes in order to provide information for the language service.\n   *\n   * Note that even when `true` the HTML parse and i18n errors are still appended to the errors\n   * output, but this is done after converting the HTML AST to R3 AST.\n   */\n  alwaysAttemptHtmlToR3AstConversion?: boolean;\n\n  /**\n   * Include HTML Comment nodes in a top-level comments array on the returned R3 AST.\n   *\n   * This option is required by tooling that needs to know the location of comment nodes within the\n   * AST. A concrete example is @angular-eslint which requires this in order to enable\n   * \"eslint-disable\" comments within HTML templates, which then allows users to turn off specific\n   * rules on a case by case basis, instead of for their whole project within a configuration file.\n   */\n  collectCommentNodes?: boolean;\n\n  /** Whether the @ block syntax is enabled. */\n  enableBlockSyntax?: boolean;\n\n  /** Whether the `@let` syntax is enabled. */\n  enableLetSyntax?: boolean;\n\n  // TODO(crisbeto): delete this option when the migration is deleted.\n  /**\n   * Whether the parser should allow invalid two-way bindings.\n   *\n   * This option is only present to support an automated migration away from the invalid syntax.\n   */\n  allowInvalidAssignmentEvents?: boolean;\n}\n\n/**\n * Parse a template into render3 `Node`s and additional metadata, with no other dependencies.\n *\n * @param template text of the template to parse\n * @param templateUrl URL to use for source mapping of the parsed template\n * @param options options to modify how the template is parsed\n */\nexport function parseTemplate(\n  template: string,\n  templateUrl: string,\n  options: ParseTemplateOptions = {},\n): ParsedTemplate {\n  const {\n    interpolationConfig,\n    preserveWhitespaces,\n    enableI18nLegacyMessageIdFormat,\n    allowInvalidAssignmentEvents,\n  } = options;\n  const bindingParser = makeBindingParser(interpolationConfig, allowInvalidAssignmentEvents);\n  const htmlParser = new HtmlParser();\n  const parseResult = htmlParser.parse(template, templateUrl, {\n    leadingTriviaChars: LEADING_TRIVIA_CHARS,\n    ...options,\n    tokenizeExpansionForms: true,\n    tokenizeBlocks: options.enableBlockSyntax ?? true,\n    tokenizeLet: options.enableLetSyntax ?? true,\n  });\n\n  if (\n    !options.alwaysAttemptHtmlToR3AstConversion &&\n    parseResult.errors &&\n    parseResult.errors.length > 0\n  ) {\n    const parsedTemplate: ParsedTemplate = {\n      interpolationConfig,\n      preserveWhitespaces,\n      errors: parseResult.errors,\n      nodes: [],\n      styleUrls: [],\n      styles: [],\n      ngContentSelectors: [],\n    };\n    if (options.collectCommentNodes) {\n      parsedTemplate.commentNodes = [];\n    }\n    return parsedTemplate;\n  }\n\n  let rootNodes: html.Node[] = parseResult.rootNodes;\n\n  // process i18n meta information (scan attributes, generate ids)\n  // before we run whitespace removal process, because existing i18n\n  // extraction process (ng extract-i18n) relies on a raw content to generate\n  // message ids\n  const i18nMetaVisitor = new I18nMetaVisitor(\n    interpolationConfig,\n    /* keepI18nAttrs */ !preserveWhitespaces,\n    enableI18nLegacyMessageIdFormat,\n  );\n  const i18nMetaResult = i18nMetaVisitor.visitAllWithErrors(rootNodes);\n\n  if (\n    !options.alwaysAttemptHtmlToR3AstConversion &&\n    i18nMetaResult.errors &&\n    i18nMetaResult.errors.length > 0\n  ) {\n    const parsedTemplate: ParsedTemplate = {\n      interpolationConfig,\n      preserveWhitespaces,\n      errors: i18nMetaResult.errors,\n      nodes: [],\n      styleUrls: [],\n      styles: [],\n      ngContentSelectors: [],\n    };\n    if (options.collectCommentNodes) {\n      parsedTemplate.commentNodes = [];\n    }\n    return parsedTemplate;\n  }\n\n  rootNodes = i18nMetaResult.rootNodes;\n\n  if (!preserveWhitespaces) {\n    rootNodes = html.visitAll(new WhitespaceVisitor(), rootNodes);\n\n    // run i18n meta visitor again in case whitespaces are removed (because that might affect\n    // generated i18n message content) and first pass indicated that i18n content is present in a\n    // template. During this pass i18n IDs generated at the first pass will be preserved, so we can\n    // mimic existing extraction process (ng extract-i18n)\n    if (i18nMetaVisitor.hasI18nMeta) {\n      rootNodes = html.visitAll(\n        new I18nMetaVisitor(interpolationConfig, /* keepI18nAttrs */ false),\n        rootNodes,\n      );\n    }\n  }\n\n  const {nodes, errors, styleUrls, styles, ngContentSelectors, commentNodes} = htmlAstToRender3Ast(\n    rootNodes,\n    bindingParser,\n    {collectCommentNodes: !!options.collectCommentNodes},\n  );\n  errors.push(...parseResult.errors, ...i18nMetaResult.errors);\n\n  const parsedTemplate: ParsedTemplate = {\n    interpolationConfig,\n    preserveWhitespaces,\n    errors: errors.length > 0 ? errors : null,\n    nodes,\n    styleUrls,\n    styles,\n    ngContentSelectors,\n  };\n\n  if (options.collectCommentNodes) {\n    parsedTemplate.commentNodes = commentNodes;\n  }\n  return parsedTemplate;\n}\n\nconst elementRegistry = new DomElementSchemaRegistry();\n\n/**\n * Construct a `BindingParser` with a default configuration.\n */\nexport function makeBindingParser(\n  interpolationConfig: InterpolationConfig = DEFAULT_INTERPOLATION_CONFIG,\n  allowInvalidAssignmentEvents = false,\n): BindingParser {\n  return new BindingParser(\n    new Parser(new Lexer()),\n    interpolationConfig,\n    elementRegistry,\n    [],\n    allowInvalidAssignmentEvents,\n  );\n}\n\n/**\n * Information about the template which was extracted during parsing.\n *\n * This contains the actual parsed template as well as any metadata collected during its parsing,\n * some of which might be useful for re-parsing the template with different options.\n */\nexport interface ParsedTemplate {\n  /**\n   * Include whitespace nodes in the parsed output.\n   */\n  preserveWhitespaces?: boolean;\n\n  /**\n   * How to parse interpolation markers.\n   */\n  interpolationConfig?: InterpolationConfig;\n  /**\n   * Any errors from parsing the template the first time.\n   *\n   * `null` if there are no errors. Otherwise, the array of errors is guaranteed to be non-empty.\n   */\n  errors: ParseError[] | null;\n\n  /**\n   * The template AST, parsed from the template.\n   */\n  nodes: t.Node[];\n\n  /**\n   * Any styleUrls extracted from the metadata.\n   */\n  styleUrls: string[];\n\n  /**\n   * Any inline styles extracted from the metadata.\n   */\n  styles: string[];\n\n  /**\n   * Any ng-content selectors extracted from the template.\n   */\n  ngContentSelectors: string[];\n\n  /**\n   * Any R3 Comment Nodes extracted from the template when the `collectCommentNodes` parse template\n   * option is enabled.\n   */\n  commentNodes?: t.Comment[];\n}\n"]}
|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"template.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler/src/render3/view/template.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {Lexer} from '../../expression_parser/lexer';\nimport {Parser} from '../../expression_parser/parser';\nimport * as html from '../../ml_parser/ast';\nimport {DEFAULT_INTERPOLATION_CONFIG, InterpolationConfig} from '../../ml_parser/defaults';\nimport {HtmlParser} from '../../ml_parser/html_parser';\nimport {WhitespaceVisitor} from '../../ml_parser/html_whitespaces';\nimport {LexerRange} from '../../ml_parser/lexer';\nimport {ParseError} from '../../parse_util';\nimport {DomElementSchemaRegistry} from '../../schema/dom_element_schema_registry';\nimport {BindingParser} from '../../template_parser/binding_parser';\nimport * as t from '../r3_ast';\nimport {htmlAstToRender3Ast} from '../r3_template_transform';\n\nimport {I18nMetaVisitor} from './i18n/meta';\n\nexport const LEADING_TRIVIA_CHARS = [' ', '\\n', '\\r', '\\t'];\n\n/**\n * Options that can be used to modify how a template is parsed by `parseTemplate()`.\n */\nexport interface ParseTemplateOptions {\n  /**\n   * Include whitespace nodes in the parsed output.\n   */\n  preserveWhitespaces?: boolean;\n  /**\n   * Preserve original line endings instead of normalizing '\\r\\n' endings to '\\n'.\n   */\n  preserveLineEndings?: boolean;\n  /**\n   * Preserve whitespace significant to rendering.\n   */\n  preserveSignificantWhitespace?: boolean;\n  /**\n   * How to parse interpolation markers.\n   */\n  interpolationConfig?: InterpolationConfig;\n  /**\n   * The start and end point of the text to parse within the `source` string.\n   * The entire `source` string is parsed if this is not provided.\n   * */\n  range?: LexerRange;\n  /**\n   * If this text is stored in a JavaScript string, then we have to deal with escape sequences.\n   *\n   * **Example 1:**\n   *\n   * ```\n   * \"abc\\\"def\\nghi\"\n   * ```\n   *\n   * - The `\\\"` must be converted to `\"`.\n   * - The `\\n` must be converted to a new line character in a token,\n   *   but it should not increment the current line for source mapping.\n   *\n   * **Example 2:**\n   *\n   * ```\n   * \"abc\\\n   *  def\"\n   * ```\n   *\n   * The line continuation (`\\` followed by a newline) should be removed from a token\n   * but the new line should increment the current line for source mapping.\n   */\n  escapedString?: boolean;\n  /**\n   * An array of characters that should be considered as leading trivia.\n   * Leading trivia are characters that are not important to the developer, and so should not be\n   * included in source-map segments.  A common example is whitespace.\n   */\n  leadingTriviaChars?: string[];\n\n  /**\n   * Render `$localize` message ids with additional legacy message ids.\n   *\n   * This option defaults to `true` but in the future the default will be flipped.\n   *\n   * For now set this option to false if you have migrated the translation files to use the new\n   * `$localize` message id format and you are not using compile time translation merging.\n   */\n  enableI18nLegacyMessageIdFormat?: boolean;\n\n  /**\n   * If this text is stored in an external template (e.g. via `templateUrl`) then we need to decide\n   * whether or not to normalize the line-endings (from `\\r\\n` to `\\n`) when processing ICU\n   * expressions.\n   *\n   * If `true` then we will normalize ICU expression line endings.\n   * The default is `false`, but this will be switched in a future major release.\n   */\n  i18nNormalizeLineEndingsInICUs?: boolean;\n\n  /**\n   * Whether to always attempt to convert the parsed HTML AST to an R3 AST, despite HTML or i18n\n   * Meta parse errors.\n   *\n   *\n   * This option is useful in the context of the language service, where we want to get as much\n   * information as possible, despite any errors in the HTML. As an example, a user may be adding\n   * a new tag and expecting autocomplete on that tag. In this scenario, the HTML is in an errored\n   * state, as there is an incomplete open tag. However, we're still able to convert the HTML AST\n   * nodes to R3 AST nodes in order to provide information for the language service.\n   *\n   * Note that even when `true` the HTML parse and i18n errors are still appended to the errors\n   * output, but this is done after converting the HTML AST to R3 AST.\n   */\n  alwaysAttemptHtmlToR3AstConversion?: boolean;\n\n  /**\n   * Include HTML Comment nodes in a top-level comments array on the returned R3 AST.\n   *\n   * This option is required by tooling that needs to know the location of comment nodes within the\n   * AST. A concrete example is @angular-eslint which requires this in order to enable\n   * \"eslint-disable\" comments within HTML templates, which then allows users to turn off specific\n   * rules on a case by case basis, instead of for their whole project within a configuration file.\n   */\n  collectCommentNodes?: boolean;\n\n  /** Whether the @ block syntax is enabled. */\n  enableBlockSyntax?: boolean;\n\n  /** Whether the `@let` syntax is enabled. */\n  enableLetSyntax?: boolean;\n\n  // TODO(crisbeto): delete this option when the migration is deleted.\n  /**\n   * Whether the parser should allow invalid two-way bindings.\n   *\n   * This option is only present to support an automated migration away from the invalid syntax.\n   */\n  allowInvalidAssignmentEvents?: boolean;\n}\n\n/**\n * Parse a template into render3 `Node`s and additional metadata, with no other dependencies.\n *\n * @param template text of the template to parse\n * @param templateUrl URL to use for source mapping of the parsed template\n * @param options options to modify how the template is parsed\n */\nexport function parseTemplate(\n  template: string,\n  templateUrl: string,\n  options: ParseTemplateOptions = {},\n): ParsedTemplate {\n  const {\n    interpolationConfig,\n    preserveWhitespaces,\n    enableI18nLegacyMessageIdFormat,\n    allowInvalidAssignmentEvents,\n  } = options;\n  const bindingParser = makeBindingParser(interpolationConfig, allowInvalidAssignmentEvents);\n  const htmlParser = new HtmlParser();\n  const parseResult = htmlParser.parse(template, templateUrl, {\n    leadingTriviaChars: LEADING_TRIVIA_CHARS,\n    ...options,\n    tokenizeExpansionForms: true,\n    tokenizeBlocks: options.enableBlockSyntax ?? true,\n    tokenizeLet: options.enableLetSyntax ?? true,\n  });\n\n  if (\n    !options.alwaysAttemptHtmlToR3AstConversion &&\n    parseResult.errors &&\n    parseResult.errors.length > 0\n  ) {\n    const parsedTemplate: ParsedTemplate = {\n      interpolationConfig,\n      preserveWhitespaces,\n      errors: parseResult.errors,\n      nodes: [],\n      styleUrls: [],\n      styles: [],\n      ngContentSelectors: [],\n    };\n    if (options.collectCommentNodes) {\n      parsedTemplate.commentNodes = [];\n    }\n    return parsedTemplate;\n  }\n\n  let rootNodes: html.Node[] = parseResult.rootNodes;\n\n  // We need to use the same `retainEmptyTokens` value for both parses to avoid\n  // causing a mismatch when reusing source spans, even if the\n  // `preserveSignificantWhitespace` behavior is different between the two\n  // parses.\n  const retainEmptyTokens = !(options.preserveSignificantWhitespace ?? true);\n\n  // process i18n meta information (scan attributes, generate ids)\n  // before we run whitespace removal process, because existing i18n\n  // extraction process (ng extract-i18n) relies on a raw content to generate\n  // message ids\n  const i18nMetaVisitor = new I18nMetaVisitor(\n    interpolationConfig,\n    /* keepI18nAttrs */ !preserveWhitespaces,\n    enableI18nLegacyMessageIdFormat,\n    /* containerBlocks */ undefined,\n    options.preserveSignificantWhitespace,\n    retainEmptyTokens,\n  );\n  const i18nMetaResult = i18nMetaVisitor.visitAllWithErrors(rootNodes);\n\n  if (\n    !options.alwaysAttemptHtmlToR3AstConversion &&\n    i18nMetaResult.errors &&\n    i18nMetaResult.errors.length > 0\n  ) {\n    const parsedTemplate: ParsedTemplate = {\n      interpolationConfig,\n      preserveWhitespaces,\n      errors: i18nMetaResult.errors,\n      nodes: [],\n      styleUrls: [],\n      styles: [],\n      ngContentSelectors: [],\n    };\n    if (options.collectCommentNodes) {\n      parsedTemplate.commentNodes = [];\n    }\n    return parsedTemplate;\n  }\n\n  rootNodes = i18nMetaResult.rootNodes;\n\n  if (!preserveWhitespaces) {\n    // Always preserve significant whitespace here because this is used to generate the `goog.getMsg`\n    // and `$localize` calls which should retain significant whitespace in order to render the\n    // correct output. We let this diverge from the message IDs generated earlier which might not\n    // have preserved significant whitespace.\n    //\n    // This should use `visitAllWithSiblings` to set `WhitespaceVisitor` context correctly, however\n    // there is an existing bug where significant whitespace is not properly retained in the JS\n    // output of leading/trailing whitespace for ICU messages due to the existing lack of context\\\n    // in `WhitespaceVisitor`. Using `visitAllWithSiblings` here would fix that bug and retain the\n    // whitespace, however it would also change the runtime representation which we don't want to do\n    // right now.\n    rootNodes = html.visitAll(\n      new WhitespaceVisitor(\n        /* preserveSignificantWhitespace */ true,\n        /* originalNodeMap */ undefined,\n        /* requireContext */ false,\n      ),\n      rootNodes,\n    );\n\n    // run i18n meta visitor again in case whitespaces are removed (because that might affect\n    // generated i18n message content) and first pass indicated that i18n content is present in a\n    // template. During this pass i18n IDs generated at the first pass will be preserved, so we can\n    // mimic existing extraction process (ng extract-i18n)\n    if (i18nMetaVisitor.hasI18nMeta) {\n      rootNodes = html.visitAll(\n        new I18nMetaVisitor(\n          interpolationConfig,\n          /* keepI18nAttrs */ false,\n          /* enableI18nLegacyMessageIdFormat */ undefined,\n          /* containerBlocks */ undefined,\n          /* preserveSignificantWhitespace */ true,\n          retainEmptyTokens,\n        ),\n        rootNodes,\n      );\n    }\n  }\n\n  const {nodes, errors, styleUrls, styles, ngContentSelectors, commentNodes} = htmlAstToRender3Ast(\n    rootNodes,\n    bindingParser,\n    {collectCommentNodes: !!options.collectCommentNodes},\n  );\n  errors.push(...parseResult.errors, ...i18nMetaResult.errors);\n\n  const parsedTemplate: ParsedTemplate = {\n    interpolationConfig,\n    preserveWhitespaces,\n    errors: errors.length > 0 ? errors : null,\n    nodes,\n    styleUrls,\n    styles,\n    ngContentSelectors,\n  };\n\n  if (options.collectCommentNodes) {\n    parsedTemplate.commentNodes = commentNodes;\n  }\n  return parsedTemplate;\n}\n\nconst elementRegistry = new DomElementSchemaRegistry();\n\n/**\n * Construct a `BindingParser` with a default configuration.\n */\nexport function makeBindingParser(\n  interpolationConfig: InterpolationConfig = DEFAULT_INTERPOLATION_CONFIG,\n  allowInvalidAssignmentEvents = false,\n): BindingParser {\n  return new BindingParser(\n    new Parser(new Lexer()),\n    interpolationConfig,\n    elementRegistry,\n    [],\n    allowInvalidAssignmentEvents,\n  );\n}\n\n/**\n * Information about the template which was extracted during parsing.\n *\n * This contains the actual parsed template as well as any metadata collected during its parsing,\n * some of which might be useful for re-parsing the template with different options.\n */\nexport interface ParsedTemplate {\n  /**\n   * Include whitespace nodes in the parsed output.\n   */\n  preserveWhitespaces?: boolean;\n\n  /**\n   * How to parse interpolation markers.\n   */\n  interpolationConfig?: InterpolationConfig;\n  /**\n   * Any errors from parsing the template the first time.\n   *\n   * `null` if there are no errors. Otherwise, the array of errors is guaranteed to be non-empty.\n   */\n  errors: ParseError[] | null;\n\n  /**\n   * The template AST, parsed from the template.\n   */\n  nodes: t.Node[];\n\n  /**\n   * Any styleUrls extracted from the metadata.\n   */\n  styleUrls: string[];\n\n  /**\n   * Any inline styles extracted from the metadata.\n   */\n  styles: string[];\n\n  /**\n   * Any ng-content selectors extracted from the template.\n   */\n  ngContentSelectors: string[];\n\n  /**\n   * Any R3 Comment Nodes extracted from the template when the `collectCommentNodes` parse template\n   * option is enabled.\n   */\n  commentNodes?: t.Comment[];\n}\n"]}
|
package/esm2022/src/version.mjs
CHANGED
|
@@ -11,5 +11,5 @@
|
|
|
11
11
|
* Entry point for all public APIs of the compiler package.
|
|
12
12
|
*/
|
|
13
13
|
import { Version } from './util';
|
|
14
|
-
export const VERSION = new Version('18.2.
|
|
14
|
+
export const VERSION = new Version('18.2.2');
|
|
15
15
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbXBpbGVyL3NyYy92ZXJzaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7R0FNRztBQUVIOzs7O0dBSUc7QUFFSCxPQUFPLEVBQUMsT0FBTyxFQUFDLE1BQU0sUUFBUSxDQUFDO0FBRS9CLE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxJQUFJLE9BQU8sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbi8qKlxuICogQG1vZHVsZVxuICogQGRlc2NyaXB0aW9uXG4gKiBFbnRyeSBwb2ludCBmb3IgYWxsIHB1YmxpYyBBUElzIG9mIHRoZSBjb21waWxlciBwYWNrYWdlLlxuICovXG5cbmltcG9ydCB7VmVyc2lvbn0gZnJvbSAnLi91dGlsJztcblxuZXhwb3J0IGNvbnN0IFZFUlNJT04gPSBuZXcgVmVyc2lvbignMC4wLjAtUExBQ0VIT0xERVInKTtcbiJdfQ==
|