@angular/compiler 19.0.0-next.1 → 19.0.0-next.11

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.
Files changed (186) hide show
  1. package/LICENSE +21 -0
  2. package/fesm2022/compiler.mjs +5465 -4675
  3. package/fesm2022/compiler.mjs.map +1 -1
  4. package/index.d.ts +115 -15
  5. package/package.json +2 -4
  6. package/esm2022/compiler.mjs +0 -13
  7. package/esm2022/index.mjs +0 -13
  8. package/esm2022/public_api.mjs +0 -15
  9. package/esm2022/src/assertions.mjs +0 -31
  10. package/esm2022/src/chars.mjs +0 -90
  11. package/esm2022/src/compiler.mjs +0 -88
  12. package/esm2022/src/compiler_facade_interface.mjs +0 -29
  13. package/esm2022/src/config.mjs +0 -20
  14. package/esm2022/src/constant_pool.mjs +0 -285
  15. package/esm2022/src/core.mjs +0 -96
  16. package/esm2022/src/expression_parser/ast.mjs +0 -755
  17. package/esm2022/src/expression_parser/lexer.mjs +0 -421
  18. package/esm2022/src/expression_parser/parser.mjs +0 -1222
  19. package/esm2022/src/i18n/digest.mjs +0 -322
  20. package/esm2022/src/i18n/extractor_merger.mjs +0 -409
  21. package/esm2022/src/i18n/i18n_ast.mjs +0 -212
  22. package/esm2022/src/i18n/i18n_html_parser.mjs +0 -54
  23. package/esm2022/src/i18n/i18n_parser.mjs +0 -247
  24. package/esm2022/src/i18n/index.mjs +0 -16
  25. package/esm2022/src/i18n/message_bundle.mjs +0 -93
  26. package/esm2022/src/i18n/parse_util.mjs +0 -17
  27. package/esm2022/src/i18n/serializers/placeholder.mjs +0 -139
  28. package/esm2022/src/i18n/serializers/serializer.mjs +0 -77
  29. package/esm2022/src/i18n/serializers/xliff.mjs +0 -300
  30. package/esm2022/src/i18n/serializers/xliff2.mjs +0 -349
  31. package/esm2022/src/i18n/serializers/xmb.mjs +0 -188
  32. package/esm2022/src/i18n/serializers/xml_helper.mjs +0 -94
  33. package/esm2022/src/i18n/serializers/xtb.mjs +0 -186
  34. package/esm2022/src/i18n/translation_bundle.mjs +0 -164
  35. package/esm2022/src/injectable_compiler_2.mjs +0 -138
  36. package/esm2022/src/jit_compiler_facade.mjs +0 -681
  37. package/esm2022/src/ml_parser/ast.mjs +0 -167
  38. package/esm2022/src/ml_parser/defaults.mjs +0 -24
  39. package/esm2022/src/ml_parser/entities.mjs +0 -2144
  40. package/esm2022/src/ml_parser/html_parser.mjs +0 -18
  41. package/esm2022/src/ml_parser/html_tags.mjs +0 -156
  42. package/esm2022/src/ml_parser/html_whitespaces.mjs +0 -107
  43. package/esm2022/src/ml_parser/icu_ast_expander.mjs +0 -125
  44. package/esm2022/src/ml_parser/lexer.mjs +0 -1210
  45. package/esm2022/src/ml_parser/parser.mjs +0 -539
  46. package/esm2022/src/ml_parser/tags.mjs +0 -47
  47. package/esm2022/src/ml_parser/tokens.mjs +0 -9
  48. package/esm2022/src/ml_parser/xml_parser.mjs +0 -19
  49. package/esm2022/src/ml_parser/xml_tags.mjs +0 -32
  50. package/esm2022/src/output/abstract_emitter.mjs +0 -524
  51. package/esm2022/src/output/abstract_js_emitter.mjs +0 -130
  52. package/esm2022/src/output/map_util.mjs +0 -19
  53. package/esm2022/src/output/output_ast.mjs +0 -1301
  54. package/esm2022/src/output/output_jit.mjs +0 -138
  55. package/esm2022/src/output/output_jit_trusted_types.mjs +0 -100
  56. package/esm2022/src/output/source_map.mjs +0 -150
  57. package/esm2022/src/parse_util.mjs +0 -198
  58. package/esm2022/src/render3/partial/api.mjs +0 -9
  59. package/esm2022/src/render3/partial/class_metadata.mjs +0 -52
  60. package/esm2022/src/render3/partial/component.mjs +0 -197
  61. package/esm2022/src/render3/partial/directive.mjs +0 -264
  62. package/esm2022/src/render3/partial/factory.mjs +0 -35
  63. package/esm2022/src/render3/partial/injectable.mjs +0 -67
  64. package/esm2022/src/render3/partial/injector.mjs +0 -41
  65. package/esm2022/src/render3/partial/ng_module.mjs +0 -63
  66. package/esm2022/src/render3/partial/pipe.mjs +0 -50
  67. package/esm2022/src/render3/partial/util.mjs +0 -79
  68. package/esm2022/src/render3/r3_ast.mjs +0 -493
  69. package/esm2022/src/render3/r3_class_debug_info_compiler.mjs +0 -35
  70. package/esm2022/src/render3/r3_class_metadata_compiler.mjs +0 -92
  71. package/esm2022/src/render3/r3_control_flow.mjs +0 -421
  72. package/esm2022/src/render3/r3_deferred_blocks.mjs +0 -170
  73. package/esm2022/src/render3/r3_deferred_triggers.mjs +0 -316
  74. package/esm2022/src/render3/r3_factory.mjs +0 -200
  75. package/esm2022/src/render3/r3_identifiers.mjs +0 -480
  76. package/esm2022/src/render3/r3_injector_compiler.mjs +0 -28
  77. package/esm2022/src/render3/r3_jit.mjs +0 -29
  78. package/esm2022/src/render3/r3_module_compiler.mjs +0 -211
  79. package/esm2022/src/render3/r3_pipe_compiler.mjs +0 -35
  80. package/esm2022/src/render3/r3_template_transform.mjs +0 -560
  81. package/esm2022/src/render3/util.mjs +0 -90
  82. package/esm2022/src/render3/view/api.mjs +0 -14
  83. package/esm2022/src/render3/view/compiler.mjs +0 -546
  84. package/esm2022/src/render3/view/i18n/get_msg_utils.mjs +0 -113
  85. package/esm2022/src/render3/view/i18n/icu_serializer.mjs +0 -43
  86. package/esm2022/src/render3/view/i18n/localize_utils.mjs +0 -118
  87. package/esm2022/src/render3/view/i18n/meta.mjs +0 -259
  88. package/esm2022/src/render3/view/i18n/util.mjs +0 -70
  89. package/esm2022/src/render3/view/query_generation.mjs +0 -182
  90. package/esm2022/src/render3/view/t2_api.mjs +0 -9
  91. package/esm2022/src/render3/view/t2_binder.mjs +0 -823
  92. package/esm2022/src/render3/view/template.mjs +0 -113
  93. package/esm2022/src/render3/view/util.mjs +0 -192
  94. package/esm2022/src/resource_loader.mjs +0 -17
  95. package/esm2022/src/schema/dom_element_schema_registry.mjs +0 -471
  96. package/esm2022/src/schema/dom_security_schema.mjs +0 -96
  97. package/esm2022/src/schema/element_schema_registry.mjs +0 -10
  98. package/esm2022/src/schema/trusted_types_sinks.mjs +0 -41
  99. package/esm2022/src/selector.mjs +0 -400
  100. package/esm2022/src/shadow_css.mjs +0 -1053
  101. package/esm2022/src/style_url_resolver.mjs +0 -17
  102. package/esm2022/src/template/pipeline/ir/index.mjs +0 -18
  103. package/esm2022/src/template/pipeline/ir/src/enums.mjs +0 -503
  104. package/esm2022/src/template/pipeline/ir/src/expression.mjs +0 -997
  105. package/esm2022/src/template/pipeline/ir/src/handle.mjs +0 -13
  106. package/esm2022/src/template/pipeline/ir/src/operations.mjs +0 -261
  107. package/esm2022/src/template/pipeline/ir/src/ops/create.mjs +0 -405
  108. package/esm2022/src/template/pipeline/ir/src/ops/host.mjs +0 -25
  109. package/esm2022/src/template/pipeline/ir/src/ops/shared.mjs +0 -43
  110. package/esm2022/src/template/pipeline/ir/src/ops/update.mjs +0 -277
  111. package/esm2022/src/template/pipeline/ir/src/traits.mjs +0 -64
  112. package/esm2022/src/template/pipeline/ir/src/variable.mjs +0 -13
  113. package/esm2022/src/template/pipeline/src/compilation.mjs +0 -194
  114. package/esm2022/src/template/pipeline/src/conversion.mjs +0 -64
  115. package/esm2022/src/template/pipeline/src/emit.mjs +0 -238
  116. package/esm2022/src/template/pipeline/src/ingest.mjs +0 -1058
  117. package/esm2022/src/template/pipeline/src/instruction.mjs +0 -564
  118. package/esm2022/src/template/pipeline/src/phases/any_cast.mjs +0 -32
  119. package/esm2022/src/template/pipeline/src/phases/apply_i18n_expressions.mjs +0 -63
  120. package/esm2022/src/template/pipeline/src/phases/assign_i18n_slot_dependencies.mjs +0 -63
  121. package/esm2022/src/template/pipeline/src/phases/attribute_extraction.mjs +0 -138
  122. package/esm2022/src/template/pipeline/src/phases/binding_specialization.mjs +0 -75
  123. package/esm2022/src/template/pipeline/src/phases/chaining.mjs +0 -112
  124. package/esm2022/src/template/pipeline/src/phases/collapse_singleton_interpolations.mjs +0 -32
  125. package/esm2022/src/template/pipeline/src/phases/conditionals.mjs +0 -58
  126. package/esm2022/src/template/pipeline/src/phases/const_collection.mjs +0 -214
  127. package/esm2022/src/template/pipeline/src/phases/convert_i18n_bindings.mjs +0 -52
  128. package/esm2022/src/template/pipeline/src/phases/create_i18n_contexts.mjs +0 -105
  129. package/esm2022/src/template/pipeline/src/phases/deduplicate_text_bindings.mjs +0 -40
  130. package/esm2022/src/template/pipeline/src/phases/defer_configs.mjs +0 -29
  131. package/esm2022/src/template/pipeline/src/phases/defer_resolve_targets.mjs +0 -113
  132. package/esm2022/src/template/pipeline/src/phases/empty_elements.mjs +0 -47
  133. package/esm2022/src/template/pipeline/src/phases/expand_safe_reads.mjs +0 -192
  134. package/esm2022/src/template/pipeline/src/phases/extract_i18n_messages.mjs +0 -218
  135. package/esm2022/src/template/pipeline/src/phases/generate_advance.mjs +0 -66
  136. package/esm2022/src/template/pipeline/src/phases/generate_local_let_references.mjs +0 -29
  137. package/esm2022/src/template/pipeline/src/phases/generate_projection_def.mjs +0 -46
  138. package/esm2022/src/template/pipeline/src/phases/generate_variables.mjs +0 -170
  139. package/esm2022/src/template/pipeline/src/phases/has_const_expression_collection.mjs +0 -28
  140. package/esm2022/src/template/pipeline/src/phases/host_style_property_parsing.mjs +0 -81
  141. package/esm2022/src/template/pipeline/src/phases/i18n_const_collection.mjs +0 -309
  142. package/esm2022/src/template/pipeline/src/phases/i18n_text_extraction.mjs +0 -97
  143. package/esm2022/src/template/pipeline/src/phases/local_refs.mjs +0 -43
  144. package/esm2022/src/template/pipeline/src/phases/namespace.mjs +0 -26
  145. package/esm2022/src/template/pipeline/src/phases/naming.mjs +0 -179
  146. package/esm2022/src/template/pipeline/src/phases/next_context_merging.mjs +0 -75
  147. package/esm2022/src/template/pipeline/src/phases/ng_container.mjs +0 -29
  148. package/esm2022/src/template/pipeline/src/phases/nonbindable.mjs +0 -47
  149. package/esm2022/src/template/pipeline/src/phases/nullish_coalescing.mjs +0 -33
  150. package/esm2022/src/template/pipeline/src/phases/ordering.mjs +0 -140
  151. package/esm2022/src/template/pipeline/src/phases/parse_extracted_styles.mjs +0 -137
  152. package/esm2022/src/template/pipeline/src/phases/phase_remove_content_selectors.mjs +0 -42
  153. package/esm2022/src/template/pipeline/src/phases/pipe_creation.mjs +0 -74
  154. package/esm2022/src/template/pipeline/src/phases/pipe_variadic.mjs +0 -30
  155. package/esm2022/src/template/pipeline/src/phases/propagate_i18n_blocks.mjs +0 -81
  156. package/esm2022/src/template/pipeline/src/phases/pure_function_extraction.mjs +0 -55
  157. package/esm2022/src/template/pipeline/src/phases/pure_literal_structures.mjs +0 -58
  158. package/esm2022/src/template/pipeline/src/phases/reify.mjs +0 -433
  159. package/esm2022/src/template/pipeline/src/phases/remove_empty_bindings.mjs +0 -31
  160. package/esm2022/src/template/pipeline/src/phases/remove_i18n_contexts.mjs +0 -27
  161. package/esm2022/src/template/pipeline/src/phases/remove_illegal_let_references.mjs +0 -36
  162. package/esm2022/src/template/pipeline/src/phases/remove_unused_i18n_attrs.mjs +0 -33
  163. package/esm2022/src/template/pipeline/src/phases/resolve_contexts.mjs +0 -60
  164. package/esm2022/src/template/pipeline/src/phases/resolve_defer_deps_fns.mjs +0 -31
  165. package/esm2022/src/template/pipeline/src/phases/resolve_dollar_event.mjs +0 -36
  166. package/esm2022/src/template/pipeline/src/phases/resolve_i18n_element_placeholders.mjs +0 -266
  167. package/esm2022/src/template/pipeline/src/phases/resolve_i18n_expression_placeholders.mjs +0 -70
  168. package/esm2022/src/template/pipeline/src/phases/resolve_names.mjs +0 -124
  169. package/esm2022/src/template/pipeline/src/phases/resolve_sanitizers.mjs +0 -123
  170. package/esm2022/src/template/pipeline/src/phases/save_restore_view.mjs +0 -64
  171. package/esm2022/src/template/pipeline/src/phases/slot_allocation.mjs +0 -62
  172. package/esm2022/src/template/pipeline/src/phases/store_let_optimization.mjs +0 -35
  173. package/esm2022/src/template/pipeline/src/phases/style_binding_specialization.mjs +0 -42
  174. package/esm2022/src/template/pipeline/src/phases/temporary_variables.mjs +0 -87
  175. package/esm2022/src/template/pipeline/src/phases/track_fn_generation.mjs +0 -52
  176. package/esm2022/src/template/pipeline/src/phases/track_fn_optimization.mjs +0 -88
  177. package/esm2022/src/template/pipeline/src/phases/track_variables.mjs +0 -36
  178. package/esm2022/src/template/pipeline/src/phases/transform_two_way_binding_set.mjs +0 -43
  179. package/esm2022/src/template/pipeline/src/phases/var_counting.mjs +0 -155
  180. package/esm2022/src/template/pipeline/src/phases/variable_optimization.mjs +0 -423
  181. package/esm2022/src/template/pipeline/src/phases/wrap_icus.mjs +0 -41
  182. package/esm2022/src/template/pipeline/src/util/elements.mjs +0 -29
  183. package/esm2022/src/template_parser/binding_parser.mjs +0 -465
  184. package/esm2022/src/template_parser/template_preparser.mjs +0 -84
  185. package/esm2022/src/util.mjs +0 -124
  186. package/esm2022/src/version.mjs +0 -15
@@ -1,465 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright Google LLC All Rights Reserved.
4
- *
5
- * Use of this source code is governed by an MIT-style license that can be
6
- * found in the LICENSE file at https://angular.io/license
7
- */
8
- import { SecurityContext } from '../core';
9
- import { AbsoluteSourceSpan, ASTWithSource, Binary, BindingType, BoundElementProperty, Conditional, EmptyExpr, KeyedRead, NonNullAssert, ParsedEvent, ParsedEventType, ParsedProperty, ParsedPropertyType, ParsedVariable, PrefixNot, PropertyRead, RecursiveAstVisitor, VariableBinding, } from '../expression_parser/ast';
10
- import { mergeNsAndName } from '../ml_parser/tags';
11
- import { ParseError, ParseErrorLevel, ParseSourceSpan } from '../parse_util';
12
- import { CssSelector } from '../selector';
13
- import { splitAtColon, splitAtPeriod } from '../util';
14
- const PROPERTY_PARTS_SEPARATOR = '.';
15
- const ATTRIBUTE_PREFIX = 'attr';
16
- const CLASS_PREFIX = 'class';
17
- const STYLE_PREFIX = 'style';
18
- const TEMPLATE_ATTR_PREFIX = '*';
19
- const ANIMATE_PROP_PREFIX = 'animate-';
20
- /**
21
- * Parses bindings in templates and in the directive host area.
22
- */
23
- export class BindingParser {
24
- constructor(_exprParser, _interpolationConfig, _schemaRegistry, errors, _allowInvalidAssignmentEvents = false) {
25
- this._exprParser = _exprParser;
26
- this._interpolationConfig = _interpolationConfig;
27
- this._schemaRegistry = _schemaRegistry;
28
- this.errors = errors;
29
- this._allowInvalidAssignmentEvents = _allowInvalidAssignmentEvents;
30
- }
31
- get interpolationConfig() {
32
- return this._interpolationConfig;
33
- }
34
- createBoundHostProperties(properties, sourceSpan) {
35
- const boundProps = [];
36
- for (const propName of Object.keys(properties)) {
37
- const expression = properties[propName];
38
- if (typeof expression === 'string') {
39
- this.parsePropertyBinding(propName, expression, true, false, sourceSpan, sourceSpan.start.offset, undefined, [],
40
- // Use the `sourceSpan` for `keySpan`. This isn't really accurate, but neither is the
41
- // sourceSpan, as it represents the sourceSpan of the host itself rather than the
42
- // source of the host binding (which doesn't exist in the template). Regardless,
43
- // neither of these values are used in Ivy but are only here to satisfy the function
44
- // signature. This should likely be refactored in the future so that `sourceSpan`
45
- // isn't being used inaccurately.
46
- boundProps, sourceSpan);
47
- }
48
- else {
49
- this._reportError(`Value of the host property binding "${propName}" needs to be a string representing an expression but got "${expression}" (${typeof expression})`, sourceSpan);
50
- }
51
- }
52
- return boundProps;
53
- }
54
- createDirectiveHostEventAsts(hostListeners, sourceSpan) {
55
- const targetEvents = [];
56
- for (const propName of Object.keys(hostListeners)) {
57
- const expression = hostListeners[propName];
58
- if (typeof expression === 'string') {
59
- // Use the `sourceSpan` for `keySpan` and `handlerSpan`. This isn't really accurate, but
60
- // neither is the `sourceSpan`, as it represents the `sourceSpan` of the host itself
61
- // rather than the source of the host binding (which doesn't exist in the template).
62
- // Regardless, neither of these values are used in Ivy but are only here to satisfy the
63
- // function signature. This should likely be refactored in the future so that `sourceSpan`
64
- // isn't being used inaccurately.
65
- this.parseEvent(propName, expression,
66
- /* isAssignmentEvent */ false, sourceSpan, sourceSpan, [], targetEvents, sourceSpan);
67
- }
68
- else {
69
- this._reportError(`Value of the host listener "${propName}" needs to be a string representing an expression but got "${expression}" (${typeof expression})`, sourceSpan);
70
- }
71
- }
72
- return targetEvents;
73
- }
74
- parseInterpolation(value, sourceSpan, interpolatedTokens) {
75
- const sourceInfo = sourceSpan.start.toString();
76
- const absoluteOffset = sourceSpan.fullStart.offset;
77
- try {
78
- const ast = this._exprParser.parseInterpolation(value, sourceInfo, absoluteOffset, interpolatedTokens, this._interpolationConfig);
79
- if (ast)
80
- this._reportExpressionParserErrors(ast.errors, sourceSpan);
81
- return ast;
82
- }
83
- catch (e) {
84
- this._reportError(`${e}`, sourceSpan);
85
- return this._exprParser.wrapLiteralPrimitive('ERROR', sourceInfo, absoluteOffset);
86
- }
87
- }
88
- /**
89
- * Similar to `parseInterpolation`, but treats the provided string as a single expression
90
- * element that would normally appear within the interpolation prefix and suffix (`{{` and `}}`).
91
- * This is used for parsing the switch expression in ICUs.
92
- */
93
- parseInterpolationExpression(expression, sourceSpan) {
94
- const sourceInfo = sourceSpan.start.toString();
95
- const absoluteOffset = sourceSpan.start.offset;
96
- try {
97
- const ast = this._exprParser.parseInterpolationExpression(expression, sourceInfo, absoluteOffset);
98
- if (ast)
99
- this._reportExpressionParserErrors(ast.errors, sourceSpan);
100
- return ast;
101
- }
102
- catch (e) {
103
- this._reportError(`${e}`, sourceSpan);
104
- return this._exprParser.wrapLiteralPrimitive('ERROR', sourceInfo, absoluteOffset);
105
- }
106
- }
107
- /**
108
- * Parses the bindings in a microsyntax expression, and converts them to
109
- * `ParsedProperty` or `ParsedVariable`.
110
- *
111
- * @param tplKey template binding name
112
- * @param tplValue template binding value
113
- * @param sourceSpan span of template binding relative to entire the template
114
- * @param absoluteValueOffset start of the tplValue relative to the entire template
115
- * @param targetMatchableAttrs potential attributes to match in the template
116
- * @param targetProps target property bindings in the template
117
- * @param targetVars target variables in the template
118
- */
119
- parseInlineTemplateBinding(tplKey, tplValue, sourceSpan, absoluteValueOffset, targetMatchableAttrs, targetProps, targetVars, isIvyAst) {
120
- const absoluteKeyOffset = sourceSpan.start.offset + TEMPLATE_ATTR_PREFIX.length;
121
- const bindings = this._parseTemplateBindings(tplKey, tplValue, sourceSpan, absoluteKeyOffset, absoluteValueOffset);
122
- for (const binding of bindings) {
123
- // sourceSpan is for the entire HTML attribute. bindingSpan is for a particular
124
- // binding within the microsyntax expression so it's more narrow than sourceSpan.
125
- const bindingSpan = moveParseSourceSpan(sourceSpan, binding.sourceSpan);
126
- const key = binding.key.source;
127
- const keySpan = moveParseSourceSpan(sourceSpan, binding.key.span);
128
- if (binding instanceof VariableBinding) {
129
- const value = binding.value ? binding.value.source : '$implicit';
130
- const valueSpan = binding.value
131
- ? moveParseSourceSpan(sourceSpan, binding.value.span)
132
- : undefined;
133
- targetVars.push(new ParsedVariable(key, value, bindingSpan, keySpan, valueSpan));
134
- }
135
- else if (binding.value) {
136
- const srcSpan = isIvyAst ? bindingSpan : sourceSpan;
137
- const valueSpan = moveParseSourceSpan(sourceSpan, binding.value.ast.sourceSpan);
138
- this._parsePropertyAst(key, binding.value, false, srcSpan, keySpan, valueSpan, targetMatchableAttrs, targetProps);
139
- }
140
- else {
141
- targetMatchableAttrs.push([key, '' /* value */]);
142
- // Since this is a literal attribute with no RHS, source span should be
143
- // just the key span.
144
- this.parseLiteralAttr(key, null /* value */, keySpan, absoluteValueOffset, undefined /* valueSpan */, targetMatchableAttrs, targetProps, keySpan);
145
- }
146
- }
147
- }
148
- /**
149
- * Parses the bindings in a microsyntax expression, e.g.
150
- * ```
151
- * <tag *tplKey="let value1 = prop; let value2 = localVar">
152
- * ```
153
- *
154
- * @param tplKey template binding name
155
- * @param tplValue template binding value
156
- * @param sourceSpan span of template binding relative to entire the template
157
- * @param absoluteKeyOffset start of the `tplKey`
158
- * @param absoluteValueOffset start of the `tplValue`
159
- */
160
- _parseTemplateBindings(tplKey, tplValue, sourceSpan, absoluteKeyOffset, absoluteValueOffset) {
161
- const sourceInfo = sourceSpan.start.toString();
162
- try {
163
- const bindingsResult = this._exprParser.parseTemplateBindings(tplKey, tplValue, sourceInfo, absoluteKeyOffset, absoluteValueOffset);
164
- this._reportExpressionParserErrors(bindingsResult.errors, sourceSpan);
165
- bindingsResult.warnings.forEach((warning) => {
166
- this._reportError(warning, sourceSpan, ParseErrorLevel.WARNING);
167
- });
168
- return bindingsResult.templateBindings;
169
- }
170
- catch (e) {
171
- this._reportError(`${e}`, sourceSpan);
172
- return [];
173
- }
174
- }
175
- parseLiteralAttr(name, value, sourceSpan, absoluteOffset, valueSpan, targetMatchableAttrs, targetProps, keySpan) {
176
- if (isAnimationLabel(name)) {
177
- name = name.substring(1);
178
- if (keySpan !== undefined) {
179
- keySpan = moveParseSourceSpan(keySpan, new AbsoluteSourceSpan(keySpan.start.offset + 1, keySpan.end.offset));
180
- }
181
- if (value) {
182
- this._reportError(`Assigning animation triggers via @prop="exp" attributes with an expression is invalid.` +
183
- ` Use property bindings (e.g. [@prop]="exp") or use an attribute without a value (e.g. @prop) instead.`, sourceSpan, ParseErrorLevel.ERROR);
184
- }
185
- this._parseAnimation(name, value, sourceSpan, absoluteOffset, keySpan, valueSpan, targetMatchableAttrs, targetProps);
186
- }
187
- else {
188
- targetProps.push(new ParsedProperty(name, this._exprParser.wrapLiteralPrimitive(value, '', absoluteOffset), ParsedPropertyType.LITERAL_ATTR, sourceSpan, keySpan, valueSpan));
189
- }
190
- }
191
- parsePropertyBinding(name, expression, isHost, isPartOfAssignmentBinding, sourceSpan, absoluteOffset, valueSpan, targetMatchableAttrs, targetProps, keySpan) {
192
- if (name.length === 0) {
193
- this._reportError(`Property name is missing in binding`, sourceSpan);
194
- }
195
- let isAnimationProp = false;
196
- if (name.startsWith(ANIMATE_PROP_PREFIX)) {
197
- isAnimationProp = true;
198
- name = name.substring(ANIMATE_PROP_PREFIX.length);
199
- if (keySpan !== undefined) {
200
- keySpan = moveParseSourceSpan(keySpan, new AbsoluteSourceSpan(keySpan.start.offset + ANIMATE_PROP_PREFIX.length, keySpan.end.offset));
201
- }
202
- }
203
- else if (isAnimationLabel(name)) {
204
- isAnimationProp = true;
205
- name = name.substring(1);
206
- if (keySpan !== undefined) {
207
- keySpan = moveParseSourceSpan(keySpan, new AbsoluteSourceSpan(keySpan.start.offset + 1, keySpan.end.offset));
208
- }
209
- }
210
- if (isAnimationProp) {
211
- this._parseAnimation(name, expression, sourceSpan, absoluteOffset, keySpan, valueSpan, targetMatchableAttrs, targetProps);
212
- }
213
- else {
214
- this._parsePropertyAst(name, this.parseBinding(expression, isHost, valueSpan || sourceSpan, absoluteOffset), isPartOfAssignmentBinding, sourceSpan, keySpan, valueSpan, targetMatchableAttrs, targetProps);
215
- }
216
- }
217
- parsePropertyInterpolation(name, value, sourceSpan, valueSpan, targetMatchableAttrs, targetProps, keySpan, interpolatedTokens) {
218
- const expr = this.parseInterpolation(value, valueSpan || sourceSpan, interpolatedTokens);
219
- if (expr) {
220
- this._parsePropertyAst(name, expr, false, sourceSpan, keySpan, valueSpan, targetMatchableAttrs, targetProps);
221
- return true;
222
- }
223
- return false;
224
- }
225
- _parsePropertyAst(name, ast, isPartOfAssignmentBinding, sourceSpan, keySpan, valueSpan, targetMatchableAttrs, targetProps) {
226
- targetMatchableAttrs.push([name, ast.source]);
227
- targetProps.push(new ParsedProperty(name, ast, isPartOfAssignmentBinding ? ParsedPropertyType.TWO_WAY : ParsedPropertyType.DEFAULT, sourceSpan, keySpan, valueSpan));
228
- }
229
- _parseAnimation(name, expression, sourceSpan, absoluteOffset, keySpan, valueSpan, targetMatchableAttrs, targetProps) {
230
- if (name.length === 0) {
231
- this._reportError('Animation trigger is missing', sourceSpan);
232
- }
233
- // This will occur when a @trigger is not paired with an expression.
234
- // For animations it is valid to not have an expression since */void
235
- // states will be applied by angular when the element is attached/detached
236
- const ast = this.parseBinding(expression || 'undefined', false, valueSpan || sourceSpan, absoluteOffset);
237
- targetMatchableAttrs.push([name, ast.source]);
238
- targetProps.push(new ParsedProperty(name, ast, ParsedPropertyType.ANIMATION, sourceSpan, keySpan, valueSpan));
239
- }
240
- parseBinding(value, isHostBinding, sourceSpan, absoluteOffset) {
241
- const sourceInfo = ((sourceSpan && sourceSpan.start) || '(unknown)').toString();
242
- try {
243
- const ast = isHostBinding
244
- ? this._exprParser.parseSimpleBinding(value, sourceInfo, absoluteOffset, this._interpolationConfig)
245
- : this._exprParser.parseBinding(value, sourceInfo, absoluteOffset, this._interpolationConfig);
246
- if (ast)
247
- this._reportExpressionParserErrors(ast.errors, sourceSpan);
248
- return ast;
249
- }
250
- catch (e) {
251
- this._reportError(`${e}`, sourceSpan);
252
- return this._exprParser.wrapLiteralPrimitive('ERROR', sourceInfo, absoluteOffset);
253
- }
254
- }
255
- createBoundElementProperty(elementSelector, boundProp, skipValidation = false, mapPropertyName = true) {
256
- if (boundProp.isAnimation) {
257
- return new BoundElementProperty(boundProp.name, BindingType.Animation, SecurityContext.NONE, boundProp.expression, null, boundProp.sourceSpan, boundProp.keySpan, boundProp.valueSpan);
258
- }
259
- let unit = null;
260
- let bindingType = undefined;
261
- let boundPropertyName = null;
262
- const parts = boundProp.name.split(PROPERTY_PARTS_SEPARATOR);
263
- let securityContexts = undefined;
264
- // Check for special cases (prefix style, attr, class)
265
- if (parts.length > 1) {
266
- if (parts[0] == ATTRIBUTE_PREFIX) {
267
- boundPropertyName = parts.slice(1).join(PROPERTY_PARTS_SEPARATOR);
268
- if (!skipValidation) {
269
- this._validatePropertyOrAttributeName(boundPropertyName, boundProp.sourceSpan, true);
270
- }
271
- securityContexts = calcPossibleSecurityContexts(this._schemaRegistry, elementSelector, boundPropertyName, true);
272
- const nsSeparatorIdx = boundPropertyName.indexOf(':');
273
- if (nsSeparatorIdx > -1) {
274
- const ns = boundPropertyName.substring(0, nsSeparatorIdx);
275
- const name = boundPropertyName.substring(nsSeparatorIdx + 1);
276
- boundPropertyName = mergeNsAndName(ns, name);
277
- }
278
- bindingType = BindingType.Attribute;
279
- }
280
- else if (parts[0] == CLASS_PREFIX) {
281
- boundPropertyName = parts[1];
282
- bindingType = BindingType.Class;
283
- securityContexts = [SecurityContext.NONE];
284
- }
285
- else if (parts[0] == STYLE_PREFIX) {
286
- unit = parts.length > 2 ? parts[2] : null;
287
- boundPropertyName = parts[1];
288
- bindingType = BindingType.Style;
289
- securityContexts = [SecurityContext.STYLE];
290
- }
291
- }
292
- // If not a special case, use the full property name
293
- if (boundPropertyName === null) {
294
- const mappedPropName = this._schemaRegistry.getMappedPropName(boundProp.name);
295
- boundPropertyName = mapPropertyName ? mappedPropName : boundProp.name;
296
- securityContexts = calcPossibleSecurityContexts(this._schemaRegistry, elementSelector, mappedPropName, false);
297
- bindingType =
298
- boundProp.type === ParsedPropertyType.TWO_WAY ? BindingType.TwoWay : BindingType.Property;
299
- if (!skipValidation) {
300
- this._validatePropertyOrAttributeName(mappedPropName, boundProp.sourceSpan, false);
301
- }
302
- }
303
- return new BoundElementProperty(boundPropertyName, bindingType, securityContexts[0], boundProp.expression, unit, boundProp.sourceSpan, boundProp.keySpan, boundProp.valueSpan);
304
- }
305
- // TODO: keySpan should be required but was made optional to avoid changing VE parser.
306
- parseEvent(name, expression, isAssignmentEvent, sourceSpan, handlerSpan, targetMatchableAttrs, targetEvents, keySpan) {
307
- if (name.length === 0) {
308
- this._reportError(`Event name is missing in binding`, sourceSpan);
309
- }
310
- if (isAnimationLabel(name)) {
311
- name = name.slice(1);
312
- if (keySpan !== undefined) {
313
- keySpan = moveParseSourceSpan(keySpan, new AbsoluteSourceSpan(keySpan.start.offset + 1, keySpan.end.offset));
314
- }
315
- this._parseAnimationEvent(name, expression, sourceSpan, handlerSpan, targetEvents, keySpan);
316
- }
317
- else {
318
- this._parseRegularEvent(name, expression, isAssignmentEvent, sourceSpan, handlerSpan, targetMatchableAttrs, targetEvents, keySpan);
319
- }
320
- }
321
- calcPossibleSecurityContexts(selector, propName, isAttribute) {
322
- const prop = this._schemaRegistry.getMappedPropName(propName);
323
- return calcPossibleSecurityContexts(this._schemaRegistry, selector, prop, isAttribute);
324
- }
325
- _parseAnimationEvent(name, expression, sourceSpan, handlerSpan, targetEvents, keySpan) {
326
- const matches = splitAtPeriod(name, [name, '']);
327
- const eventName = matches[0];
328
- const phase = matches[1].toLowerCase();
329
- const ast = this._parseAction(expression, handlerSpan);
330
- targetEvents.push(new ParsedEvent(eventName, phase, ParsedEventType.Animation, ast, sourceSpan, handlerSpan, keySpan));
331
- if (eventName.length === 0) {
332
- this._reportError(`Animation event name is missing in binding`, sourceSpan);
333
- }
334
- if (phase) {
335
- if (phase !== 'start' && phase !== 'done') {
336
- this._reportError(`The provided animation output phase value "${phase}" for "@${eventName}" is not supported (use start or done)`, sourceSpan);
337
- }
338
- }
339
- else {
340
- this._reportError(`The animation trigger output event (@${eventName}) is missing its phase value name (start or done are currently supported)`, sourceSpan);
341
- }
342
- }
343
- _parseRegularEvent(name, expression, isAssignmentEvent, sourceSpan, handlerSpan, targetMatchableAttrs, targetEvents, keySpan) {
344
- // long format: 'target: eventName'
345
- const [target, eventName] = splitAtColon(name, [null, name]);
346
- const prevErrorCount = this.errors.length;
347
- const ast = this._parseAction(expression, handlerSpan);
348
- const isValid = this.errors.length === prevErrorCount;
349
- targetMatchableAttrs.push([name, ast.source]);
350
- // Don't try to validate assignment events if there were other
351
- // parsing errors to avoid adding more noise to the error logs.
352
- if (isAssignmentEvent && isValid && !this._isAllowedAssignmentEvent(ast)) {
353
- this._reportError('Unsupported expression in a two-way binding', sourceSpan);
354
- }
355
- targetEvents.push(new ParsedEvent(eventName, target, isAssignmentEvent ? ParsedEventType.TwoWay : ParsedEventType.Regular, ast, sourceSpan, handlerSpan, keySpan));
356
- // Don't detect directives for event names for now,
357
- // so don't add the event name to the matchableAttrs
358
- }
359
- _parseAction(value, sourceSpan) {
360
- const sourceInfo = ((sourceSpan && sourceSpan.start) || '(unknown').toString();
361
- const absoluteOffset = sourceSpan && sourceSpan.start ? sourceSpan.start.offset : 0;
362
- try {
363
- const ast = this._exprParser.parseAction(value, sourceInfo, absoluteOffset, this._interpolationConfig);
364
- if (ast) {
365
- this._reportExpressionParserErrors(ast.errors, sourceSpan);
366
- }
367
- if (!ast || ast.ast instanceof EmptyExpr) {
368
- this._reportError(`Empty expressions are not allowed`, sourceSpan);
369
- return this._exprParser.wrapLiteralPrimitive('ERROR', sourceInfo, absoluteOffset);
370
- }
371
- return ast;
372
- }
373
- catch (e) {
374
- this._reportError(`${e}`, sourceSpan);
375
- return this._exprParser.wrapLiteralPrimitive('ERROR', sourceInfo, absoluteOffset);
376
- }
377
- }
378
- _reportError(message, sourceSpan, level = ParseErrorLevel.ERROR) {
379
- this.errors.push(new ParseError(sourceSpan, message, level));
380
- }
381
- _reportExpressionParserErrors(errors, sourceSpan) {
382
- for (const error of errors) {
383
- this._reportError(error.message, sourceSpan);
384
- }
385
- }
386
- /**
387
- * @param propName the name of the property / attribute
388
- * @param sourceSpan
389
- * @param isAttr true when binding to an attribute
390
- */
391
- _validatePropertyOrAttributeName(propName, sourceSpan, isAttr) {
392
- const report = isAttr
393
- ? this._schemaRegistry.validateAttribute(propName)
394
- : this._schemaRegistry.validateProperty(propName);
395
- if (report.error) {
396
- this._reportError(report.msg, sourceSpan, ParseErrorLevel.ERROR);
397
- }
398
- }
399
- /**
400
- * Returns whether a parsed AST is allowed to be used within the event side of a two-way binding.
401
- * @param ast Parsed AST to be checked.
402
- */
403
- _isAllowedAssignmentEvent(ast) {
404
- if (ast instanceof ASTWithSource) {
405
- return this._isAllowedAssignmentEvent(ast.ast);
406
- }
407
- if (ast instanceof NonNullAssert) {
408
- return this._isAllowedAssignmentEvent(ast.expression);
409
- }
410
- if (ast instanceof PropertyRead || ast instanceof KeyedRead) {
411
- return true;
412
- }
413
- // TODO(crisbeto): this logic is only here to support the automated migration away
414
- // from invalid bindings. It should be removed once the migration is deleted.
415
- if (!this._allowInvalidAssignmentEvents) {
416
- return false;
417
- }
418
- if (ast instanceof Binary) {
419
- return ((ast.operation === '&&' || ast.operation === '||' || ast.operation === '??') &&
420
- (ast.right instanceof PropertyRead || ast.right instanceof KeyedRead));
421
- }
422
- return ast instanceof Conditional || ast instanceof PrefixNot;
423
- }
424
- }
425
- export class PipeCollector extends RecursiveAstVisitor {
426
- constructor() {
427
- super(...arguments);
428
- this.pipes = new Map();
429
- }
430
- visitPipe(ast, context) {
431
- this.pipes.set(ast.name, ast);
432
- ast.exp.visit(this);
433
- this.visitAll(ast.args, context);
434
- return null;
435
- }
436
- }
437
- function isAnimationLabel(name) {
438
- return name[0] == '@';
439
- }
440
- export function calcPossibleSecurityContexts(registry, selector, propName, isAttribute) {
441
- const ctxs = [];
442
- CssSelector.parse(selector).forEach((selector) => {
443
- const elementNames = selector.element ? [selector.element] : registry.allKnownElementNames();
444
- const notElementNames = new Set(selector.notSelectors
445
- .filter((selector) => selector.isElementSelector())
446
- .map((selector) => selector.element));
447
- const possibleElementNames = elementNames.filter((elementName) => !notElementNames.has(elementName));
448
- ctxs.push(...possibleElementNames.map((elementName) => registry.securityContext(elementName, propName, isAttribute)));
449
- });
450
- return ctxs.length === 0 ? [SecurityContext.NONE] : Array.from(new Set(ctxs)).sort();
451
- }
452
- /**
453
- * Compute a new ParseSourceSpan based off an original `sourceSpan` by using
454
- * absolute offsets from the specified `absoluteSpan`.
455
- *
456
- * @param sourceSpan original source span
457
- * @param absoluteSpan absolute source span to move to
458
- */
459
- function moveParseSourceSpan(sourceSpan, absoluteSpan) {
460
- // The difference of two absolute offsets provide the relative offset
461
- const startDiff = absoluteSpan.start - sourceSpan.start.offset;
462
- const endDiff = absoluteSpan.end - sourceSpan.end.offset;
463
- return new ParseSourceSpan(sourceSpan.start.moveBy(startDiff), sourceSpan.end.moveBy(endDiff), sourceSpan.fullStart.moveBy(startDiff), sourceSpan.details);
464
- }
465
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"binding_parser.js","sourceRoot":"","sources":["../../../../../../../packages/compiler/src/template_parser/binding_parser.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 {SecurityContext} from '../core';\nimport {\n  AbsoluteSourceSpan,\n  AST,\n  ASTWithSource,\n  Binary,\n  BindingPipe,\n  BindingType,\n  BoundElementProperty,\n  Conditional,\n  EmptyExpr,\n  KeyedRead,\n  NonNullAssert,\n  ParsedEvent,\n  ParsedEventType,\n  ParsedProperty,\n  ParsedPropertyType,\n  ParsedVariable,\n  ParserError,\n  PrefixNot,\n  PropertyRead,\n  RecursiveAstVisitor,\n  TemplateBinding,\n  VariableBinding,\n} from '../expression_parser/ast';\nimport {Parser} from '../expression_parser/parser';\nimport {InterpolationConfig} from '../ml_parser/defaults';\nimport {mergeNsAndName} from '../ml_parser/tags';\nimport {InterpolatedAttributeToken, InterpolatedTextToken} from '../ml_parser/tokens';\nimport {ParseError, ParseErrorLevel, ParseSourceSpan} from '../parse_util';\nimport {ElementSchemaRegistry} from '../schema/element_schema_registry';\nimport {CssSelector} from '../selector';\nimport {splitAtColon, splitAtPeriod} from '../util';\n\nconst PROPERTY_PARTS_SEPARATOR = '.';\nconst ATTRIBUTE_PREFIX = 'attr';\nconst CLASS_PREFIX = 'class';\nconst STYLE_PREFIX = 'style';\nconst TEMPLATE_ATTR_PREFIX = '*';\nconst ANIMATE_PROP_PREFIX = 'animate-';\n\nexport interface HostProperties {\n  [key: string]: string;\n}\n\nexport interface HostListeners {\n  [key: string]: string;\n}\n\n/**\n * Parses bindings in templates and in the directive host area.\n */\nexport class BindingParser {\n  constructor(\n    private _exprParser: Parser,\n    private _interpolationConfig: InterpolationConfig,\n    private _schemaRegistry: ElementSchemaRegistry,\n    public errors: ParseError[],\n    private _allowInvalidAssignmentEvents = false,\n  ) {}\n\n  get interpolationConfig(): InterpolationConfig {\n    return this._interpolationConfig;\n  }\n\n  createBoundHostProperties(\n    properties: HostProperties,\n    sourceSpan: ParseSourceSpan,\n  ): ParsedProperty[] | null {\n    const boundProps: ParsedProperty[] = [];\n    for (const propName of Object.keys(properties)) {\n      const expression = properties[propName];\n      if (typeof expression === 'string') {\n        this.parsePropertyBinding(\n          propName,\n          expression,\n          true,\n          false,\n          sourceSpan,\n          sourceSpan.start.offset,\n          undefined,\n          [],\n          // Use the `sourceSpan` for  `keySpan`. This isn't really accurate, but neither is the\n          // sourceSpan, as it represents the sourceSpan of the host itself rather than the\n          // source of the host binding (which doesn't exist in the template). Regardless,\n          // neither of these values are used in Ivy but are only here to satisfy the function\n          // signature. This should likely be refactored in the future so that `sourceSpan`\n          // isn't being used inaccurately.\n          boundProps,\n          sourceSpan,\n        );\n      } else {\n        this._reportError(\n          `Value of the host property binding \"${propName}\" needs to be a string representing an expression but got \"${expression}\" (${typeof expression})`,\n          sourceSpan,\n        );\n      }\n    }\n    return boundProps;\n  }\n\n  createDirectiveHostEventAsts(\n    hostListeners: HostListeners,\n    sourceSpan: ParseSourceSpan,\n  ): ParsedEvent[] | null {\n    const targetEvents: ParsedEvent[] = [];\n    for (const propName of Object.keys(hostListeners)) {\n      const expression = hostListeners[propName];\n      if (typeof expression === 'string') {\n        // Use the `sourceSpan` for  `keySpan` and `handlerSpan`. This isn't really accurate, but\n        // neither is the `sourceSpan`, as it represents the `sourceSpan` of the host itself\n        // rather than the source of the host binding (which doesn't exist in the template).\n        // Regardless, neither of these values are used in Ivy but are only here to satisfy the\n        // function signature. This should likely be refactored in the future so that `sourceSpan`\n        // isn't being used inaccurately.\n        this.parseEvent(\n          propName,\n          expression,\n          /* isAssignmentEvent */ false,\n          sourceSpan,\n          sourceSpan,\n          [],\n          targetEvents,\n          sourceSpan,\n        );\n      } else {\n        this._reportError(\n          `Value of the host listener \"${propName}\" needs to be a string representing an expression but got \"${expression}\" (${typeof expression})`,\n          sourceSpan,\n        );\n      }\n    }\n    return targetEvents;\n  }\n\n  parseInterpolation(\n    value: string,\n    sourceSpan: ParseSourceSpan,\n    interpolatedTokens: InterpolatedAttributeToken[] | InterpolatedTextToken[] | null,\n  ): ASTWithSource {\n    const sourceInfo = sourceSpan.start.toString();\n    const absoluteOffset = sourceSpan.fullStart.offset;\n\n    try {\n      const ast = this._exprParser.parseInterpolation(\n        value,\n        sourceInfo,\n        absoluteOffset,\n        interpolatedTokens,\n        this._interpolationConfig,\n      )!;\n      if (ast) this._reportExpressionParserErrors(ast.errors, sourceSpan);\n      return ast;\n    } catch (e) {\n      this._reportError(`${e}`, sourceSpan);\n      return this._exprParser.wrapLiteralPrimitive('ERROR', sourceInfo, absoluteOffset);\n    }\n  }\n\n  /**\n   * Similar to `parseInterpolation`, but treats the provided string as a single expression\n   * element that would normally appear within the interpolation prefix and suffix (`{{` and `}}`).\n   * This is used for parsing the switch expression in ICUs.\n   */\n  parseInterpolationExpression(expression: string, sourceSpan: ParseSourceSpan): ASTWithSource {\n    const sourceInfo = sourceSpan.start.toString();\n    const absoluteOffset = sourceSpan.start.offset;\n\n    try {\n      const ast = this._exprParser.parseInterpolationExpression(\n        expression,\n        sourceInfo,\n        absoluteOffset,\n      );\n      if (ast) this._reportExpressionParserErrors(ast.errors, sourceSpan);\n      return ast;\n    } catch (e) {\n      this._reportError(`${e}`, sourceSpan);\n      return this._exprParser.wrapLiteralPrimitive('ERROR', sourceInfo, absoluteOffset);\n    }\n  }\n\n  /**\n   * Parses the bindings in a microsyntax expression, and converts them to\n   * `ParsedProperty` or `ParsedVariable`.\n   *\n   * @param tplKey template binding name\n   * @param tplValue template binding value\n   * @param sourceSpan span of template binding relative to entire the template\n   * @param absoluteValueOffset start of the tplValue relative to the entire template\n   * @param targetMatchableAttrs potential attributes to match in the template\n   * @param targetProps target property bindings in the template\n   * @param targetVars target variables in the template\n   */\n  parseInlineTemplateBinding(\n    tplKey: string,\n    tplValue: string,\n    sourceSpan: ParseSourceSpan,\n    absoluteValueOffset: number,\n    targetMatchableAttrs: string[][],\n    targetProps: ParsedProperty[],\n    targetVars: ParsedVariable[],\n    isIvyAst: boolean,\n  ) {\n    const absoluteKeyOffset = sourceSpan.start.offset + TEMPLATE_ATTR_PREFIX.length;\n    const bindings = this._parseTemplateBindings(\n      tplKey,\n      tplValue,\n      sourceSpan,\n      absoluteKeyOffset,\n      absoluteValueOffset,\n    );\n\n    for (const binding of bindings) {\n      // sourceSpan is for the entire HTML attribute. bindingSpan is for a particular\n      // binding within the microsyntax expression so it's more narrow than sourceSpan.\n      const bindingSpan = moveParseSourceSpan(sourceSpan, binding.sourceSpan);\n      const key = binding.key.source;\n      const keySpan = moveParseSourceSpan(sourceSpan, binding.key.span);\n      if (binding instanceof VariableBinding) {\n        const value = binding.value ? binding.value.source : '$implicit';\n        const valueSpan = binding.value\n          ? moveParseSourceSpan(sourceSpan, binding.value.span)\n          : undefined;\n        targetVars.push(new ParsedVariable(key, value, bindingSpan, keySpan, valueSpan));\n      } else if (binding.value) {\n        const srcSpan = isIvyAst ? bindingSpan : sourceSpan;\n        const valueSpan = moveParseSourceSpan(sourceSpan, binding.value.ast.sourceSpan);\n        this._parsePropertyAst(\n          key,\n          binding.value,\n          false,\n          srcSpan,\n          keySpan,\n          valueSpan,\n          targetMatchableAttrs,\n          targetProps,\n        );\n      } else {\n        targetMatchableAttrs.push([key, '' /* value */]);\n        // Since this is a literal attribute with no RHS, source span should be\n        // just the key span.\n        this.parseLiteralAttr(\n          key,\n          null /* value */,\n          keySpan,\n          absoluteValueOffset,\n          undefined /* valueSpan */,\n          targetMatchableAttrs,\n          targetProps,\n          keySpan,\n        );\n      }\n    }\n  }\n\n  /**\n   * Parses the bindings in a microsyntax expression, e.g.\n   * ```\n   *    <tag *tplKey=\"let value1 = prop; let value2 = localVar\">\n   * ```\n   *\n   * @param tplKey template binding name\n   * @param tplValue template binding value\n   * @param sourceSpan span of template binding relative to entire the template\n   * @param absoluteKeyOffset start of the `tplKey`\n   * @param absoluteValueOffset start of the `tplValue`\n   */\n  private _parseTemplateBindings(\n    tplKey: string,\n    tplValue: string,\n    sourceSpan: ParseSourceSpan,\n    absoluteKeyOffset: number,\n    absoluteValueOffset: number,\n  ): TemplateBinding[] {\n    const sourceInfo = sourceSpan.start.toString();\n\n    try {\n      const bindingsResult = this._exprParser.parseTemplateBindings(\n        tplKey,\n        tplValue,\n        sourceInfo,\n        absoluteKeyOffset,\n        absoluteValueOffset,\n      );\n      this._reportExpressionParserErrors(bindingsResult.errors, sourceSpan);\n      bindingsResult.warnings.forEach((warning) => {\n        this._reportError(warning, sourceSpan, ParseErrorLevel.WARNING);\n      });\n      return bindingsResult.templateBindings;\n    } catch (e) {\n      this._reportError(`${e}`, sourceSpan);\n      return [];\n    }\n  }\n\n  parseLiteralAttr(\n    name: string,\n    value: string | null,\n    sourceSpan: ParseSourceSpan,\n    absoluteOffset: number,\n    valueSpan: ParseSourceSpan | undefined,\n    targetMatchableAttrs: string[][],\n    targetProps: ParsedProperty[],\n    keySpan: ParseSourceSpan,\n  ) {\n    if (isAnimationLabel(name)) {\n      name = name.substring(1);\n      if (keySpan !== undefined) {\n        keySpan = moveParseSourceSpan(\n          keySpan,\n          new AbsoluteSourceSpan(keySpan.start.offset + 1, keySpan.end.offset),\n        );\n      }\n      if (value) {\n        this._reportError(\n          `Assigning animation triggers via @prop=\"exp\" attributes with an expression is invalid.` +\n            ` Use property bindings (e.g. [@prop]=\"exp\") or use an attribute without a value (e.g. @prop) instead.`,\n          sourceSpan,\n          ParseErrorLevel.ERROR,\n        );\n      }\n      this._parseAnimation(\n        name,\n        value,\n        sourceSpan,\n        absoluteOffset,\n        keySpan,\n        valueSpan,\n        targetMatchableAttrs,\n        targetProps,\n      );\n    } else {\n      targetProps.push(\n        new ParsedProperty(\n          name,\n          this._exprParser.wrapLiteralPrimitive(value, '', absoluteOffset),\n          ParsedPropertyType.LITERAL_ATTR,\n          sourceSpan,\n          keySpan,\n          valueSpan,\n        ),\n      );\n    }\n  }\n\n  parsePropertyBinding(\n    name: string,\n    expression: string,\n    isHost: boolean,\n    isPartOfAssignmentBinding: boolean,\n    sourceSpan: ParseSourceSpan,\n    absoluteOffset: number,\n    valueSpan: ParseSourceSpan | undefined,\n    targetMatchableAttrs: string[][],\n    targetProps: ParsedProperty[],\n    keySpan: ParseSourceSpan,\n  ) {\n    if (name.length === 0) {\n      this._reportError(`Property name is missing in binding`, sourceSpan);\n    }\n\n    let isAnimationProp = false;\n    if (name.startsWith(ANIMATE_PROP_PREFIX)) {\n      isAnimationProp = true;\n      name = name.substring(ANIMATE_PROP_PREFIX.length);\n      if (keySpan !== undefined) {\n        keySpan = moveParseSourceSpan(\n          keySpan,\n          new AbsoluteSourceSpan(\n            keySpan.start.offset + ANIMATE_PROP_PREFIX.length,\n            keySpan.end.offset,\n          ),\n        );\n      }\n    } else if (isAnimationLabel(name)) {\n      isAnimationProp = true;\n      name = name.substring(1);\n      if (keySpan !== undefined) {\n        keySpan = moveParseSourceSpan(\n          keySpan,\n          new AbsoluteSourceSpan(keySpan.start.offset + 1, keySpan.end.offset),\n        );\n      }\n    }\n\n    if (isAnimationProp) {\n      this._parseAnimation(\n        name,\n        expression,\n        sourceSpan,\n        absoluteOffset,\n        keySpan,\n        valueSpan,\n        targetMatchableAttrs,\n        targetProps,\n      );\n    } else {\n      this._parsePropertyAst(\n        name,\n        this.parseBinding(expression, isHost, valueSpan || sourceSpan, absoluteOffset),\n        isPartOfAssignmentBinding,\n        sourceSpan,\n        keySpan,\n        valueSpan,\n        targetMatchableAttrs,\n        targetProps,\n      );\n    }\n  }\n\n  parsePropertyInterpolation(\n    name: string,\n    value: string,\n    sourceSpan: ParseSourceSpan,\n    valueSpan: ParseSourceSpan | undefined,\n    targetMatchableAttrs: string[][],\n    targetProps: ParsedProperty[],\n    keySpan: ParseSourceSpan,\n    interpolatedTokens: InterpolatedAttributeToken[] | InterpolatedTextToken[] | null,\n  ): boolean {\n    const expr = this.parseInterpolation(value, valueSpan || sourceSpan, interpolatedTokens);\n    if (expr) {\n      this._parsePropertyAst(\n        name,\n        expr,\n        false,\n        sourceSpan,\n        keySpan,\n        valueSpan,\n        targetMatchableAttrs,\n        targetProps,\n      );\n      return true;\n    }\n    return false;\n  }\n\n  private _parsePropertyAst(\n    name: string,\n    ast: ASTWithSource,\n    isPartOfAssignmentBinding: boolean,\n    sourceSpan: ParseSourceSpan,\n    keySpan: ParseSourceSpan,\n    valueSpan: ParseSourceSpan | undefined,\n    targetMatchableAttrs: string[][],\n    targetProps: ParsedProperty[],\n  ) {\n    targetMatchableAttrs.push([name, ast.source!]);\n    targetProps.push(\n      new ParsedProperty(\n        name,\n        ast,\n        isPartOfAssignmentBinding ? ParsedPropertyType.TWO_WAY : ParsedPropertyType.DEFAULT,\n        sourceSpan,\n        keySpan,\n        valueSpan,\n      ),\n    );\n  }\n\n  private _parseAnimation(\n    name: string,\n    expression: string | null,\n    sourceSpan: ParseSourceSpan,\n    absoluteOffset: number,\n    keySpan: ParseSourceSpan,\n    valueSpan: ParseSourceSpan | undefined,\n    targetMatchableAttrs: string[][],\n    targetProps: ParsedProperty[],\n  ) {\n    if (name.length === 0) {\n      this._reportError('Animation trigger is missing', sourceSpan);\n    }\n\n    // This will occur when a @trigger is not paired with an expression.\n    // For animations it is valid to not have an expression since */void\n    // states will be applied by angular when the element is attached/detached\n    const ast = this.parseBinding(\n      expression || 'undefined',\n      false,\n      valueSpan || sourceSpan,\n      absoluteOffset,\n    );\n    targetMatchableAttrs.push([name, ast.source!]);\n    targetProps.push(\n      new ParsedProperty(name, ast, ParsedPropertyType.ANIMATION, sourceSpan, keySpan, valueSpan),\n    );\n  }\n\n  parseBinding(\n    value: string,\n    isHostBinding: boolean,\n    sourceSpan: ParseSourceSpan,\n    absoluteOffset: number,\n  ): ASTWithSource {\n    const sourceInfo = ((sourceSpan && sourceSpan.start) || '(unknown)').toString();\n\n    try {\n      const ast = isHostBinding\n        ? this._exprParser.parseSimpleBinding(\n            value,\n            sourceInfo,\n            absoluteOffset,\n            this._interpolationConfig,\n          )\n        : this._exprParser.parseBinding(\n            value,\n            sourceInfo,\n            absoluteOffset,\n            this._interpolationConfig,\n          );\n      if (ast) this._reportExpressionParserErrors(ast.errors, sourceSpan);\n      return ast;\n    } catch (e) {\n      this._reportError(`${e}`, sourceSpan);\n      return this._exprParser.wrapLiteralPrimitive('ERROR', sourceInfo, absoluteOffset);\n    }\n  }\n\n  createBoundElementProperty(\n    elementSelector: string,\n    boundProp: ParsedProperty,\n    skipValidation: boolean = false,\n    mapPropertyName: boolean = true,\n  ): BoundElementProperty {\n    if (boundProp.isAnimation) {\n      return new BoundElementProperty(\n        boundProp.name,\n        BindingType.Animation,\n        SecurityContext.NONE,\n        boundProp.expression,\n        null,\n        boundProp.sourceSpan,\n        boundProp.keySpan,\n        boundProp.valueSpan,\n      );\n    }\n\n    let unit: string | null = null;\n    let bindingType: BindingType = undefined!;\n    let boundPropertyName: string | null = null;\n    const parts = boundProp.name.split(PROPERTY_PARTS_SEPARATOR);\n    let securityContexts: SecurityContext[] = undefined!;\n\n    // Check for special cases (prefix style, attr, class)\n    if (parts.length > 1) {\n      if (parts[0] == ATTRIBUTE_PREFIX) {\n        boundPropertyName = parts.slice(1).join(PROPERTY_PARTS_SEPARATOR);\n        if (!skipValidation) {\n          this._validatePropertyOrAttributeName(boundPropertyName, boundProp.sourceSpan, true);\n        }\n        securityContexts = calcPossibleSecurityContexts(\n          this._schemaRegistry,\n          elementSelector,\n          boundPropertyName,\n          true,\n        );\n\n        const nsSeparatorIdx = boundPropertyName.indexOf(':');\n        if (nsSeparatorIdx > -1) {\n          const ns = boundPropertyName.substring(0, nsSeparatorIdx);\n          const name = boundPropertyName.substring(nsSeparatorIdx + 1);\n          boundPropertyName = mergeNsAndName(ns, name);\n        }\n\n        bindingType = BindingType.Attribute;\n      } else if (parts[0] == CLASS_PREFIX) {\n        boundPropertyName = parts[1];\n        bindingType = BindingType.Class;\n        securityContexts = [SecurityContext.NONE];\n      } else if (parts[0] == STYLE_PREFIX) {\n        unit = parts.length > 2 ? parts[2] : null;\n        boundPropertyName = parts[1];\n        bindingType = BindingType.Style;\n        securityContexts = [SecurityContext.STYLE];\n      }\n    }\n\n    // If not a special case, use the full property name\n    if (boundPropertyName === null) {\n      const mappedPropName = this._schemaRegistry.getMappedPropName(boundProp.name);\n      boundPropertyName = mapPropertyName ? mappedPropName : boundProp.name;\n      securityContexts = calcPossibleSecurityContexts(\n        this._schemaRegistry,\n        elementSelector,\n        mappedPropName,\n        false,\n      );\n      bindingType =\n        boundProp.type === ParsedPropertyType.TWO_WAY ? BindingType.TwoWay : BindingType.Property;\n      if (!skipValidation) {\n        this._validatePropertyOrAttributeName(mappedPropName, boundProp.sourceSpan, false);\n      }\n    }\n\n    return new BoundElementProperty(\n      boundPropertyName,\n      bindingType,\n      securityContexts[0],\n      boundProp.expression,\n      unit,\n      boundProp.sourceSpan,\n      boundProp.keySpan,\n      boundProp.valueSpan,\n    );\n  }\n\n  // TODO: keySpan should be required but was made optional to avoid changing VE parser.\n  parseEvent(\n    name: string,\n    expression: string,\n    isAssignmentEvent: boolean,\n    sourceSpan: ParseSourceSpan,\n    handlerSpan: ParseSourceSpan,\n    targetMatchableAttrs: string[][],\n    targetEvents: ParsedEvent[],\n    keySpan: ParseSourceSpan,\n  ) {\n    if (name.length === 0) {\n      this._reportError(`Event name is missing in binding`, sourceSpan);\n    }\n\n    if (isAnimationLabel(name)) {\n      name = name.slice(1);\n      if (keySpan !== undefined) {\n        keySpan = moveParseSourceSpan(\n          keySpan,\n          new AbsoluteSourceSpan(keySpan.start.offset + 1, keySpan.end.offset),\n        );\n      }\n      this._parseAnimationEvent(name, expression, sourceSpan, handlerSpan, targetEvents, keySpan);\n    } else {\n      this._parseRegularEvent(\n        name,\n        expression,\n        isAssignmentEvent,\n        sourceSpan,\n        handlerSpan,\n        targetMatchableAttrs,\n        targetEvents,\n        keySpan,\n      );\n    }\n  }\n\n  calcPossibleSecurityContexts(\n    selector: string,\n    propName: string,\n    isAttribute: boolean,\n  ): SecurityContext[] {\n    const prop = this._schemaRegistry.getMappedPropName(propName);\n    return calcPossibleSecurityContexts(this._schemaRegistry, selector, prop, isAttribute);\n  }\n\n  private _parseAnimationEvent(\n    name: string,\n    expression: string,\n    sourceSpan: ParseSourceSpan,\n    handlerSpan: ParseSourceSpan,\n    targetEvents: ParsedEvent[],\n    keySpan: ParseSourceSpan,\n  ) {\n    const matches = splitAtPeriod(name, [name, '']);\n    const eventName = matches[0];\n    const phase = matches[1].toLowerCase();\n    const ast = this._parseAction(expression, handlerSpan);\n    targetEvents.push(\n      new ParsedEvent(\n        eventName,\n        phase,\n        ParsedEventType.Animation,\n        ast,\n        sourceSpan,\n        handlerSpan,\n        keySpan,\n      ),\n    );\n\n    if (eventName.length === 0) {\n      this._reportError(`Animation event name is missing in binding`, sourceSpan);\n    }\n    if (phase) {\n      if (phase !== 'start' && phase !== 'done') {\n        this._reportError(\n          `The provided animation output phase value \"${phase}\" for \"@${eventName}\" is not supported (use start or done)`,\n          sourceSpan,\n        );\n      }\n    } else {\n      this._reportError(\n        `The animation trigger output event (@${eventName}) is missing its phase value name (start or done are currently supported)`,\n        sourceSpan,\n      );\n    }\n  }\n\n  private _parseRegularEvent(\n    name: string,\n    expression: string,\n    isAssignmentEvent: boolean,\n    sourceSpan: ParseSourceSpan,\n    handlerSpan: ParseSourceSpan,\n    targetMatchableAttrs: string[][],\n    targetEvents: ParsedEvent[],\n    keySpan: ParseSourceSpan,\n  ): void {\n    // long format: 'target: eventName'\n    const [target, eventName] = splitAtColon(name, [null!, name]);\n    const prevErrorCount = this.errors.length;\n    const ast = this._parseAction(expression, handlerSpan);\n    const isValid = this.errors.length === prevErrorCount;\n    targetMatchableAttrs.push([name!, ast.source!]);\n\n    // Don't try to validate assignment events if there were other\n    // parsing errors to avoid adding more noise to the error logs.\n    if (isAssignmentEvent && isValid && !this._isAllowedAssignmentEvent(ast)) {\n      this._reportError('Unsupported expression in a two-way binding', sourceSpan);\n    }\n\n    targetEvents.push(\n      new ParsedEvent(\n        eventName,\n        target,\n        isAssignmentEvent ? ParsedEventType.TwoWay : ParsedEventType.Regular,\n        ast,\n        sourceSpan,\n        handlerSpan,\n        keySpan,\n      ),\n    );\n    // Don't detect directives for event names for now,\n    // so don't add the event name to the matchableAttrs\n  }\n\n  private _parseAction(value: string, sourceSpan: ParseSourceSpan): ASTWithSource {\n    const sourceInfo = ((sourceSpan && sourceSpan.start) || '(unknown').toString();\n    const absoluteOffset = sourceSpan && sourceSpan.start ? sourceSpan.start.offset : 0;\n\n    try {\n      const ast = this._exprParser.parseAction(\n        value,\n        sourceInfo,\n        absoluteOffset,\n        this._interpolationConfig,\n      );\n      if (ast) {\n        this._reportExpressionParserErrors(ast.errors, sourceSpan);\n      }\n      if (!ast || ast.ast instanceof EmptyExpr) {\n        this._reportError(`Empty expressions are not allowed`, sourceSpan);\n        return this._exprParser.wrapLiteralPrimitive('ERROR', sourceInfo, absoluteOffset);\n      }\n      return ast;\n    } catch (e) {\n      this._reportError(`${e}`, sourceSpan);\n      return this._exprParser.wrapLiteralPrimitive('ERROR', sourceInfo, absoluteOffset);\n    }\n  }\n\n  private _reportError(\n    message: string,\n    sourceSpan: ParseSourceSpan,\n    level: ParseErrorLevel = ParseErrorLevel.ERROR,\n  ) {\n    this.errors.push(new ParseError(sourceSpan, message, level));\n  }\n\n  private _reportExpressionParserErrors(errors: ParserError[], sourceSpan: ParseSourceSpan) {\n    for (const error of errors) {\n      this._reportError(error.message, sourceSpan);\n    }\n  }\n\n  /**\n   * @param propName the name of the property / attribute\n   * @param sourceSpan\n   * @param isAttr true when binding to an attribute\n   */\n  private _validatePropertyOrAttributeName(\n    propName: string,\n    sourceSpan: ParseSourceSpan,\n    isAttr: boolean,\n  ): void {\n    const report = isAttr\n      ? this._schemaRegistry.validateAttribute(propName)\n      : this._schemaRegistry.validateProperty(propName);\n    if (report.error) {\n      this._reportError(report.msg!, sourceSpan, ParseErrorLevel.ERROR);\n    }\n  }\n\n  /**\n   * Returns whether a parsed AST is allowed to be used within the event side of a two-way binding.\n   * @param ast Parsed AST to be checked.\n   */\n  private _isAllowedAssignmentEvent(ast: AST): boolean {\n    if (ast instanceof ASTWithSource) {\n      return this._isAllowedAssignmentEvent(ast.ast);\n    }\n\n    if (ast instanceof NonNullAssert) {\n      return this._isAllowedAssignmentEvent(ast.expression);\n    }\n\n    if (ast instanceof PropertyRead || ast instanceof KeyedRead) {\n      return true;\n    }\n\n    // TODO(crisbeto): this logic is only here to support the automated migration away\n    // from invalid bindings. It should be removed once the migration is deleted.\n    if (!this._allowInvalidAssignmentEvents) {\n      return false;\n    }\n\n    if (ast instanceof Binary) {\n      return (\n        (ast.operation === '&&' || ast.operation === '||' || ast.operation === '??') &&\n        (ast.right instanceof PropertyRead || ast.right instanceof KeyedRead)\n      );\n    }\n\n    return ast instanceof Conditional || ast instanceof PrefixNot;\n  }\n}\n\nexport class PipeCollector extends RecursiveAstVisitor {\n  pipes = new Map<string, BindingPipe>();\n  override visitPipe(ast: BindingPipe, context: any): any {\n    this.pipes.set(ast.name, ast);\n    ast.exp.visit(this);\n    this.visitAll(ast.args, context);\n    return null;\n  }\n}\n\nfunction isAnimationLabel(name: string): boolean {\n  return name[0] == '@';\n}\n\nexport function calcPossibleSecurityContexts(\n  registry: ElementSchemaRegistry,\n  selector: string,\n  propName: string,\n  isAttribute: boolean,\n): SecurityContext[] {\n  const ctxs: SecurityContext[] = [];\n  CssSelector.parse(selector).forEach((selector) => {\n    const elementNames = selector.element ? [selector.element] : registry.allKnownElementNames();\n    const notElementNames = new Set(\n      selector.notSelectors\n        .filter((selector) => selector.isElementSelector())\n        .map((selector) => selector.element),\n    );\n    const possibleElementNames = elementNames.filter(\n      (elementName) => !notElementNames.has(elementName),\n    );\n\n    ctxs.push(\n      ...possibleElementNames.map((elementName) =>\n        registry.securityContext(elementName, propName, isAttribute),\n      ),\n    );\n  });\n  return ctxs.length === 0 ? [SecurityContext.NONE] : Array.from(new Set(ctxs)).sort();\n}\n\n/**\n * Compute a new ParseSourceSpan based off an original `sourceSpan` by using\n * absolute offsets from the specified `absoluteSpan`.\n *\n * @param sourceSpan original source span\n * @param absoluteSpan absolute source span to move to\n */\nfunction moveParseSourceSpan(\n  sourceSpan: ParseSourceSpan,\n  absoluteSpan: AbsoluteSourceSpan,\n): ParseSourceSpan {\n  // The difference of two absolute offsets provide the relative offset\n  const startDiff = absoluteSpan.start - sourceSpan.start.offset;\n  const endDiff = absoluteSpan.end - sourceSpan.end.offset;\n  return new ParseSourceSpan(\n    sourceSpan.start.moveBy(startDiff),\n    sourceSpan.end.moveBy(endDiff),\n    sourceSpan.fullStart.moveBy(startDiff),\n    sourceSpan.details,\n  );\n}\n"]}