@angular/language-service 11.0.5 → 11.0.9
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/bundles/ivy.js +148 -141
- package/bundles/language-service.js +175 -106
- package/package.json +1 -1
- package/src/completions.js +2 -2
package/bundles/ivy.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* @license Angular v11.0.
|
|
2
|
+
* @license Angular v11.0.9
|
|
3
3
|
* Copyright Google LLC All Rights Reserved.
|
|
4
4
|
* License: MIT
|
|
5
5
|
*/
|
|
@@ -3133,12 +3133,60 @@ define(['exports', 'os', 'typescript', 'fs', 'constants', 'stream', 'util', 'ass
|
|
|
3133
3133
|
* found in the LICENSE file at https://angular.io/license
|
|
3134
3134
|
*/
|
|
3135
3135
|
/**
|
|
3136
|
-
* A wrapper around the Node.js file-system
|
|
3136
|
+
* A wrapper around the Node.js file-system that supports path manipulation.
|
|
3137
3137
|
*/
|
|
3138
|
-
class
|
|
3138
|
+
class NodeJSPathManipulation {
|
|
3139
|
+
pwd() {
|
|
3140
|
+
return this.normalize(process.cwd());
|
|
3141
|
+
}
|
|
3142
|
+
chdir(dir) {
|
|
3143
|
+
process.chdir(dir);
|
|
3144
|
+
}
|
|
3145
|
+
resolve(...paths) {
|
|
3146
|
+
return this.normalize(path.resolve(...paths));
|
|
3147
|
+
}
|
|
3148
|
+
dirname(file) {
|
|
3149
|
+
return this.normalize(path.dirname(file));
|
|
3150
|
+
}
|
|
3151
|
+
join(basePath, ...paths) {
|
|
3152
|
+
return this.normalize(path.join(basePath, ...paths));
|
|
3153
|
+
}
|
|
3154
|
+
isRoot(path) {
|
|
3155
|
+
return this.dirname(path) === this.normalize(path);
|
|
3156
|
+
}
|
|
3157
|
+
isRooted(path$1) {
|
|
3158
|
+
return path.isAbsolute(path$1);
|
|
3159
|
+
}
|
|
3160
|
+
relative(from, to) {
|
|
3161
|
+
return this.normalize(path.relative(from, to));
|
|
3162
|
+
}
|
|
3163
|
+
basename(filePath, extension) {
|
|
3164
|
+
return path.basename(filePath, extension);
|
|
3165
|
+
}
|
|
3166
|
+
extname(path$1) {
|
|
3167
|
+
return path.extname(path$1);
|
|
3168
|
+
}
|
|
3169
|
+
normalize(path) {
|
|
3170
|
+
// Convert backslashes to forward slashes
|
|
3171
|
+
return path.replace(/\\/g, '/');
|
|
3172
|
+
}
|
|
3173
|
+
}
|
|
3174
|
+
/**
|
|
3175
|
+
* A wrapper around the Node.js file-system that supports readonly operations and path manipulation.
|
|
3176
|
+
*/
|
|
3177
|
+
class NodeJSReadonlyFileSystem extends NodeJSPathManipulation {
|
|
3139
3178
|
constructor() {
|
|
3179
|
+
super(...arguments);
|
|
3140
3180
|
this._caseSensitive = undefined;
|
|
3141
3181
|
}
|
|
3182
|
+
isCaseSensitive() {
|
|
3183
|
+
if (this._caseSensitive === undefined) {
|
|
3184
|
+
// Note the use of the real file-system is intentional:
|
|
3185
|
+
// `this.exists()` relies upon `isCaseSensitive()` so that would cause an infinite recursion.
|
|
3186
|
+
this._caseSensitive = !fs$2.existsSync(this.normalize(toggleCase(__filename)));
|
|
3187
|
+
}
|
|
3188
|
+
return this._caseSensitive;
|
|
3189
|
+
}
|
|
3142
3190
|
exists(path) {
|
|
3143
3191
|
return fs$2.existsSync(path);
|
|
3144
3192
|
}
|
|
@@ -3148,15 +3196,6 @@ define(['exports', 'os', 'typescript', 'fs', 'constants', 'stream', 'util', 'ass
|
|
|
3148
3196
|
readFileBuffer(path) {
|
|
3149
3197
|
return fs$2.readFileSync(path);
|
|
3150
3198
|
}
|
|
3151
|
-
writeFile(path, data, exclusive = false) {
|
|
3152
|
-
fs$2.writeFileSync(path, data, exclusive ? { flag: 'wx' } : undefined);
|
|
3153
|
-
}
|
|
3154
|
-
removeFile(path) {
|
|
3155
|
-
fs$2.unlinkSync(path);
|
|
3156
|
-
}
|
|
3157
|
-
symlink(target, path) {
|
|
3158
|
-
fs$2.symlinkSync(target, path);
|
|
3159
|
-
}
|
|
3160
3199
|
readdir(path) {
|
|
3161
3200
|
return fs$2.readdirSync(path);
|
|
3162
3201
|
}
|
|
@@ -3166,11 +3205,25 @@ define(['exports', 'os', 'typescript', 'fs', 'constants', 'stream', 'util', 'ass
|
|
|
3166
3205
|
stat(path) {
|
|
3167
3206
|
return fs$2.statSync(path);
|
|
3168
3207
|
}
|
|
3169
|
-
|
|
3170
|
-
return this.
|
|
3208
|
+
realpath(path) {
|
|
3209
|
+
return this.resolve(fs$2.realpathSync(path));
|
|
3171
3210
|
}
|
|
3172
|
-
|
|
3173
|
-
|
|
3211
|
+
getDefaultLibLocation() {
|
|
3212
|
+
return this.resolve(require.resolve('typescript'), '..');
|
|
3213
|
+
}
|
|
3214
|
+
}
|
|
3215
|
+
/**
|
|
3216
|
+
* A wrapper around the Node.js file-system (i.e. the `fs` package).
|
|
3217
|
+
*/
|
|
3218
|
+
class NodeJSFileSystem extends NodeJSReadonlyFileSystem {
|
|
3219
|
+
writeFile(path, data, exclusive = false) {
|
|
3220
|
+
fs$2.writeFileSync(path, data, exclusive ? { flag: 'wx' } : undefined);
|
|
3221
|
+
}
|
|
3222
|
+
removeFile(path) {
|
|
3223
|
+
fs$2.unlinkSync(path);
|
|
3224
|
+
}
|
|
3225
|
+
symlink(target, path) {
|
|
3226
|
+
fs$2.symlinkSync(target, path);
|
|
3174
3227
|
}
|
|
3175
3228
|
copyFile(from, to) {
|
|
3176
3229
|
fs$2.copyFileSync(from, to);
|
|
@@ -3191,48 +3244,6 @@ define(['exports', 'os', 'typescript', 'fs', 'constants', 'stream', 'util', 'ass
|
|
|
3191
3244
|
removeDeep(path) {
|
|
3192
3245
|
undefined(path);
|
|
3193
3246
|
}
|
|
3194
|
-
isCaseSensitive() {
|
|
3195
|
-
if (this._caseSensitive === undefined) {
|
|
3196
|
-
// Note the use of the real file-system is intentional:
|
|
3197
|
-
// `this.exists()` relies upon `isCaseSensitive()` so that would cause an infinite recursion.
|
|
3198
|
-
this._caseSensitive = !fs$2.existsSync(togglePathCase(__filename));
|
|
3199
|
-
}
|
|
3200
|
-
return this._caseSensitive;
|
|
3201
|
-
}
|
|
3202
|
-
resolve(...paths) {
|
|
3203
|
-
return this.normalize(path.resolve(...paths));
|
|
3204
|
-
}
|
|
3205
|
-
dirname(file) {
|
|
3206
|
-
return this.normalize(path.dirname(file));
|
|
3207
|
-
}
|
|
3208
|
-
join(basePath, ...paths) {
|
|
3209
|
-
return this.normalize(path.join(basePath, ...paths));
|
|
3210
|
-
}
|
|
3211
|
-
isRoot(path) {
|
|
3212
|
-
return this.dirname(path) === this.normalize(path);
|
|
3213
|
-
}
|
|
3214
|
-
isRooted(path$1) {
|
|
3215
|
-
return path.isAbsolute(path$1);
|
|
3216
|
-
}
|
|
3217
|
-
relative(from, to) {
|
|
3218
|
-
return this.normalize(path.relative(from, to));
|
|
3219
|
-
}
|
|
3220
|
-
basename(filePath, extension) {
|
|
3221
|
-
return path.basename(filePath, extension);
|
|
3222
|
-
}
|
|
3223
|
-
extname(path$1) {
|
|
3224
|
-
return path.extname(path$1);
|
|
3225
|
-
}
|
|
3226
|
-
realpath(path) {
|
|
3227
|
-
return this.resolve(fs$2.realpathSync(path));
|
|
3228
|
-
}
|
|
3229
|
-
getDefaultLibLocation() {
|
|
3230
|
-
return this.resolve(require.resolve('typescript'), '..');
|
|
3231
|
-
}
|
|
3232
|
-
normalize(path) {
|
|
3233
|
-
// Convert backslashes to forward slashes
|
|
3234
|
-
return path.replace(/\\/g, '/');
|
|
3235
|
-
}
|
|
3236
3247
|
safeMkdir(path) {
|
|
3237
3248
|
try {
|
|
3238
3249
|
fs$2.mkdirSync(path);
|
|
@@ -3247,10 +3258,10 @@ define(['exports', 'os', 'typescript', 'fs', 'constants', 'stream', 'util', 'ass
|
|
|
3247
3258
|
}
|
|
3248
3259
|
}
|
|
3249
3260
|
/**
|
|
3250
|
-
* Toggle the case of each character in a
|
|
3261
|
+
* Toggle the case of each character in a string.
|
|
3251
3262
|
*/
|
|
3252
|
-
function
|
|
3253
|
-
return
|
|
3263
|
+
function toggleCase(str) {
|
|
3264
|
+
return str.replace(/\w/g, ch => ch.toUpperCase() === ch ? ch.toLowerCase() : ch.toUpperCase());
|
|
3254
3265
|
}
|
|
3255
3266
|
|
|
3256
3267
|
/**
|
|
@@ -3583,6 +3594,13 @@ define(['exports', 'os', 'typescript', 'fs', 'constants', 'stream', 'util', 'ass
|
|
|
3583
3594
|
isClosedByChild(name) {
|
|
3584
3595
|
return this.isVoid || name.toLowerCase() in this.closedByChildren;
|
|
3585
3596
|
}
|
|
3597
|
+
getContentType(prefix) {
|
|
3598
|
+
if (typeof this.contentType === 'object') {
|
|
3599
|
+
const overrideType = prefix == null ? undefined : this.contentType[prefix];
|
|
3600
|
+
return overrideType !== null && overrideType !== void 0 ? overrideType : this.contentType.default;
|
|
3601
|
+
}
|
|
3602
|
+
return this.contentType;
|
|
3603
|
+
}
|
|
3586
3604
|
}
|
|
3587
3605
|
let _DEFAULT_TAG_DEFINITION;
|
|
3588
3606
|
// see https://www.w3.org/TR/html51/syntax.html#optional-tags
|
|
@@ -3648,7 +3666,11 @@ define(['exports', 'os', 'typescript', 'fs', 'constants', 'stream', 'util', 'ass
|
|
|
3648
3666
|
'listing': new HtmlTagDefinition({ ignoreFirstLf: true }),
|
|
3649
3667
|
'style': new HtmlTagDefinition({ contentType: TagContentType.RAW_TEXT }),
|
|
3650
3668
|
'script': new HtmlTagDefinition({ contentType: TagContentType.RAW_TEXT }),
|
|
3651
|
-
'title': new HtmlTagDefinition({
|
|
3669
|
+
'title': new HtmlTagDefinition({
|
|
3670
|
+
// The browser supports two separate `title` tags which have to use
|
|
3671
|
+
// a different content type: `HTMLTitleElement` and `SVGTitleElement`
|
|
3672
|
+
contentType: { default: TagContentType.ESCAPABLE_RAW_TEXT, svg: TagContentType.PARSABLE_DATA }
|
|
3673
|
+
}),
|
|
3652
3674
|
'textarea': new HtmlTagDefinition({ contentType: TagContentType.ESCAPABLE_RAW_TEXT, ignoreFirstLf: true }),
|
|
3653
3675
|
};
|
|
3654
3676
|
}
|
|
@@ -5058,10 +5080,6 @@ define(['exports', 'os', 'typescript', 'fs', 'constants', 'stream', 'util', 'ass
|
|
|
5058
5080
|
function error(msg) {
|
|
5059
5081
|
throw new Error(`Internal Error: ${msg}`);
|
|
5060
5082
|
}
|
|
5061
|
-
// Escape characters that have a special meaning in Regular Expressions
|
|
5062
|
-
function escapeRegExp(s) {
|
|
5063
|
-
return s.replace(/([.*+?^=!:${}()|[\]\/\\])/g, '\\$1');
|
|
5064
|
-
}
|
|
5065
5083
|
function utf8Encode(str) {
|
|
5066
5084
|
let encoded = [];
|
|
5067
5085
|
for (let index = 0; index < str.length; index++) {
|
|
@@ -10964,12 +10982,13 @@ define(['exports', 'os', 'typescript', 'fs', 'constants', 'stream', 'util', 'ass
|
|
|
10964
10982
|
this.index = 0;
|
|
10965
10983
|
// Replaces attribute selectors with placeholders.
|
|
10966
10984
|
// The WS in [attr="va lue"] would otherwise be interpreted as a selector separator.
|
|
10967
|
-
selector =
|
|
10968
|
-
|
|
10969
|
-
|
|
10970
|
-
|
|
10971
|
-
|
|
10972
|
-
|
|
10985
|
+
selector = this._escapeRegexMatches(selector, /(\[[^\]]*\])/g);
|
|
10986
|
+
// CSS allows for certain special characters to be used in selectors if they're escaped.
|
|
10987
|
+
// E.g. `.foo:blue` won't match a class called `foo:blue`, because the colon denotes a
|
|
10988
|
+
// pseudo-class, but writing `.foo\:blue` will match, because the colon was escaped.
|
|
10989
|
+
// Replace all escape sequences (`\` followed by a character) with a placeholder so
|
|
10990
|
+
// that our handling of pseudo-selectors doesn't mess with them.
|
|
10991
|
+
selector = this._escapeRegexMatches(selector, /(\\.)/g);
|
|
10973
10992
|
// Replaces the expression in `:nth-child(2n + 1)` with a placeholder.
|
|
10974
10993
|
// WS and "+" would otherwise be interpreted as selector separators.
|
|
10975
10994
|
this._content = selector.replace(/(:nth-[-\w]+)(\([^)]+\))/g, (_, pseudo, exp) => {
|
|
@@ -10980,11 +10999,23 @@ define(['exports', 'os', 'typescript', 'fs', 'constants', 'stream', 'util', 'ass
|
|
|
10980
10999
|
});
|
|
10981
11000
|
}
|
|
10982
11001
|
restore(content) {
|
|
10983
|
-
return content.replace(/__ph-(\d+)__/g, (
|
|
11002
|
+
return content.replace(/__ph-(\d+)__/g, (_ph, index) => this.placeholders[+index]);
|
|
10984
11003
|
}
|
|
10985
11004
|
content() {
|
|
10986
11005
|
return this._content;
|
|
10987
11006
|
}
|
|
11007
|
+
/**
|
|
11008
|
+
* Replaces all of the substrings that match a regex within a
|
|
11009
|
+
* special string (e.g. `__ph-0__`, `__ph-1__`, etc).
|
|
11010
|
+
*/
|
|
11011
|
+
_escapeRegexMatches(content, pattern) {
|
|
11012
|
+
return content.replace(pattern, (_, keep) => {
|
|
11013
|
+
const replaceBy = `__ph-${this.index}__`;
|
|
11014
|
+
this.placeholders.push(keep);
|
|
11015
|
+
this.index++;
|
|
11016
|
+
return replaceBy;
|
|
11017
|
+
});
|
|
11018
|
+
}
|
|
10988
11019
|
}
|
|
10989
11020
|
const _cssContentNextSelectorRe = /polyfill-next-selector[^}]*content:[\s]*?(['"])(.*?)\1[;\s]*}([^{]*?){/gim;
|
|
10990
11021
|
const _cssContentRuleRe = /(polyfill-rule)[^}]*(content:[\s]*(['"])(.*?)\3)[;\s]*[^}]*}/gim;
|
|
@@ -11644,7 +11675,7 @@ define(['exports', 'os', 'typescript', 'fs', 'constants', 'stream', 'util', 'ass
|
|
|
11644
11675
|
}
|
|
11645
11676
|
throw e;
|
|
11646
11677
|
}
|
|
11647
|
-
const contentTokenType = this._getTagDefinition(tagName).
|
|
11678
|
+
const contentTokenType = this._getTagDefinition(tagName).getContentType(prefix);
|
|
11648
11679
|
if (contentTokenType === TagContentType.RAW_TEXT) {
|
|
11649
11680
|
this._consumeRawTextWithTagClose(prefix, tagName, false);
|
|
11650
11681
|
}
|
|
@@ -11653,7 +11684,7 @@ define(['exports', 'os', 'typescript', 'fs', 'constants', 'stream', 'util', 'ass
|
|
|
11653
11684
|
}
|
|
11654
11685
|
}
|
|
11655
11686
|
_consumeRawTextWithTagClose(prefix, tagName, decodeEntities) {
|
|
11656
|
-
|
|
11687
|
+
this._consumeRawText(decodeEntities, () => {
|
|
11657
11688
|
if (!this._attemptCharCode($LT))
|
|
11658
11689
|
return false;
|
|
11659
11690
|
if (!this._attemptCharCode($SLASH))
|
|
@@ -14149,19 +14180,6 @@ define(['exports', 'os', 'typescript', 'fs', 'constants', 'stream', 'util', 'ass
|
|
|
14149
14180
|
this.errors = errors;
|
|
14150
14181
|
}
|
|
14151
14182
|
}
|
|
14152
|
-
const defaultInterpolateRegExp = _createInterpolateRegExp(DEFAULT_INTERPOLATION_CONFIG);
|
|
14153
|
-
function _getInterpolateRegExp(config) {
|
|
14154
|
-
if (config === DEFAULT_INTERPOLATION_CONFIG) {
|
|
14155
|
-
return defaultInterpolateRegExp;
|
|
14156
|
-
}
|
|
14157
|
-
else {
|
|
14158
|
-
return _createInterpolateRegExp(config);
|
|
14159
|
-
}
|
|
14160
|
-
}
|
|
14161
|
-
function _createInterpolateRegExp(config) {
|
|
14162
|
-
const pattern = escapeRegExp(config.start) + '([\\s\\S]*?)' + escapeRegExp(config.end);
|
|
14163
|
-
return new RegExp(pattern, 'g');
|
|
14164
|
-
}
|
|
14165
14183
|
class Parser$1 {
|
|
14166
14184
|
constructor(_lexer) {
|
|
14167
14185
|
this._lexer = _lexer;
|
|
@@ -14321,7 +14339,7 @@ define(['exports', 'os', 'typescript', 'fs', 'constants', 'stream', 'util', 'ass
|
|
|
14321
14339
|
// parse from starting {{ to ending }} while ignoring content inside quotes.
|
|
14322
14340
|
const fullStart = i;
|
|
14323
14341
|
const exprStart = fullStart + interpStart.length;
|
|
14324
|
-
const exprEnd = this.
|
|
14342
|
+
const exprEnd = this._getInterpolationEndIndex(input, interpEnd, exprStart);
|
|
14325
14343
|
if (exprEnd === -1) {
|
|
14326
14344
|
// Could not find the end of the interpolation; do not parse an expression.
|
|
14327
14345
|
// Instead we should extend the content on the last raw string.
|
|
@@ -14380,50 +14398,64 @@ define(['exports', 'os', 'typescript', 'fs', 'constants', 'stream', 'util', 'ass
|
|
|
14380
14398
|
}
|
|
14381
14399
|
return null;
|
|
14382
14400
|
}
|
|
14383
|
-
_checkNoInterpolation(input, location,
|
|
14384
|
-
|
|
14385
|
-
|
|
14386
|
-
|
|
14387
|
-
|
|
14401
|
+
_checkNoInterpolation(input, location, { start, end }) {
|
|
14402
|
+
let startIndex = -1;
|
|
14403
|
+
let endIndex = -1;
|
|
14404
|
+
for (const charIndex of this._forEachUnquotedChar(input, 0)) {
|
|
14405
|
+
if (startIndex === -1) {
|
|
14406
|
+
if (input.startsWith(start)) {
|
|
14407
|
+
startIndex = charIndex;
|
|
14408
|
+
}
|
|
14409
|
+
}
|
|
14410
|
+
else {
|
|
14411
|
+
endIndex = this._getInterpolationEndIndex(input, end, charIndex);
|
|
14412
|
+
if (endIndex > -1) {
|
|
14413
|
+
break;
|
|
14414
|
+
}
|
|
14415
|
+
}
|
|
14388
14416
|
}
|
|
14389
|
-
|
|
14390
|
-
|
|
14391
|
-
let errLocation = '';
|
|
14392
|
-
for (let j = 0; j < partInErrIdx; j++) {
|
|
14393
|
-
errLocation += j % 2 === 0 ?
|
|
14394
|
-
parts[j] :
|
|
14395
|
-
`${interpolationConfig.start}${parts[j]}${interpolationConfig.end}`;
|
|
14417
|
+
if (startIndex > -1 && endIndex > -1) {
|
|
14418
|
+
this._reportError(`Got interpolation (${start}${end}) where expression was expected`, input, `at column ${startIndex} in`, location);
|
|
14396
14419
|
}
|
|
14397
|
-
return errLocation.length;
|
|
14398
14420
|
}
|
|
14399
14421
|
/**
|
|
14400
14422
|
* Finds the index of the end of an interpolation expression
|
|
14401
14423
|
* while ignoring comments and quoted content.
|
|
14402
14424
|
*/
|
|
14403
|
-
|
|
14425
|
+
_getInterpolationEndIndex(input, expressionEnd, start) {
|
|
14426
|
+
for (const charIndex of this._forEachUnquotedChar(input, start)) {
|
|
14427
|
+
if (input.startsWith(expressionEnd, charIndex)) {
|
|
14428
|
+
return charIndex;
|
|
14429
|
+
}
|
|
14430
|
+
// Nothing else in the expression matters after we've
|
|
14431
|
+
// hit a comment so look directly for the end token.
|
|
14432
|
+
if (input.startsWith('//', charIndex)) {
|
|
14433
|
+
return input.indexOf(expressionEnd, charIndex);
|
|
14434
|
+
}
|
|
14435
|
+
}
|
|
14436
|
+
return -1;
|
|
14437
|
+
}
|
|
14438
|
+
/**
|
|
14439
|
+
* Generator used to iterate over the character indexes of a string that are outside of quotes.
|
|
14440
|
+
* @param input String to loop through.
|
|
14441
|
+
* @param start Index within the string at which to start.
|
|
14442
|
+
*/
|
|
14443
|
+
*_forEachUnquotedChar(input, start) {
|
|
14404
14444
|
let currentQuote = null;
|
|
14405
14445
|
let escapeCount = 0;
|
|
14406
14446
|
for (let i = start; i < input.length; i++) {
|
|
14407
14447
|
const char = input[i];
|
|
14408
|
-
// Skip the characters inside quotes. Note that we only care about the
|
|
14409
|
-
//
|
|
14448
|
+
// Skip the characters inside quotes. Note that we only care about the outer-most
|
|
14449
|
+
// quotes matching up and we need to account for escape characters.
|
|
14410
14450
|
if (isQuote(input.charCodeAt(i)) && (currentQuote === null || currentQuote === char) &&
|
|
14411
14451
|
escapeCount % 2 === 0) {
|
|
14412
14452
|
currentQuote = currentQuote === null ? char : null;
|
|
14413
14453
|
}
|
|
14414
14454
|
else if (currentQuote === null) {
|
|
14415
|
-
|
|
14416
|
-
return i;
|
|
14417
|
-
}
|
|
14418
|
-
// Nothing else in the expression matters after we've
|
|
14419
|
-
// hit a comment so look directly for the end token.
|
|
14420
|
-
if (input.startsWith('//', i)) {
|
|
14421
|
-
return input.indexOf(expressionEnd, i);
|
|
14422
|
-
}
|
|
14455
|
+
yield i;
|
|
14423
14456
|
}
|
|
14424
14457
|
escapeCount = char === '\\' ? escapeCount + 1 : 0;
|
|
14425
14458
|
}
|
|
14426
|
-
return -1;
|
|
14427
14459
|
}
|
|
14428
14460
|
}
|
|
14429
14461
|
class IvyParser extends Parser$1 {
|
|
@@ -19639,7 +19671,7 @@ define(['exports', 'os', 'typescript', 'fs', 'constants', 'stream', 'util', 'ass
|
|
|
19639
19671
|
* Use of this source code is governed by an MIT-style license that can be
|
|
19640
19672
|
* found in the LICENSE file at https://angular.io/license
|
|
19641
19673
|
*/
|
|
19642
|
-
const VERSION$1 = new Version('11.0.
|
|
19674
|
+
const VERSION$1 = new Version('11.0.9');
|
|
19643
19675
|
|
|
19644
19676
|
/**
|
|
19645
19677
|
* @license
|
|
@@ -19654,31 +19686,6 @@ define(['exports', 'os', 'typescript', 'fs', 'constants', 'stream', 'util', 'ass
|
|
|
19654
19686
|
_VisitorMode[_VisitorMode["Merge"] = 1] = "Merge";
|
|
19655
19687
|
})(_VisitorMode || (_VisitorMode = {}));
|
|
19656
19688
|
|
|
19657
|
-
/**
|
|
19658
|
-
* @license
|
|
19659
|
-
* Copyright Google LLC All Rights Reserved.
|
|
19660
|
-
*
|
|
19661
|
-
* Use of this source code is governed by an MIT-style license that can be
|
|
19662
|
-
* found in the LICENSE file at https://angular.io/license
|
|
19663
|
-
*/
|
|
19664
|
-
class XmlTagDefinition {
|
|
19665
|
-
constructor() {
|
|
19666
|
-
this.closedByParent = false;
|
|
19667
|
-
this.contentType = TagContentType.PARSABLE_DATA;
|
|
19668
|
-
this.isVoid = false;
|
|
19669
|
-
this.ignoreFirstLf = false;
|
|
19670
|
-
this.canSelfClose = true;
|
|
19671
|
-
this.preventNamespaceInheritance = false;
|
|
19672
|
-
}
|
|
19673
|
-
requireExtraParent(currentParent) {
|
|
19674
|
-
return false;
|
|
19675
|
-
}
|
|
19676
|
-
isClosedByChild(name) {
|
|
19677
|
-
return false;
|
|
19678
|
-
}
|
|
19679
|
-
}
|
|
19680
|
-
const _TAG_DEFINITION = new XmlTagDefinition();
|
|
19681
|
-
|
|
19682
19689
|
/**
|
|
19683
19690
|
* @license
|
|
19684
19691
|
* Copyright Google LLC All Rights Reserved.
|
|
@@ -20274,7 +20281,7 @@ define(['exports', 'os', 'typescript', 'fs', 'constants', 'stream', 'util', 'ass
|
|
|
20274
20281
|
* Use of this source code is governed by an MIT-style license that can be
|
|
20275
20282
|
* found in the LICENSE file at https://angular.io/license
|
|
20276
20283
|
*/
|
|
20277
|
-
const VERSION$2 = new Version('11.0.
|
|
20284
|
+
const VERSION$2 = new Version('11.0.9');
|
|
20278
20285
|
|
|
20279
20286
|
/**
|
|
20280
20287
|
* @license
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* @license Angular v11.0.
|
|
2
|
+
* @license Angular v11.0.9
|
|
3
3
|
* Copyright Google LLC All Rights Reserved.
|
|
4
4
|
* License: MIT
|
|
5
5
|
*/
|
|
@@ -359,6 +359,13 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
359
359
|
isClosedByChild(name) {
|
|
360
360
|
return this.isVoid || name.toLowerCase() in this.closedByChildren;
|
|
361
361
|
}
|
|
362
|
+
getContentType(prefix) {
|
|
363
|
+
if (typeof this.contentType === 'object') {
|
|
364
|
+
const overrideType = prefix == null ? undefined : this.contentType[prefix];
|
|
365
|
+
return overrideType !== null && overrideType !== void 0 ? overrideType : this.contentType.default;
|
|
366
|
+
}
|
|
367
|
+
return this.contentType;
|
|
368
|
+
}
|
|
362
369
|
}
|
|
363
370
|
let _DEFAULT_TAG_DEFINITION;
|
|
364
371
|
// see https://www.w3.org/TR/html51/syntax.html#optional-tags
|
|
@@ -424,7 +431,11 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
424
431
|
'listing': new HtmlTagDefinition({ ignoreFirstLf: true }),
|
|
425
432
|
'style': new HtmlTagDefinition({ contentType: TagContentType.RAW_TEXT }),
|
|
426
433
|
'script': new HtmlTagDefinition({ contentType: TagContentType.RAW_TEXT }),
|
|
427
|
-
'title': new HtmlTagDefinition({
|
|
434
|
+
'title': new HtmlTagDefinition({
|
|
435
|
+
// The browser supports two separate `title` tags which have to use
|
|
436
|
+
// a different content type: `HTMLTitleElement` and `SVGTitleElement`
|
|
437
|
+
contentType: { default: TagContentType.ESCAPABLE_RAW_TEXT, svg: TagContentType.PARSABLE_DATA }
|
|
438
|
+
}),
|
|
428
439
|
'textarea': new HtmlTagDefinition({ contentType: TagContentType.ESCAPABLE_RAW_TEXT, ignoreFirstLf: true }),
|
|
429
440
|
};
|
|
430
441
|
}
|
|
@@ -1921,10 +1932,6 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
1921
1932
|
}
|
|
1922
1933
|
const ERROR_SYNTAX_ERROR = 'ngSyntaxError';
|
|
1923
1934
|
const ERROR_PARSE_ERRORS = 'ngParseErrors';
|
|
1924
|
-
// Escape characters that have a special meaning in Regular Expressions
|
|
1925
|
-
function escapeRegExp(s) {
|
|
1926
|
-
return s.replace(/([.*+?^=!:${}()|[\]\/\\])/g, '\\$1');
|
|
1927
|
-
}
|
|
1928
1935
|
const STRING_MAP_PROTO = Object.getPrototypeOf({});
|
|
1929
1936
|
function isStrictStringMap(obj) {
|
|
1930
1937
|
return typeof obj === 'object' && obj !== null && Object.getPrototypeOf(obj) === STRING_MAP_PROTO;
|
|
@@ -8188,12 +8195,13 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
8188
8195
|
this.index = 0;
|
|
8189
8196
|
// Replaces attribute selectors with placeholders.
|
|
8190
8197
|
// The WS in [attr="va lue"] would otherwise be interpreted as a selector separator.
|
|
8191
|
-
selector =
|
|
8192
|
-
|
|
8193
|
-
|
|
8194
|
-
|
|
8195
|
-
|
|
8196
|
-
|
|
8198
|
+
selector = this._escapeRegexMatches(selector, /(\[[^\]]*\])/g);
|
|
8199
|
+
// CSS allows for certain special characters to be used in selectors if they're escaped.
|
|
8200
|
+
// E.g. `.foo:blue` won't match a class called `foo:blue`, because the colon denotes a
|
|
8201
|
+
// pseudo-class, but writing `.foo\:blue` will match, because the colon was escaped.
|
|
8202
|
+
// Replace all escape sequences (`\` followed by a character) with a placeholder so
|
|
8203
|
+
// that our handling of pseudo-selectors doesn't mess with them.
|
|
8204
|
+
selector = this._escapeRegexMatches(selector, /(\\.)/g);
|
|
8197
8205
|
// Replaces the expression in `:nth-child(2n + 1)` with a placeholder.
|
|
8198
8206
|
// WS and "+" would otherwise be interpreted as selector separators.
|
|
8199
8207
|
this._content = selector.replace(/(:nth-[-\w]+)(\([^)]+\))/g, (_, pseudo, exp) => {
|
|
@@ -8204,11 +8212,23 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
8204
8212
|
});
|
|
8205
8213
|
}
|
|
8206
8214
|
restore(content) {
|
|
8207
|
-
return content.replace(/__ph-(\d+)__/g, (
|
|
8215
|
+
return content.replace(/__ph-(\d+)__/g, (_ph, index) => this.placeholders[+index]);
|
|
8208
8216
|
}
|
|
8209
8217
|
content() {
|
|
8210
8218
|
return this._content;
|
|
8211
8219
|
}
|
|
8220
|
+
/**
|
|
8221
|
+
* Replaces all of the substrings that match a regex within a
|
|
8222
|
+
* special string (e.g. `__ph-0__`, `__ph-1__`, etc).
|
|
8223
|
+
*/
|
|
8224
|
+
_escapeRegexMatches(content, pattern) {
|
|
8225
|
+
return content.replace(pattern, (_, keep) => {
|
|
8226
|
+
const replaceBy = `__ph-${this.index}__`;
|
|
8227
|
+
this.placeholders.push(keep);
|
|
8228
|
+
this.index++;
|
|
8229
|
+
return replaceBy;
|
|
8230
|
+
});
|
|
8231
|
+
}
|
|
8212
8232
|
}
|
|
8213
8233
|
const _cssContentNextSelectorRe = /polyfill-next-selector[^}]*content:[\s]*?(['"])(.*?)\1[;\s]*}([^{]*?){/gim;
|
|
8214
8234
|
const _cssContentRuleRe = /(polyfill-rule)[^}]*(content:[\s]*(['"])(.*?)\3)[;\s]*[^}]*}/gim;
|
|
@@ -8955,7 +8975,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
8955
8975
|
}
|
|
8956
8976
|
throw e;
|
|
8957
8977
|
}
|
|
8958
|
-
const contentTokenType = this._getTagDefinition(tagName).
|
|
8978
|
+
const contentTokenType = this._getTagDefinition(tagName).getContentType(prefix);
|
|
8959
8979
|
if (contentTokenType === TagContentType.RAW_TEXT) {
|
|
8960
8980
|
this._consumeRawTextWithTagClose(prefix, tagName, false);
|
|
8961
8981
|
}
|
|
@@ -8964,7 +8984,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
8964
8984
|
}
|
|
8965
8985
|
}
|
|
8966
8986
|
_consumeRawTextWithTagClose(prefix, tagName, decodeEntities) {
|
|
8967
|
-
|
|
8987
|
+
this._consumeRawText(decodeEntities, () => {
|
|
8968
8988
|
if (!this._attemptCharCode($LT))
|
|
8969
8989
|
return false;
|
|
8970
8990
|
if (!this._attemptCharCode($SLASH))
|
|
@@ -12946,19 +12966,6 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
12946
12966
|
this.errors = errors;
|
|
12947
12967
|
}
|
|
12948
12968
|
}
|
|
12949
|
-
const defaultInterpolateRegExp = _createInterpolateRegExp(DEFAULT_INTERPOLATION_CONFIG);
|
|
12950
|
-
function _getInterpolateRegExp(config) {
|
|
12951
|
-
if (config === DEFAULT_INTERPOLATION_CONFIG) {
|
|
12952
|
-
return defaultInterpolateRegExp;
|
|
12953
|
-
}
|
|
12954
|
-
else {
|
|
12955
|
-
return _createInterpolateRegExp(config);
|
|
12956
|
-
}
|
|
12957
|
-
}
|
|
12958
|
-
function _createInterpolateRegExp(config) {
|
|
12959
|
-
const pattern = escapeRegExp(config.start) + '([\\s\\S]*?)' + escapeRegExp(config.end);
|
|
12960
|
-
return new RegExp(pattern, 'g');
|
|
12961
|
-
}
|
|
12962
12969
|
class Parser$1 {
|
|
12963
12970
|
constructor(_lexer) {
|
|
12964
12971
|
this._lexer = _lexer;
|
|
@@ -13118,7 +13125,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
13118
13125
|
// parse from starting {{ to ending }} while ignoring content inside quotes.
|
|
13119
13126
|
const fullStart = i;
|
|
13120
13127
|
const exprStart = fullStart + interpStart.length;
|
|
13121
|
-
const exprEnd = this.
|
|
13128
|
+
const exprEnd = this._getInterpolationEndIndex(input, interpEnd, exprStart);
|
|
13122
13129
|
if (exprEnd === -1) {
|
|
13123
13130
|
// Could not find the end of the interpolation; do not parse an expression.
|
|
13124
13131
|
// Instead we should extend the content on the last raw string.
|
|
@@ -13177,50 +13184,64 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
13177
13184
|
}
|
|
13178
13185
|
return null;
|
|
13179
13186
|
}
|
|
13180
|
-
_checkNoInterpolation(input, location,
|
|
13181
|
-
|
|
13182
|
-
|
|
13183
|
-
|
|
13184
|
-
|
|
13187
|
+
_checkNoInterpolation(input, location, { start, end }) {
|
|
13188
|
+
let startIndex = -1;
|
|
13189
|
+
let endIndex = -1;
|
|
13190
|
+
for (const charIndex of this._forEachUnquotedChar(input, 0)) {
|
|
13191
|
+
if (startIndex === -1) {
|
|
13192
|
+
if (input.startsWith(start)) {
|
|
13193
|
+
startIndex = charIndex;
|
|
13194
|
+
}
|
|
13195
|
+
}
|
|
13196
|
+
else {
|
|
13197
|
+
endIndex = this._getInterpolationEndIndex(input, end, charIndex);
|
|
13198
|
+
if (endIndex > -1) {
|
|
13199
|
+
break;
|
|
13200
|
+
}
|
|
13201
|
+
}
|
|
13185
13202
|
}
|
|
13186
|
-
|
|
13187
|
-
|
|
13188
|
-
let errLocation = '';
|
|
13189
|
-
for (let j = 0; j < partInErrIdx; j++) {
|
|
13190
|
-
errLocation += j % 2 === 0 ?
|
|
13191
|
-
parts[j] :
|
|
13192
|
-
`${interpolationConfig.start}${parts[j]}${interpolationConfig.end}`;
|
|
13203
|
+
if (startIndex > -1 && endIndex > -1) {
|
|
13204
|
+
this._reportError(`Got interpolation (${start}${end}) where expression was expected`, input, `at column ${startIndex} in`, location);
|
|
13193
13205
|
}
|
|
13194
|
-
return errLocation.length;
|
|
13195
13206
|
}
|
|
13196
13207
|
/**
|
|
13197
13208
|
* Finds the index of the end of an interpolation expression
|
|
13198
13209
|
* while ignoring comments and quoted content.
|
|
13199
13210
|
*/
|
|
13200
|
-
|
|
13211
|
+
_getInterpolationEndIndex(input, expressionEnd, start) {
|
|
13212
|
+
for (const charIndex of this._forEachUnquotedChar(input, start)) {
|
|
13213
|
+
if (input.startsWith(expressionEnd, charIndex)) {
|
|
13214
|
+
return charIndex;
|
|
13215
|
+
}
|
|
13216
|
+
// Nothing else in the expression matters after we've
|
|
13217
|
+
// hit a comment so look directly for the end token.
|
|
13218
|
+
if (input.startsWith('//', charIndex)) {
|
|
13219
|
+
return input.indexOf(expressionEnd, charIndex);
|
|
13220
|
+
}
|
|
13221
|
+
}
|
|
13222
|
+
return -1;
|
|
13223
|
+
}
|
|
13224
|
+
/**
|
|
13225
|
+
* Generator used to iterate over the character indexes of a string that are outside of quotes.
|
|
13226
|
+
* @param input String to loop through.
|
|
13227
|
+
* @param start Index within the string at which to start.
|
|
13228
|
+
*/
|
|
13229
|
+
*_forEachUnquotedChar(input, start) {
|
|
13201
13230
|
let currentQuote = null;
|
|
13202
13231
|
let escapeCount = 0;
|
|
13203
13232
|
for (let i = start; i < input.length; i++) {
|
|
13204
13233
|
const char = input[i];
|
|
13205
|
-
// Skip the characters inside quotes. Note that we only care about the
|
|
13206
|
-
//
|
|
13234
|
+
// Skip the characters inside quotes. Note that we only care about the outer-most
|
|
13235
|
+
// quotes matching up and we need to account for escape characters.
|
|
13207
13236
|
if (isQuote(input.charCodeAt(i)) && (currentQuote === null || currentQuote === char) &&
|
|
13208
13237
|
escapeCount % 2 === 0) {
|
|
13209
13238
|
currentQuote = currentQuote === null ? char : null;
|
|
13210
13239
|
}
|
|
13211
13240
|
else if (currentQuote === null) {
|
|
13212
|
-
|
|
13213
|
-
return i;
|
|
13214
|
-
}
|
|
13215
|
-
// Nothing else in the expression matters after we've
|
|
13216
|
-
// hit a comment so look directly for the end token.
|
|
13217
|
-
if (input.startsWith('//', i)) {
|
|
13218
|
-
return input.indexOf(expressionEnd, i);
|
|
13219
|
-
}
|
|
13241
|
+
yield i;
|
|
13220
13242
|
}
|
|
13221
13243
|
escapeCount = char === '\\' ? escapeCount + 1 : 0;
|
|
13222
13244
|
}
|
|
13223
|
-
return -1;
|
|
13224
13245
|
}
|
|
13225
13246
|
}
|
|
13226
13247
|
class IvyParser extends Parser$1 {
|
|
@@ -18436,7 +18457,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
18436
18457
|
* Use of this source code is governed by an MIT-style license that can be
|
|
18437
18458
|
* found in the LICENSE file at https://angular.io/license
|
|
18438
18459
|
*/
|
|
18439
|
-
const VERSION$1 = new Version('11.0.
|
|
18460
|
+
const VERSION$1 = new Version('11.0.9');
|
|
18440
18461
|
|
|
18441
18462
|
/**
|
|
18442
18463
|
* @license
|
|
@@ -18867,31 +18888,6 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
18867
18888
|
_VisitorMode[_VisitorMode["Merge"] = 1] = "Merge";
|
|
18868
18889
|
})(_VisitorMode || (_VisitorMode = {}));
|
|
18869
18890
|
|
|
18870
|
-
/**
|
|
18871
|
-
* @license
|
|
18872
|
-
* Copyright Google LLC All Rights Reserved.
|
|
18873
|
-
*
|
|
18874
|
-
* Use of this source code is governed by an MIT-style license that can be
|
|
18875
|
-
* found in the LICENSE file at https://angular.io/license
|
|
18876
|
-
*/
|
|
18877
|
-
class XmlTagDefinition {
|
|
18878
|
-
constructor() {
|
|
18879
|
-
this.closedByParent = false;
|
|
18880
|
-
this.contentType = TagContentType.PARSABLE_DATA;
|
|
18881
|
-
this.isVoid = false;
|
|
18882
|
-
this.ignoreFirstLf = false;
|
|
18883
|
-
this.canSelfClose = true;
|
|
18884
|
-
this.preventNamespaceInheritance = false;
|
|
18885
|
-
}
|
|
18886
|
-
requireExtraParent(currentParent) {
|
|
18887
|
-
return false;
|
|
18888
|
-
}
|
|
18889
|
-
isClosedByChild(name) {
|
|
18890
|
-
return false;
|
|
18891
|
-
}
|
|
18892
|
-
}
|
|
18893
|
-
const _TAG_DEFINITION = new XmlTagDefinition();
|
|
18894
|
-
|
|
18895
18891
|
/**
|
|
18896
18892
|
* @license
|
|
18897
18893
|
* Copyright Google LLC All Rights Reserved.
|
|
@@ -24881,7 +24877,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
24881
24877
|
// any test cases for it.
|
|
24882
24878
|
const element = this.htmlPath.first(Element$1);
|
|
24883
24879
|
if (element &&
|
|
24884
|
-
getHtmlTagDefinition(element.name).
|
|
24880
|
+
getHtmlTagDefinition(element.name).getContentType() !== TagContentType.PARSABLE_DATA) {
|
|
24885
24881
|
return [];
|
|
24886
24882
|
}
|
|
24887
24883
|
// This is to account for cases like <h1> <a> text | </h1> where the
|
|
@@ -26933,6 +26929,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
26933
26929
|
// T_HOST is index 6
|
|
26934
26930
|
// We already have this constants in LView, we don't need to re-create it.
|
|
26935
26931
|
const NATIVE = 7;
|
|
26932
|
+
const VIEW_REFS = 8;
|
|
26936
26933
|
const MOVED_VIEWS = 9;
|
|
26937
26934
|
/**
|
|
26938
26935
|
* Size of LContainer's header. Represents the index after which all views in the
|
|
@@ -27891,8 +27888,9 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
27891
27888
|
(currentView[PREORDER_HOOK_FLAGS] & 65535 /* IndexOfTheNextPreOrderHookMaskMask */) :
|
|
27892
27889
|
0;
|
|
27893
27890
|
const nodeIndexLimit = currentNodeIndex != null ? currentNodeIndex : -1;
|
|
27891
|
+
const max = arr.length - 1; // Stop the loop at length - 1, because we look for the hook at i + 1
|
|
27894
27892
|
let lastNodeIndexFound = 0;
|
|
27895
|
-
for (let i = startIndex; i <
|
|
27893
|
+
for (let i = startIndex; i < max; i++) {
|
|
27896
27894
|
const hook = arr[i + 1];
|
|
27897
27895
|
if (typeof hook === 'number') {
|
|
27898
27896
|
lastNodeIndexFound = arr[i];
|
|
@@ -27929,8 +27927,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
27929
27927
|
const directive = currentView[directiveIndex];
|
|
27930
27928
|
if (isInitHook) {
|
|
27931
27929
|
const indexWithintInitPhase = currentView[FLAGS] >> 11 /* IndexWithinInitPhaseShift */;
|
|
27932
|
-
// The init phase state must be always checked here as it may have been recursively
|
|
27933
|
-
// updated
|
|
27930
|
+
// The init phase state must be always checked here as it may have been recursively updated.
|
|
27934
27931
|
if (indexWithintInitPhase <
|
|
27935
27932
|
(currentView[PREORDER_HOOK_FLAGS] >> 16 /* NumberOfInitHooksCalledShift */) &&
|
|
27936
27933
|
(currentView[FLAGS] & 3 /* InitPhaseStateMask */) === initPhase) {
|
|
@@ -29157,6 +29154,15 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
29157
29154
|
* Use of this source code is governed by an MIT-style license that can be
|
|
29158
29155
|
* found in the LICENSE file at https://angular.io/license
|
|
29159
29156
|
*/
|
|
29157
|
+
function removeFromArray(arr, index) {
|
|
29158
|
+
// perf: array.pop is faster than array.splice!
|
|
29159
|
+
if (index >= arr.length - 1) {
|
|
29160
|
+
return arr.pop();
|
|
29161
|
+
}
|
|
29162
|
+
else {
|
|
29163
|
+
return arr.splice(index, 1)[0];
|
|
29164
|
+
}
|
|
29165
|
+
}
|
|
29160
29166
|
function newArray$1(size, value) {
|
|
29161
29167
|
const list = [];
|
|
29162
29168
|
for (let i = 0; i < size; i++) {
|
|
@@ -29558,6 +29564,9 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
29558
29564
|
else if (meta instanceof Self || meta.ngMetadataName === 'Self' || meta === Self) {
|
|
29559
29565
|
flags |= InjectFlags.Self;
|
|
29560
29566
|
}
|
|
29567
|
+
else if (meta instanceof Host || meta.ngMetadataName === 'Host' || meta === Host) {
|
|
29568
|
+
flags |= InjectFlags.Host;
|
|
29569
|
+
}
|
|
29561
29570
|
else if (meta instanceof Inject || meta === Inject) {
|
|
29562
29571
|
type = meta.token;
|
|
29563
29572
|
}
|
|
@@ -30116,6 +30125,22 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
30116
30125
|
renderer.createElementNS(namespace, name);
|
|
30117
30126
|
}
|
|
30118
30127
|
}
|
|
30128
|
+
/**
|
|
30129
|
+
* Removes all DOM elements associated with a view.
|
|
30130
|
+
*
|
|
30131
|
+
* Because some root nodes of the view may be containers, we sometimes need
|
|
30132
|
+
* to propagate deeply into the nested containers to remove all elements in the
|
|
30133
|
+
* views beneath it.
|
|
30134
|
+
*
|
|
30135
|
+
* @param tView The `TView' of the `LView` from which elements should be added or removed
|
|
30136
|
+
* @param lView The view from which elements should be added or removed
|
|
30137
|
+
*/
|
|
30138
|
+
function removeViewFromContainer(tView, lView) {
|
|
30139
|
+
const renderer = lView[RENDERER];
|
|
30140
|
+
applyView(tView, lView, renderer, 2 /* Detach */, null, null);
|
|
30141
|
+
lView[HOST] = null;
|
|
30142
|
+
lView[T_HOST] = null;
|
|
30143
|
+
}
|
|
30119
30144
|
/**
|
|
30120
30145
|
* Detach a `LView` from the DOM by detaching its nodes.
|
|
30121
30146
|
*
|
|
@@ -30193,6 +30218,43 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
30193
30218
|
}
|
|
30194
30219
|
movedViews.splice(declarationViewIndex, 1);
|
|
30195
30220
|
}
|
|
30221
|
+
/**
|
|
30222
|
+
* Detaches a view from a container.
|
|
30223
|
+
*
|
|
30224
|
+
* This method removes the view from the container's array of active views. It also
|
|
30225
|
+
* removes the view's elements from the DOM.
|
|
30226
|
+
*
|
|
30227
|
+
* @param lContainer The container from which to detach a view
|
|
30228
|
+
* @param removeIndex The index of the view to detach
|
|
30229
|
+
* @returns Detached LView instance.
|
|
30230
|
+
*/
|
|
30231
|
+
function detachView(lContainer, removeIndex) {
|
|
30232
|
+
if (lContainer.length <= CONTAINER_HEADER_OFFSET)
|
|
30233
|
+
return;
|
|
30234
|
+
const indexInContainer = CONTAINER_HEADER_OFFSET + removeIndex;
|
|
30235
|
+
const viewToDetach = lContainer[indexInContainer];
|
|
30236
|
+
if (viewToDetach) {
|
|
30237
|
+
const declarationLContainer = viewToDetach[DECLARATION_LCONTAINER];
|
|
30238
|
+
if (declarationLContainer !== null && declarationLContainer !== lContainer) {
|
|
30239
|
+
detachMovedView(declarationLContainer, viewToDetach);
|
|
30240
|
+
}
|
|
30241
|
+
if (removeIndex > 0) {
|
|
30242
|
+
lContainer[indexInContainer - 1][NEXT] = viewToDetach[NEXT];
|
|
30243
|
+
}
|
|
30244
|
+
const removedLView = removeFromArray(lContainer, CONTAINER_HEADER_OFFSET + removeIndex);
|
|
30245
|
+
removeViewFromContainer(viewToDetach[TVIEW], viewToDetach);
|
|
30246
|
+
// notify query that a view has been removed
|
|
30247
|
+
const lQueries = removedLView[QUERIES];
|
|
30248
|
+
if (lQueries !== null) {
|
|
30249
|
+
lQueries.detachView(removedLView[TVIEW]);
|
|
30250
|
+
}
|
|
30251
|
+
viewToDetach[PARENT] = null;
|
|
30252
|
+
viewToDetach[NEXT] = null;
|
|
30253
|
+
// Unsets the attached flag
|
|
30254
|
+
viewToDetach[FLAGS] &= ~128 /* Attached */;
|
|
30255
|
+
}
|
|
30256
|
+
return viewToDetach;
|
|
30257
|
+
}
|
|
30196
30258
|
/**
|
|
30197
30259
|
* A standalone function which destroys an LView,
|
|
30198
30260
|
* conducting clean up (e.g. removing listeners, calling onDestroys).
|
|
@@ -30290,12 +30352,12 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
30290
30352
|
tCleanup[i].call(context);
|
|
30291
30353
|
}
|
|
30292
30354
|
}
|
|
30293
|
-
|
|
30294
|
-
|
|
30295
|
-
|
|
30296
|
-
|
|
30297
|
-
|
|
30298
|
-
|
|
30355
|
+
}
|
|
30356
|
+
if (lCleanup !== null) {
|
|
30357
|
+
for (let i = lastLCleanupIndex + 1; i < lCleanup.length; i++) {
|
|
30358
|
+
const instanceCleanupFn = lCleanup[i];
|
|
30359
|
+
ngDevMode && assertFunction(instanceCleanupFn, 'Expecting instance cleanup function.');
|
|
30360
|
+
instanceCleanupFn();
|
|
30299
30361
|
}
|
|
30300
30362
|
lView[CLEANUP] = null;
|
|
30301
30363
|
}
|
|
@@ -31924,19 +31986,19 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
31924
31986
|
* is `null` and the function is store in `LView` (rather than it `TView`).
|
|
31925
31987
|
*/
|
|
31926
31988
|
function storeCleanupWithContext(tView, lView, context, cleanupFn) {
|
|
31927
|
-
const lCleanup =
|
|
31989
|
+
const lCleanup = getOrCreateLViewCleanup(lView);
|
|
31928
31990
|
if (context === null) {
|
|
31929
31991
|
// If context is null that this is instance specific callback. These callbacks can only be
|
|
31930
31992
|
// inserted after template shared instances. For this reason in ngDevMode we freeze the TView.
|
|
31931
31993
|
if (ngDevMode) {
|
|
31932
|
-
Object.freeze(
|
|
31994
|
+
Object.freeze(getOrCreateTViewCleanup(tView));
|
|
31933
31995
|
}
|
|
31934
31996
|
lCleanup.push(cleanupFn);
|
|
31935
31997
|
}
|
|
31936
31998
|
else {
|
|
31937
31999
|
lCleanup.push(context);
|
|
31938
32000
|
if (tView.firstCreatePass) {
|
|
31939
|
-
|
|
32001
|
+
getOrCreateTViewCleanup(tView).push(cleanupFn, lCleanup.length - 1);
|
|
31940
32002
|
}
|
|
31941
32003
|
}
|
|
31942
32004
|
}
|
|
@@ -32408,11 +32470,11 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
32408
32470
|
viewQueryFn(flags, component);
|
|
32409
32471
|
}
|
|
32410
32472
|
const CLEAN_PROMISE = _CLEAN_PROMISE;
|
|
32411
|
-
function
|
|
32473
|
+
function getOrCreateLViewCleanup(view) {
|
|
32412
32474
|
// top level variables should not be exported for performance reasons (PERF_NOTES.md)
|
|
32413
32475
|
return view[CLEANUP] || (view[CLEANUP] = ngDevMode ? new LCleanup() : []);
|
|
32414
32476
|
}
|
|
32415
|
-
function
|
|
32477
|
+
function getOrCreateTViewCleanup(tView) {
|
|
32416
32478
|
return tView.cleanup || (tView.cleanup = ngDevMode ? new TCleanup() : []);
|
|
32417
32479
|
}
|
|
32418
32480
|
/** Handles an error thrown in an LView. */
|
|
@@ -34331,7 +34393,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
34331
34393
|
/**
|
|
34332
34394
|
* @publicApi
|
|
34333
34395
|
*/
|
|
34334
|
-
const VERSION$2 = new Version$1('11.0.
|
|
34396
|
+
const VERSION$2 = new Version$1('11.0.9');
|
|
34335
34397
|
|
|
34336
34398
|
/**
|
|
34337
34399
|
* @license
|
|
@@ -35490,7 +35552,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
35490
35552
|
this._lView = _lView;
|
|
35491
35553
|
this._cdRefInjectingView = _cdRefInjectingView;
|
|
35492
35554
|
this._appRef = null;
|
|
35493
|
-
this.
|
|
35555
|
+
this._attachedToViewContainer = false;
|
|
35494
35556
|
}
|
|
35495
35557
|
get rootNodes() {
|
|
35496
35558
|
const lView = this._lView;
|
|
@@ -35507,12 +35569,19 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
35507
35569
|
if (this._appRef) {
|
|
35508
35570
|
this._appRef.detachView(this);
|
|
35509
35571
|
}
|
|
35510
|
-
else if (this.
|
|
35511
|
-
const
|
|
35512
|
-
if (
|
|
35513
|
-
|
|
35572
|
+
else if (this._attachedToViewContainer) {
|
|
35573
|
+
const parent = this._lView[PARENT];
|
|
35574
|
+
if (isLContainer(parent)) {
|
|
35575
|
+
const viewRefs = parent[VIEW_REFS];
|
|
35576
|
+
const index = viewRefs ? viewRefs.indexOf(this) : -1;
|
|
35577
|
+
if (index > -1) {
|
|
35578
|
+
ngDevMode &&
|
|
35579
|
+
assertEqual(index, parent.indexOf(this._lView) - CONTAINER_HEADER_OFFSET, 'An attached view should be in the same position within its container as its ViewRef in the VIEW_REFS array.');
|
|
35580
|
+
detachView(parent, index);
|
|
35581
|
+
removeFromArray(viewRefs, index);
|
|
35582
|
+
}
|
|
35514
35583
|
}
|
|
35515
|
-
this.
|
|
35584
|
+
this._attachedToViewContainer = false;
|
|
35516
35585
|
}
|
|
35517
35586
|
destroyLView(this._lView[TVIEW], this._lView);
|
|
35518
35587
|
}
|
|
@@ -35704,18 +35773,18 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
35704
35773
|
checkNoChanges() {
|
|
35705
35774
|
checkNoChangesInternal(this._lView[TVIEW], this._lView, this.context);
|
|
35706
35775
|
}
|
|
35707
|
-
attachToViewContainerRef(
|
|
35776
|
+
attachToViewContainerRef() {
|
|
35708
35777
|
if (this._appRef) {
|
|
35709
35778
|
throw new Error('This view is already attached directly to the ApplicationRef!');
|
|
35710
35779
|
}
|
|
35711
|
-
this.
|
|
35780
|
+
this._attachedToViewContainer = true;
|
|
35712
35781
|
}
|
|
35713
35782
|
detachFromAppRef() {
|
|
35714
35783
|
this._appRef = null;
|
|
35715
35784
|
renderDetachView(this._lView[TVIEW], this._lView);
|
|
35716
35785
|
}
|
|
35717
35786
|
attachToAppRef(appRef) {
|
|
35718
|
-
if (this.
|
|
35787
|
+
if (this._attachedToViewContainer) {
|
|
35719
35788
|
throw new Error('This view is already attached to a ViewContainer!');
|
|
35720
35789
|
}
|
|
35721
35790
|
this._appRef = appRef;
|
|
@@ -38957,7 +39026,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
38957
39026
|
}
|
|
38958
39027
|
/**
|
|
38959
39028
|
* Creates a factory for a platform. Can be used to provide or override `Providers` specific to
|
|
38960
|
-
* your
|
|
39029
|
+
* your application's runtime needs, such as `PLATFORM_INITIALIZER` and `PLATFORM_ID`.
|
|
38961
39030
|
* @param parentPlatformFactory Another platform factory to modify. Allows you to compose factories
|
|
38962
39031
|
* to build up configurations that might be required by different libraries or parts of the
|
|
38963
39032
|
* application.
|
package/package.json
CHANGED
package/src/completions.js
CHANGED
|
@@ -194,7 +194,7 @@
|
|
|
194
194
|
// any test cases for it.
|
|
195
195
|
var element = this.htmlPath.first(compiler_1.Element);
|
|
196
196
|
if (element &&
|
|
197
|
-
compiler_1.getHtmlTagDefinition(element.name).
|
|
197
|
+
compiler_1.getHtmlTagDefinition(element.name).getContentType() !== compiler_1.TagContentType.PARSABLE_DATA) {
|
|
198
198
|
return [];
|
|
199
199
|
}
|
|
200
200
|
// This is to account for cases like <h1> <a> text | </h1> where the
|
|
@@ -666,4 +666,4 @@
|
|
|
666
666
|
return { templateRefs: templateRefs, inputs: inputs, outputs: outputs, bananas: bananas, others: others };
|
|
667
667
|
}
|
|
668
668
|
});
|
|
669
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"completions.js","sourceRoot":"","sources":["../../../../../../packages/language-service/src/completions.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 {AbsoluteSourceSpan, AST, AstPath, AttrAst, Attribute, BoundDirectivePropertyAst, BoundElementPropertyAst, BoundEventAst, BoundTextAst, Element, ElementAst, EmptyExpr, ExpressionBinding, getHtmlTagDefinition, HtmlAstPath, Node as HtmlAst, NullTemplateVisitor, ParseSpan, ReferenceAst, TagContentType, TemplateBinding, Text, VariableBinding, Visitor} from '@angular/compiler';\nimport {$$, $_, isAsciiLetter, isDigit} from '@angular/compiler/src/chars';\n\nimport {ATTR, getBindingDescriptor} from './binding_utils';\nimport {getExpressionScope} from './expression_diagnostics';\nimport {getExpressionCompletions} from './expressions';\nimport {attributeNames, elementNames, eventNames, propertyNames} from './html_info';\nimport {InlineTemplate} from './template';\nimport * as ng from './types';\nimport {diagnosticInfoFromTemplateInfo, findTemplateAstAt, getPathToNodeAtPosition, getSelectors, inSpan, isStructuralDirective, spanOf} from './utils';\n\nconst HIDDEN_HTML_ELEMENTS: ReadonlySet<string> =\n    new Set(['html', 'script', 'noscript', 'base', 'body', 'title', 'head', 'link']);\nconst HTML_ELEMENTS: ReadonlyArray<ng.CompletionEntry> =\n    elementNames().filter(name => !HIDDEN_HTML_ELEMENTS.has(name)).map(name => {\n      return {\n        name,\n        kind: ng.CompletionKind.HTML_ELEMENT,\n        sortText: name,\n      };\n    });\nconst ANGULAR_ELEMENTS: ReadonlyArray<ng.CompletionEntry> = [\n  {\n    name: 'ng-container',\n    kind: ng.CompletionKind.ANGULAR_ELEMENT,\n    sortText: 'ng-container',\n  },\n  {\n    name: 'ng-content',\n    kind: ng.CompletionKind.ANGULAR_ELEMENT,\n    sortText: 'ng-content',\n  },\n  {\n    name: 'ng-template',\n    kind: ng.CompletionKind.ANGULAR_ELEMENT,\n    sortText: 'ng-template',\n  },\n];\n\nfunction isIdentifierPart(code: number) {\n  // Identifiers consist of alphanumeric characters, '_', or '$'.\n  return isAsciiLetter(code) || isDigit(code) || code == $$ || code == $_;\n}\n\n/**\n * Gets the span of word in a template that surrounds `position`. If there is no word around\n * `position`, nothing is returned.\n */\nfunction getBoundedWordSpan(\n    templateInfo: ng.AstResult, position: number, ast: HtmlAst|undefined): ts.TextSpan|undefined {\n  const {template} = templateInfo;\n  const templateSrc = template.source;\n\n  if (!templateSrc) return;\n\n  if (ast instanceof Element) {\n    // The HTML tag may include `-` (e.g. `app-root`),\n    // so use the HtmlAst to get the span before ayazhafiz refactor the code.\n    return {\n      start: templateInfo.template.span.start + ast.startSourceSpan.start.offset + 1,\n      length: ast.name.length\n    };\n  }\n\n  // TODO(ayazhafiz): A solution based on word expansion will always be expensive compared to one\n  // based on ASTs. Whatever penalty we incur is probably manageable for small-length (i.e. the\n  // majority of) identifiers, but the current solution involes a number of branchings and we can't\n  // control potentially very long identifiers. Consider moving to an AST-based solution once\n  // existing difficulties with AST spans are more clearly resolved (see #31898 for discussion of\n  // known problems, and #33091 for how they affect text replacement).\n  //\n  // `templatePosition` represents the right-bound location of a cursor in the template.\n  //    key.ent|ry\n  //           ^---- cursor, at position `r` is at.\n  // A cursor is not itself a character in the template; it has a left (lower) and right (upper)\n  // index bound that hugs the cursor itself.\n  let templatePosition = position - template.span.start;\n  // To perform word expansion, we want to determine the left and right indices that hug the cursor.\n  // There are three cases here.\n  let left, right;\n  if (templatePosition === 0) {\n    // 1. Case like\n    //      |rest of template\n    //    the cursor is at the start of the template, hugged only by the right side (0-index).\n    left = right = 0;\n  } else if (templatePosition === templateSrc.length) {\n    // 2. Case like\n    //      rest of template|\n    //    the cursor is at the end of the template, hugged only by the left side (last-index).\n    left = right = templateSrc.length - 1;\n  } else {\n    // 3. Case like\n    //      wo|rd\n    //    there is a clear left and right index.\n    left = templatePosition - 1;\n    right = templatePosition;\n  }\n\n  if (!isIdentifierPart(templateSrc.charCodeAt(left)) &&\n      !isIdentifierPart(templateSrc.charCodeAt(right))) {\n    // Case like\n    //         .|.\n    // left ---^ ^--- right\n    // There is no word here.\n    return;\n  }\n\n  // Expand on the left and right side until a word boundary is hit. Back up one expansion on both\n  // side to stay inside the word.\n  while (left >= 0 && isIdentifierPart(templateSrc.charCodeAt(left))) --left;\n  ++left;\n  while (right < templateSrc.length && isIdentifierPart(templateSrc.charCodeAt(right))) ++right;\n  --right;\n\n  const absoluteStartPosition = position - (templatePosition - left);\n  const length = right - left + 1;\n  return {start: absoluteStartPosition, length};\n}\n\nexport function getTemplateCompletions(\n    templateInfo: ng.AstResult, position: number): ng.CompletionEntry[] {\n  const {htmlAst, template} = templateInfo;\n  // Calculate the position relative to the start of the template. This is needed\n  // because spans in HTML AST are relative. Inline template has non-zero start position.\n  const templatePosition = position - template.span.start;\n  const htmlPath: HtmlAstPath = getPathToNodeAtPosition(htmlAst, templatePosition);\n  const mostSpecific = htmlPath.tail;\n  const visitor = new HtmlVisitor(templateInfo, htmlPath);\n  const results: ng.CompletionEntry[] = mostSpecific ?\n      mostSpecific.visit(visitor, null /* context */) :\n      elementCompletions(templateInfo);\n  const replacementSpan = getBoundedWordSpan(templateInfo, position, mostSpecific);\n  return results.map(entry => {\n    return {\n      ...entry,\n      replacementSpan,\n    };\n  });\n}\n\nclass HtmlVisitor implements Visitor {\n  /**\n   * Position relative to the start of the template.\n   */\n  private readonly relativePosition: number;\n  constructor(private readonly templateInfo: ng.AstResult, private readonly htmlPath: HtmlAstPath) {\n    this.relativePosition = htmlPath.position;\n  }\n  // Note that every visitor method must explicitly specify return type because\n  // Visitor returns `any` for all methods.\n  visitElement(ast: Element): ng.CompletionEntry[] {\n    const startTagSpan = spanOf(ast.sourceSpan);\n    const tagLen = ast.name.length;\n    // + 1 for the opening angle bracket\n    if (this.relativePosition <= startTagSpan.start + tagLen + 1) {\n      // If we are in the tag then return the element completions.\n      return elementCompletions(this.templateInfo);\n    }\n    if (this.relativePosition < startTagSpan.end) {\n      // We are in the attribute section of the element (but not in an attribute).\n      // Return the attribute completions.\n      return attributeCompletionsForElement(this.templateInfo, ast.name);\n    }\n    return [];\n  }\n  visitAttribute(ast: Attribute): ng.CompletionEntry[] {\n    // An attribute consists of two parts, LHS=\"RHS\".\n    // Determine if completions are requested for LHS or RHS\n    if (ast.valueSpan && inSpan(this.relativePosition, spanOf(ast.valueSpan))) {\n      // RHS completion\n      return attributeValueCompletions(this.templateInfo, this.htmlPath);\n    }\n    // LHS completion\n    return attributeCompletions(this.templateInfo, this.htmlPath);\n  }\n  visitText(): ng.CompletionEntry[] {\n    const templatePath = findTemplateAstAt(this.templateInfo.templateAst, this.relativePosition);\n    if (templatePath.tail instanceof BoundTextAst) {\n      // If we know that this is an interpolation then do not try other scenarios.\n      const visitor = new ExpressionVisitor(\n          this.templateInfo, this.relativePosition,\n          () =>\n              getExpressionScope(diagnosticInfoFromTemplateInfo(this.templateInfo), templatePath));\n      templatePath.tail?.visit(visitor, null);\n      return visitor.results;\n    }\n    // TODO(kyliau): Not sure if this check is really needed since we don't have\n    // any test cases for it.\n    const element = this.htmlPath.first(Element);\n    if (element &&\n        getHtmlTagDefinition(element.name).contentType !== TagContentType.PARSABLE_DATA) {\n      return [];\n    }\n    // This is to account for cases like <h1> <a> text | </h1> where the\n    // closest element has no closing tag and thus is considered plain text.\n    const results = voidElementAttributeCompletions(this.templateInfo, this.htmlPath);\n    if (results.length) {\n      return results;\n    }\n    return elementCompletions(this.templateInfo);\n  }\n  visitComment(): ng.CompletionEntry[] {\n    return [];\n  }\n  visitExpansion(): ng.CompletionEntry[] {\n    return [];\n  }\n  visitExpansionCase(): ng.CompletionEntry[] {\n    return [];\n  }\n}\n\nfunction attributeCompletions(info: ng.AstResult, path: AstPath<HtmlAst>): ng.CompletionEntry[] {\n  const attr = path.tail;\n  const elem = path.parentOf(attr);\n  if (!(attr instanceof Attribute) || !(elem instanceof Element)) {\n    return [];\n  }\n\n  // TODO: Consider parsing the attrinute name to a proper AST instead of\n  // matching using regex. This is because the regexp would incorrectly identify\n  // bind parts for cases like [()|]\n  //                              ^ cursor is here\n  const binding = getBindingDescriptor(attr.name);\n  if (!binding) {\n    // This is a normal HTML attribute, not an Angular attribute.\n    return attributeCompletionsForElement(info, elem.name);\n  }\n\n  const results: string[] = [];\n  const ngAttrs = angularAttributes(info, elem.name);\n  switch (binding.kind) {\n    case ATTR.KW_MICROSYNTAX:\n      // template reference attribute: *attrName\n      results.push(...ngAttrs.templateRefs);\n      break;\n\n    case ATTR.KW_BIND:\n    case ATTR.IDENT_PROPERTY:\n      // property binding via bind- or []\n      results.push(...propertyNames(elem.name), ...ngAttrs.inputs);\n      break;\n\n    case ATTR.KW_ON:\n    case ATTR.IDENT_EVENT:\n      // event binding via on- or ()\n      results.push(...eventNames(elem.name), ...ngAttrs.outputs);\n      break;\n\n    case ATTR.KW_BINDON:\n    case ATTR.IDENT_BANANA_BOX:\n      // banana-in-a-box binding via bindon- or [()]\n      results.push(...ngAttrs.bananas);\n      break;\n  }\n\n  return results.map(name => {\n    return {\n      name,\n      kind: ng.CompletionKind.ATTRIBUTE,\n      sortText: name,\n    };\n  });\n}\n\nfunction attributeCompletionsForElement(\n    info: ng.AstResult, elementName: string): ng.CompletionEntry[] {\n  const results: ng.CompletionEntry[] = [];\n\n  if (info.template instanceof InlineTemplate) {\n    // Provide HTML attributes completion only for inline templates\n    for (const name of attributeNames(elementName)) {\n      results.push({\n        name,\n        kind: ng.CompletionKind.HTML_ATTRIBUTE,\n        sortText: name,\n      });\n    }\n  }\n\n  // Add Angular attributes\n  const ngAttrs = angularAttributes(info, elementName);\n  for (const name of ngAttrs.others) {\n    results.push({\n      name,\n      kind: ng.CompletionKind.ATTRIBUTE,\n      sortText: name,\n    });\n  }\n\n  return results;\n}\n\n/**\n * Provide completions to the RHS of an attribute, which is of the form\n * LHS=\"RHS\". The template path is computed from the specified `info` whereas\n * the context is determined from the specified `htmlPath`.\n * @param info Object that contains the template AST\n * @param htmlPath Path to the HTML node\n */\nfunction attributeValueCompletions(\n    info: ng.AstResult, htmlPath: HtmlAstPath): ng.CompletionEntry[] {\n  // Find the corresponding Template AST path.\n  const templatePath = findTemplateAstAt(info.templateAst, htmlPath.position);\n  const visitor = new ExpressionVisitor(info, htmlPath.position, () => {\n    const dinfo = diagnosticInfoFromTemplateInfo(info);\n    return getExpressionScope(dinfo, templatePath);\n  });\n  if (templatePath.tail instanceof AttrAst ||\n      templatePath.tail instanceof BoundElementPropertyAst ||\n      templatePath.tail instanceof BoundEventAst) {\n    templatePath.tail.visit(visitor, null);\n    return visitor.results;\n  }\n  // In order to provide accurate attribute value completion, we need to know\n  // what the LHS is, and construct the proper AST if it is missing.\n  const htmlAttr = htmlPath.tail as Attribute;\n  const binding = getBindingDescriptor(htmlAttr.name);\n  if (binding && binding.kind === ATTR.KW_REF) {\n    let refAst: ReferenceAst|undefined;\n    let elemAst: ElementAst|undefined;\n    if (templatePath.tail instanceof ReferenceAst) {\n      refAst = templatePath.tail;\n      const parent = templatePath.parentOf(refAst);\n      if (parent instanceof ElementAst) {\n        elemAst = parent;\n      }\n    } else if (templatePath.tail instanceof ElementAst) {\n      refAst = new ReferenceAst(htmlAttr.name, null!, htmlAttr.value, htmlAttr.valueSpan!);\n      elemAst = templatePath.tail;\n    }\n    if (refAst && elemAst) {\n      refAst.visit(visitor, elemAst);\n    }\n  } else {\n    // HtmlAst contains the `Attribute` node, however the corresponding `AttrAst`\n    // node is missing from the TemplateAst.\n    const attrAst = new AttrAst(htmlAttr.name, htmlAttr.value, htmlAttr.valueSpan!);\n    attrAst.visit(visitor, null);\n  }\n  return visitor.results;\n}\n\nfunction elementCompletions(info: ng.AstResult): ng.CompletionEntry[] {\n  const results: ng.CompletionEntry[] = [...ANGULAR_ELEMENTS];\n\n  if (info.template instanceof InlineTemplate) {\n    // Provide HTML elements completion only for inline templates\n    results.push(...HTML_ELEMENTS);\n  }\n\n  // Collect the elements referenced by the selectors\n  const components = new Set<string>();\n  for (const selector of getSelectors(info).selectors) {\n    const name = selector.element;\n    if (name && !components.has(name)) {\n      components.add(name);\n      results.push({\n        name,\n        kind: ng.CompletionKind.COMPONENT,\n        sortText: name,\n      });\n    }\n  }\n\n  return results;\n}\n\n// There is a special case of HTML where text that contains a unclosed tag is treated as\n// text. For exaple '<h1> Some <a text </h1>' produces a text nodes inside of the H1\n// element \"Some <a text\". We, however, want to treat this as if the user was requesting\n// the attributes of an \"a\" element, not requesting completion in the a text element. This\n// code checks for this case and returns element completions if it is detected or undefined\n// if it is not.\nfunction voidElementAttributeCompletions(\n    info: ng.AstResult, path: AstPath<HtmlAst>): ng.CompletionEntry[] {\n  const tail = path.tail;\n  if (tail instanceof Text) {\n    const match = tail.value.match(/<(\\w(\\w|\\d|-)*:)?(\\w(\\w|\\d|-)*)\\s/);\n    // The position must be after the match, otherwise we are still in a place where elements\n    // are expected (such as `<|a` or `<a|`; we only want attributes for `<a |` or after).\n    if (match &&\n        path.position >= (match.index || 0) + match[0].length + tail.sourceSpan.start.offset) {\n      return attributeCompletionsForElement(info, match[3]);\n    }\n  }\n  return [];\n}\n\nclass ExpressionVisitor extends NullTemplateVisitor {\n  private readonly completions = new Map<string, ng.CompletionEntry>();\n\n  constructor(\n      private readonly info: ng.AstResult, private readonly position: number,\n      private readonly getExpressionScope: () => ng.SymbolTable) {\n    super();\n  }\n\n  get results(): ng.CompletionEntry[] {\n    return Array.from(this.completions.values());\n  }\n\n  visitDirectiveProperty(ast: BoundDirectivePropertyAst): void {\n    this.processExpressionCompletions(ast.value);\n  }\n\n  visitElementProperty(ast: BoundElementPropertyAst): void {\n    this.processExpressionCompletions(ast.value);\n  }\n\n  visitEvent(ast: BoundEventAst): void {\n    this.processExpressionCompletions(ast.handler);\n  }\n\n  visitElement(): void {\n    // no-op for now\n  }\n\n  visitAttr(ast: AttrAst) {\n    const binding = getBindingDescriptor(ast.name);\n    if (binding && binding.kind === ATTR.KW_MICROSYNTAX) {\n      // This a template binding given by micro syntax expression.\n      // First, verify the attribute consists of some binding we can give completions for.\n      // The sourceSpan of AttrAst points to the RHS of the attribute\n      const templateKey = binding.name;\n      const templateValue = ast.sourceSpan.toString();\n      const templateUrl = ast.sourceSpan.start.file.url;\n      // TODO(kyliau): We are unable to determine the absolute offset of the key\n      // but it is okay here, because we are only looking at the RHS of the attr\n      const absKeyOffset = 0;\n      const absValueOffset = ast.sourceSpan.start.offset;\n      const {templateBindings} = this.info.expressionParser.parseTemplateBindings(\n          templateKey, templateValue, templateUrl, absKeyOffset, absValueOffset);\n      // Find the nearest template binding to the position.\n      const lastBindingEnd = templateBindings.length > 0 &&\n          templateBindings[templateBindings.length - 1].sourceSpan.end;\n      const normalizedPositionToBinding =\n          lastBindingEnd && this.position > lastBindingEnd ? lastBindingEnd : this.position;\n      const templateBinding =\n          templateBindings.find(b => inSpan(normalizedPositionToBinding, b.sourceSpan));\n\n      if (!templateBinding) {\n        return;\n      }\n\n      this.microSyntaxInAttributeValue(ast, templateBinding);\n    } else {\n      const expressionAst = this.info.expressionParser.parseBinding(\n          ast.value, ast.sourceSpan.toString(), ast.sourceSpan.start.offset);\n      this.processExpressionCompletions(expressionAst);\n    }\n  }\n\n  visitReference(_ast: ReferenceAst, context: ElementAst) {\n    context.directives.forEach(dir => {\n      const {exportAs} = dir.directive;\n      if (exportAs) {\n        this.completions.set(\n            exportAs, {name: exportAs, kind: ng.CompletionKind.REFERENCE, sortText: exportAs});\n      }\n    });\n  }\n\n  visitBoundText(ast: BoundTextAst) {\n    if (inSpan(this.position, ast.value.sourceSpan)) {\n      const completions = getExpressionCompletions(\n          this.getExpressionScope(), ast.value, this.position, this.info.template);\n      if (completions) {\n        this.addSymbolsToCompletions(completions);\n      }\n    }\n  }\n\n  private processExpressionCompletions(value: AST) {\n    const symbols = getExpressionCompletions(\n        this.getExpressionScope(), value, this.position, this.info.template);\n    if (symbols) {\n      this.addSymbolsToCompletions(symbols);\n    }\n  }\n\n  private addSymbolsToCompletions(symbols: ng.Symbol[]) {\n    for (const s of symbols) {\n      if (s.name.startsWith('__') || !s.public || this.completions.has(s.name)) {\n        continue;\n      }\n\n      // The pipe method should not include parentheses.\n      // e.g. {{ value_expression | slice : start [ : end ] }}\n      const shouldInsertParentheses = s.callable && s.kind !== ng.CompletionKind.PIPE;\n      this.completions.set(s.name, {\n        name: s.name,\n        kind: s.kind as ng.CompletionKind,\n        sortText: s.name,\n        insertText: shouldInsertParentheses ? `${s.name}()` : s.name,\n      });\n    }\n  }\n\n  /**\n   * This method handles the completions of attribute values for directives that\n   * support the microsyntax format. Examples are *ngFor and *ngIf.\n   * These directives allows declaration of \"let\" variables, adds context-specific\n   * symbols like $implicit, index, count, among other behaviors.\n   * For a complete description of such format, see\n   * https://angular.io/guide/structural-directives#the-asterisk--prefix\n   *\n   * @param attr descriptor for attribute name and value pair\n   * @param binding template binding for the expression in the attribute\n   */\n  private microSyntaxInAttributeValue(attr: AttrAst, binding: TemplateBinding) {\n    const key = attr.name.substring(1);  // remove leading asterisk\n\n    // Find the selector - eg ngFor, ngIf, etc\n    const selectorInfo = getSelectors(this.info);\n    const selector = selectorInfo.selectors.find(s => {\n      // attributes are listed in (attribute, value) pairs\n      for (let i = 0; i < s.attrs.length; i += 2) {\n        if (s.attrs[i] === key) {\n          return true;\n        }\n      }\n    });\n\n    if (!selector) {\n      return;\n    }\n\n    const valueRelativePosition = this.position - attr.sourceSpan.start.offset;\n\n    if (binding instanceof VariableBinding) {\n      // TODO(kyliau): With expression sourceSpan we shouldn't have to search\n      // the attribute value string anymore. Just check if position is in the\n      // expression source span.\n      const equalLocation = attr.value.indexOf('=');\n      if (equalLocation > 0 && valueRelativePosition > equalLocation) {\n        // We are after the '=' in a let clause. The valid values here are the members of the\n        // template reference's type parameter.\n        const directiveMetadata = selectorInfo.map.get(selector);\n        if (directiveMetadata) {\n          const contextTable =\n              this.info.template.query.getTemplateContext(directiveMetadata.type.reference);\n          if (contextTable) {\n            // This adds symbols like $implicit, index, count, etc.\n            this.addSymbolsToCompletions(contextTable.values());\n            return;\n          }\n        }\n      }\n    } else if (binding instanceof ExpressionBinding) {\n      if (inSpan(this.position, binding.value?.ast.sourceSpan)) {\n        this.processExpressionCompletions(binding.value!.ast);\n        return;\n      } else if (!binding.value && this.position > binding.key.span.end) {\n        // No expression is defined for the value of the key expression binding, but the cursor is\n        // in a location where the expression would be defined. This can happen in a case like\n        //   let i of |\n        //            ^-- cursor\n        // In this case, backfill the value to be an empty expression and retrieve completions.\n        this.processExpressionCompletions(new EmptyExpr(\n            new ParseSpan(valueRelativePosition, valueRelativePosition),\n            new AbsoluteSourceSpan(this.position, this.position)));\n        return;\n      }\n    }\n  }\n}\n\ninterface AngularAttributes {\n  /**\n   * Attributes that support the * syntax. See https://angular.io/api/core/TemplateRef\n   */\n  templateRefs: Set<string>;\n  /**\n   * Attributes with the @Input annotation.\n   */\n  inputs: Set<string>;\n  /**\n   * Attributes with the @Output annotation.\n   */\n  outputs: Set<string>;\n  /**\n   * Attributes that support the [()] or bindon- syntax.\n   */\n  bananas: Set<string>;\n  /**\n   * General attributes that match the specified element.\n   */\n  others: Set<string>;\n}\n\n/**\n * Return all Angular-specific attributes for the element with `elementName`.\n * @param info\n * @param elementName\n */\nfunction angularAttributes(info: ng.AstResult, elementName: string): AngularAttributes {\n  const {selectors, map: selectorMap} = getSelectors(info);\n  const templateRefs = new Set<string>();\n  const inputs = new Set<string>();\n  const outputs = new Set<string>();\n  const bananas = new Set<string>();\n  const others = new Set<string>();\n  for (const selector of selectors) {\n    if (selector.element && selector.element !== elementName) {\n      continue;\n    }\n    const summary = selectorMap.get(selector)!;\n    const hasTemplateRef = isStructuralDirective(summary.type);\n    // attributes are listed in (attribute, value) pairs\n    for (let i = 0; i < selector.attrs.length; i += 2) {\n      const attr = selector.attrs[i];\n      if (hasTemplateRef) {\n        templateRefs.add(attr);\n      } else {\n        others.add(attr);\n      }\n    }\n    for (const input of Object.values(summary.inputs)) {\n      inputs.add(input);\n    }\n    for (const output of Object.values(summary.outputs)) {\n      outputs.add(output);\n    }\n  }\n  for (const name of inputs) {\n    // Add banana-in-a-box syntax\n    // https://angular.io/guide/template-syntax#two-way-binding-\n    if (outputs.has(`${name}Change`)) {\n      bananas.add(name);\n    }\n  }\n  return {templateRefs, inputs, outputs, bananas, others};\n}\n"]}
|
|
669
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"completions.js","sourceRoot":"","sources":["../../../../../../packages/language-service/src/completions.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 {AbsoluteSourceSpan, AST, AstPath, AttrAst, Attribute, BoundDirectivePropertyAst, BoundElementPropertyAst, BoundEventAst, BoundTextAst, Element, ElementAst, EmptyExpr, ExpressionBinding, getHtmlTagDefinition, HtmlAstPath, Node as HtmlAst, NullTemplateVisitor, ParseSpan, ReferenceAst, TagContentType, TemplateBinding, Text, VariableBinding, Visitor} from '@angular/compiler';\nimport {$$, $_, isAsciiLetter, isDigit} from '@angular/compiler/src/chars';\n\nimport {ATTR, getBindingDescriptor} from './binding_utils';\nimport {getExpressionScope} from './expression_diagnostics';\nimport {getExpressionCompletions} from './expressions';\nimport {attributeNames, elementNames, eventNames, propertyNames} from './html_info';\nimport {InlineTemplate} from './template';\nimport * as ng from './types';\nimport {diagnosticInfoFromTemplateInfo, findTemplateAstAt, getPathToNodeAtPosition, getSelectors, inSpan, isStructuralDirective, spanOf} from './utils';\n\nconst HIDDEN_HTML_ELEMENTS: ReadonlySet<string> =\n    new Set(['html', 'script', 'noscript', 'base', 'body', 'title', 'head', 'link']);\nconst HTML_ELEMENTS: ReadonlyArray<ng.CompletionEntry> =\n    elementNames().filter(name => !HIDDEN_HTML_ELEMENTS.has(name)).map(name => {\n      return {\n        name,\n        kind: ng.CompletionKind.HTML_ELEMENT,\n        sortText: name,\n      };\n    });\nconst ANGULAR_ELEMENTS: ReadonlyArray<ng.CompletionEntry> = [\n  {\n    name: 'ng-container',\n    kind: ng.CompletionKind.ANGULAR_ELEMENT,\n    sortText: 'ng-container',\n  },\n  {\n    name: 'ng-content',\n    kind: ng.CompletionKind.ANGULAR_ELEMENT,\n    sortText: 'ng-content',\n  },\n  {\n    name: 'ng-template',\n    kind: ng.CompletionKind.ANGULAR_ELEMENT,\n    sortText: 'ng-template',\n  },\n];\n\nfunction isIdentifierPart(code: number) {\n  // Identifiers consist of alphanumeric characters, '_', or '$'.\n  return isAsciiLetter(code) || isDigit(code) || code == $$ || code == $_;\n}\n\n/**\n * Gets the span of word in a template that surrounds `position`. If there is no word around\n * `position`, nothing is returned.\n */\nfunction getBoundedWordSpan(\n    templateInfo: ng.AstResult, position: number, ast: HtmlAst|undefined): ts.TextSpan|undefined {\n  const {template} = templateInfo;\n  const templateSrc = template.source;\n\n  if (!templateSrc) return;\n\n  if (ast instanceof Element) {\n    // The HTML tag may include `-` (e.g. `app-root`),\n    // so use the HtmlAst to get the span before ayazhafiz refactor the code.\n    return {\n      start: templateInfo.template.span.start + ast.startSourceSpan.start.offset + 1,\n      length: ast.name.length\n    };\n  }\n\n  // TODO(ayazhafiz): A solution based on word expansion will always be expensive compared to one\n  // based on ASTs. Whatever penalty we incur is probably manageable for small-length (i.e. the\n  // majority of) identifiers, but the current solution involes a number of branchings and we can't\n  // control potentially very long identifiers. Consider moving to an AST-based solution once\n  // existing difficulties with AST spans are more clearly resolved (see #31898 for discussion of\n  // known problems, and #33091 for how they affect text replacement).\n  //\n  // `templatePosition` represents the right-bound location of a cursor in the template.\n  //    key.ent|ry\n  //           ^---- cursor, at position `r` is at.\n  // A cursor is not itself a character in the template; it has a left (lower) and right (upper)\n  // index bound that hugs the cursor itself.\n  let templatePosition = position - template.span.start;\n  // To perform word expansion, we want to determine the left and right indices that hug the cursor.\n  // There are three cases here.\n  let left, right;\n  if (templatePosition === 0) {\n    // 1. Case like\n    //      |rest of template\n    //    the cursor is at the start of the template, hugged only by the right side (0-index).\n    left = right = 0;\n  } else if (templatePosition === templateSrc.length) {\n    // 2. Case like\n    //      rest of template|\n    //    the cursor is at the end of the template, hugged only by the left side (last-index).\n    left = right = templateSrc.length - 1;\n  } else {\n    // 3. Case like\n    //      wo|rd\n    //    there is a clear left and right index.\n    left = templatePosition - 1;\n    right = templatePosition;\n  }\n\n  if (!isIdentifierPart(templateSrc.charCodeAt(left)) &&\n      !isIdentifierPart(templateSrc.charCodeAt(right))) {\n    // Case like\n    //         .|.\n    // left ---^ ^--- right\n    // There is no word here.\n    return;\n  }\n\n  // Expand on the left and right side until a word boundary is hit. Back up one expansion on both\n  // side to stay inside the word.\n  while (left >= 0 && isIdentifierPart(templateSrc.charCodeAt(left))) --left;\n  ++left;\n  while (right < templateSrc.length && isIdentifierPart(templateSrc.charCodeAt(right))) ++right;\n  --right;\n\n  const absoluteStartPosition = position - (templatePosition - left);\n  const length = right - left + 1;\n  return {start: absoluteStartPosition, length};\n}\n\nexport function getTemplateCompletions(\n    templateInfo: ng.AstResult, position: number): ng.CompletionEntry[] {\n  const {htmlAst, template} = templateInfo;\n  // Calculate the position relative to the start of the template. This is needed\n  // because spans in HTML AST are relative. Inline template has non-zero start position.\n  const templatePosition = position - template.span.start;\n  const htmlPath: HtmlAstPath = getPathToNodeAtPosition(htmlAst, templatePosition);\n  const mostSpecific = htmlPath.tail;\n  const visitor = new HtmlVisitor(templateInfo, htmlPath);\n  const results: ng.CompletionEntry[] = mostSpecific ?\n      mostSpecific.visit(visitor, null /* context */) :\n      elementCompletions(templateInfo);\n  const replacementSpan = getBoundedWordSpan(templateInfo, position, mostSpecific);\n  return results.map(entry => {\n    return {\n      ...entry,\n      replacementSpan,\n    };\n  });\n}\n\nclass HtmlVisitor implements Visitor {\n  /**\n   * Position relative to the start of the template.\n   */\n  private readonly relativePosition: number;\n  constructor(private readonly templateInfo: ng.AstResult, private readonly htmlPath: HtmlAstPath) {\n    this.relativePosition = htmlPath.position;\n  }\n  // Note that every visitor method must explicitly specify return type because\n  // Visitor returns `any` for all methods.\n  visitElement(ast: Element): ng.CompletionEntry[] {\n    const startTagSpan = spanOf(ast.sourceSpan);\n    const tagLen = ast.name.length;\n    // + 1 for the opening angle bracket\n    if (this.relativePosition <= startTagSpan.start + tagLen + 1) {\n      // If we are in the tag then return the element completions.\n      return elementCompletions(this.templateInfo);\n    }\n    if (this.relativePosition < startTagSpan.end) {\n      // We are in the attribute section of the element (but not in an attribute).\n      // Return the attribute completions.\n      return attributeCompletionsForElement(this.templateInfo, ast.name);\n    }\n    return [];\n  }\n  visitAttribute(ast: Attribute): ng.CompletionEntry[] {\n    // An attribute consists of two parts, LHS=\"RHS\".\n    // Determine if completions are requested for LHS or RHS\n    if (ast.valueSpan && inSpan(this.relativePosition, spanOf(ast.valueSpan))) {\n      // RHS completion\n      return attributeValueCompletions(this.templateInfo, this.htmlPath);\n    }\n    // LHS completion\n    return attributeCompletions(this.templateInfo, this.htmlPath);\n  }\n  visitText(): ng.CompletionEntry[] {\n    const templatePath = findTemplateAstAt(this.templateInfo.templateAst, this.relativePosition);\n    if (templatePath.tail instanceof BoundTextAst) {\n      // If we know that this is an interpolation then do not try other scenarios.\n      const visitor = new ExpressionVisitor(\n          this.templateInfo, this.relativePosition,\n          () =>\n              getExpressionScope(diagnosticInfoFromTemplateInfo(this.templateInfo), templatePath));\n      templatePath.tail?.visit(visitor, null);\n      return visitor.results;\n    }\n    // TODO(kyliau): Not sure if this check is really needed since we don't have\n    // any test cases for it.\n    const element = this.htmlPath.first(Element);\n    if (element &&\n        getHtmlTagDefinition(element.name).getContentType() !== TagContentType.PARSABLE_DATA) {\n      return [];\n    }\n    // This is to account for cases like <h1> <a> text | </h1> where the\n    // closest element has no closing tag and thus is considered plain text.\n    const results = voidElementAttributeCompletions(this.templateInfo, this.htmlPath);\n    if (results.length) {\n      return results;\n    }\n    return elementCompletions(this.templateInfo);\n  }\n  visitComment(): ng.CompletionEntry[] {\n    return [];\n  }\n  visitExpansion(): ng.CompletionEntry[] {\n    return [];\n  }\n  visitExpansionCase(): ng.CompletionEntry[] {\n    return [];\n  }\n}\n\nfunction attributeCompletions(info: ng.AstResult, path: AstPath<HtmlAst>): ng.CompletionEntry[] {\n  const attr = path.tail;\n  const elem = path.parentOf(attr);\n  if (!(attr instanceof Attribute) || !(elem instanceof Element)) {\n    return [];\n  }\n\n  // TODO: Consider parsing the attrinute name to a proper AST instead of\n  // matching using regex. This is because the regexp would incorrectly identify\n  // bind parts for cases like [()|]\n  //                              ^ cursor is here\n  const binding = getBindingDescriptor(attr.name);\n  if (!binding) {\n    // This is a normal HTML attribute, not an Angular attribute.\n    return attributeCompletionsForElement(info, elem.name);\n  }\n\n  const results: string[] = [];\n  const ngAttrs = angularAttributes(info, elem.name);\n  switch (binding.kind) {\n    case ATTR.KW_MICROSYNTAX:\n      // template reference attribute: *attrName\n      results.push(...ngAttrs.templateRefs);\n      break;\n\n    case ATTR.KW_BIND:\n    case ATTR.IDENT_PROPERTY:\n      // property binding via bind- or []\n      results.push(...propertyNames(elem.name), ...ngAttrs.inputs);\n      break;\n\n    case ATTR.KW_ON:\n    case ATTR.IDENT_EVENT:\n      // event binding via on- or ()\n      results.push(...eventNames(elem.name), ...ngAttrs.outputs);\n      break;\n\n    case ATTR.KW_BINDON:\n    case ATTR.IDENT_BANANA_BOX:\n      // banana-in-a-box binding via bindon- or [()]\n      results.push(...ngAttrs.bananas);\n      break;\n  }\n\n  return results.map(name => {\n    return {\n      name,\n      kind: ng.CompletionKind.ATTRIBUTE,\n      sortText: name,\n    };\n  });\n}\n\nfunction attributeCompletionsForElement(\n    info: ng.AstResult, elementName: string): ng.CompletionEntry[] {\n  const results: ng.CompletionEntry[] = [];\n\n  if (info.template instanceof InlineTemplate) {\n    // Provide HTML attributes completion only for inline templates\n    for (const name of attributeNames(elementName)) {\n      results.push({\n        name,\n        kind: ng.CompletionKind.HTML_ATTRIBUTE,\n        sortText: name,\n      });\n    }\n  }\n\n  // Add Angular attributes\n  const ngAttrs = angularAttributes(info, elementName);\n  for (const name of ngAttrs.others) {\n    results.push({\n      name,\n      kind: ng.CompletionKind.ATTRIBUTE,\n      sortText: name,\n    });\n  }\n\n  return results;\n}\n\n/**\n * Provide completions to the RHS of an attribute, which is of the form\n * LHS=\"RHS\". The template path is computed from the specified `info` whereas\n * the context is determined from the specified `htmlPath`.\n * @param info Object that contains the template AST\n * @param htmlPath Path to the HTML node\n */\nfunction attributeValueCompletions(\n    info: ng.AstResult, htmlPath: HtmlAstPath): ng.CompletionEntry[] {\n  // Find the corresponding Template AST path.\n  const templatePath = findTemplateAstAt(info.templateAst, htmlPath.position);\n  const visitor = new ExpressionVisitor(info, htmlPath.position, () => {\n    const dinfo = diagnosticInfoFromTemplateInfo(info);\n    return getExpressionScope(dinfo, templatePath);\n  });\n  if (templatePath.tail instanceof AttrAst ||\n      templatePath.tail instanceof BoundElementPropertyAst ||\n      templatePath.tail instanceof BoundEventAst) {\n    templatePath.tail.visit(visitor, null);\n    return visitor.results;\n  }\n  // In order to provide accurate attribute value completion, we need to know\n  // what the LHS is, and construct the proper AST if it is missing.\n  const htmlAttr = htmlPath.tail as Attribute;\n  const binding = getBindingDescriptor(htmlAttr.name);\n  if (binding && binding.kind === ATTR.KW_REF) {\n    let refAst: ReferenceAst|undefined;\n    let elemAst: ElementAst|undefined;\n    if (templatePath.tail instanceof ReferenceAst) {\n      refAst = templatePath.tail;\n      const parent = templatePath.parentOf(refAst);\n      if (parent instanceof ElementAst) {\n        elemAst = parent;\n      }\n    } else if (templatePath.tail instanceof ElementAst) {\n      refAst = new ReferenceAst(htmlAttr.name, null!, htmlAttr.value, htmlAttr.valueSpan!);\n      elemAst = templatePath.tail;\n    }\n    if (refAst && elemAst) {\n      refAst.visit(visitor, elemAst);\n    }\n  } else {\n    // HtmlAst contains the `Attribute` node, however the corresponding `AttrAst`\n    // node is missing from the TemplateAst.\n    const attrAst = new AttrAst(htmlAttr.name, htmlAttr.value, htmlAttr.valueSpan!);\n    attrAst.visit(visitor, null);\n  }\n  return visitor.results;\n}\n\nfunction elementCompletions(info: ng.AstResult): ng.CompletionEntry[] {\n  const results: ng.CompletionEntry[] = [...ANGULAR_ELEMENTS];\n\n  if (info.template instanceof InlineTemplate) {\n    // Provide HTML elements completion only for inline templates\n    results.push(...HTML_ELEMENTS);\n  }\n\n  // Collect the elements referenced by the selectors\n  const components = new Set<string>();\n  for (const selector of getSelectors(info).selectors) {\n    const name = selector.element;\n    if (name && !components.has(name)) {\n      components.add(name);\n      results.push({\n        name,\n        kind: ng.CompletionKind.COMPONENT,\n        sortText: name,\n      });\n    }\n  }\n\n  return results;\n}\n\n// There is a special case of HTML where text that contains a unclosed tag is treated as\n// text. For exaple '<h1> Some <a text </h1>' produces a text nodes inside of the H1\n// element \"Some <a text\". We, however, want to treat this as if the user was requesting\n// the attributes of an \"a\" element, not requesting completion in the a text element. This\n// code checks for this case and returns element completions if it is detected or undefined\n// if it is not.\nfunction voidElementAttributeCompletions(\n    info: ng.AstResult, path: AstPath<HtmlAst>): ng.CompletionEntry[] {\n  const tail = path.tail;\n  if (tail instanceof Text) {\n    const match = tail.value.match(/<(\\w(\\w|\\d|-)*:)?(\\w(\\w|\\d|-)*)\\s/);\n    // The position must be after the match, otherwise we are still in a place where elements\n    // are expected (such as `<|a` or `<a|`; we only want attributes for `<a |` or after).\n    if (match &&\n        path.position >= (match.index || 0) + match[0].length + tail.sourceSpan.start.offset) {\n      return attributeCompletionsForElement(info, match[3]);\n    }\n  }\n  return [];\n}\n\nclass ExpressionVisitor extends NullTemplateVisitor {\n  private readonly completions = new Map<string, ng.CompletionEntry>();\n\n  constructor(\n      private readonly info: ng.AstResult, private readonly position: number,\n      private readonly getExpressionScope: () => ng.SymbolTable) {\n    super();\n  }\n\n  get results(): ng.CompletionEntry[] {\n    return Array.from(this.completions.values());\n  }\n\n  visitDirectiveProperty(ast: BoundDirectivePropertyAst): void {\n    this.processExpressionCompletions(ast.value);\n  }\n\n  visitElementProperty(ast: BoundElementPropertyAst): void {\n    this.processExpressionCompletions(ast.value);\n  }\n\n  visitEvent(ast: BoundEventAst): void {\n    this.processExpressionCompletions(ast.handler);\n  }\n\n  visitElement(): void {\n    // no-op for now\n  }\n\n  visitAttr(ast: AttrAst) {\n    const binding = getBindingDescriptor(ast.name);\n    if (binding && binding.kind === ATTR.KW_MICROSYNTAX) {\n      // This a template binding given by micro syntax expression.\n      // First, verify the attribute consists of some binding we can give completions for.\n      // The sourceSpan of AttrAst points to the RHS of the attribute\n      const templateKey = binding.name;\n      const templateValue = ast.sourceSpan.toString();\n      const templateUrl = ast.sourceSpan.start.file.url;\n      // TODO(kyliau): We are unable to determine the absolute offset of the key\n      // but it is okay here, because we are only looking at the RHS of the attr\n      const absKeyOffset = 0;\n      const absValueOffset = ast.sourceSpan.start.offset;\n      const {templateBindings} = this.info.expressionParser.parseTemplateBindings(\n          templateKey, templateValue, templateUrl, absKeyOffset, absValueOffset);\n      // Find the nearest template binding to the position.\n      const lastBindingEnd = templateBindings.length > 0 &&\n          templateBindings[templateBindings.length - 1].sourceSpan.end;\n      const normalizedPositionToBinding =\n          lastBindingEnd && this.position > lastBindingEnd ? lastBindingEnd : this.position;\n      const templateBinding =\n          templateBindings.find(b => inSpan(normalizedPositionToBinding, b.sourceSpan));\n\n      if (!templateBinding) {\n        return;\n      }\n\n      this.microSyntaxInAttributeValue(ast, templateBinding);\n    } else {\n      const expressionAst = this.info.expressionParser.parseBinding(\n          ast.value, ast.sourceSpan.toString(), ast.sourceSpan.start.offset);\n      this.processExpressionCompletions(expressionAst);\n    }\n  }\n\n  visitReference(_ast: ReferenceAst, context: ElementAst) {\n    context.directives.forEach(dir => {\n      const {exportAs} = dir.directive;\n      if (exportAs) {\n        this.completions.set(\n            exportAs, {name: exportAs, kind: ng.CompletionKind.REFERENCE, sortText: exportAs});\n      }\n    });\n  }\n\n  visitBoundText(ast: BoundTextAst) {\n    if (inSpan(this.position, ast.value.sourceSpan)) {\n      const completions = getExpressionCompletions(\n          this.getExpressionScope(), ast.value, this.position, this.info.template);\n      if (completions) {\n        this.addSymbolsToCompletions(completions);\n      }\n    }\n  }\n\n  private processExpressionCompletions(value: AST) {\n    const symbols = getExpressionCompletions(\n        this.getExpressionScope(), value, this.position, this.info.template);\n    if (symbols) {\n      this.addSymbolsToCompletions(symbols);\n    }\n  }\n\n  private addSymbolsToCompletions(symbols: ng.Symbol[]) {\n    for (const s of symbols) {\n      if (s.name.startsWith('__') || !s.public || this.completions.has(s.name)) {\n        continue;\n      }\n\n      // The pipe method should not include parentheses.\n      // e.g. {{ value_expression | slice : start [ : end ] }}\n      const shouldInsertParentheses = s.callable && s.kind !== ng.CompletionKind.PIPE;\n      this.completions.set(s.name, {\n        name: s.name,\n        kind: s.kind as ng.CompletionKind,\n        sortText: s.name,\n        insertText: shouldInsertParentheses ? `${s.name}()` : s.name,\n      });\n    }\n  }\n\n  /**\n   * This method handles the completions of attribute values for directives that\n   * support the microsyntax format. Examples are *ngFor and *ngIf.\n   * These directives allows declaration of \"let\" variables, adds context-specific\n   * symbols like $implicit, index, count, among other behaviors.\n   * For a complete description of such format, see\n   * https://angular.io/guide/structural-directives#the-asterisk--prefix\n   *\n   * @param attr descriptor for attribute name and value pair\n   * @param binding template binding for the expression in the attribute\n   */\n  private microSyntaxInAttributeValue(attr: AttrAst, binding: TemplateBinding) {\n    const key = attr.name.substring(1);  // remove leading asterisk\n\n    // Find the selector - eg ngFor, ngIf, etc\n    const selectorInfo = getSelectors(this.info);\n    const selector = selectorInfo.selectors.find(s => {\n      // attributes are listed in (attribute, value) pairs\n      for (let i = 0; i < s.attrs.length; i += 2) {\n        if (s.attrs[i] === key) {\n          return true;\n        }\n      }\n    });\n\n    if (!selector) {\n      return;\n    }\n\n    const valueRelativePosition = this.position - attr.sourceSpan.start.offset;\n\n    if (binding instanceof VariableBinding) {\n      // TODO(kyliau): With expression sourceSpan we shouldn't have to search\n      // the attribute value string anymore. Just check if position is in the\n      // expression source span.\n      const equalLocation = attr.value.indexOf('=');\n      if (equalLocation > 0 && valueRelativePosition > equalLocation) {\n        // We are after the '=' in a let clause. The valid values here are the members of the\n        // template reference's type parameter.\n        const directiveMetadata = selectorInfo.map.get(selector);\n        if (directiveMetadata) {\n          const contextTable =\n              this.info.template.query.getTemplateContext(directiveMetadata.type.reference);\n          if (contextTable) {\n            // This adds symbols like $implicit, index, count, etc.\n            this.addSymbolsToCompletions(contextTable.values());\n            return;\n          }\n        }\n      }\n    } else if (binding instanceof ExpressionBinding) {\n      if (inSpan(this.position, binding.value?.ast.sourceSpan)) {\n        this.processExpressionCompletions(binding.value!.ast);\n        return;\n      } else if (!binding.value && this.position > binding.key.span.end) {\n        // No expression is defined for the value of the key expression binding, but the cursor is\n        // in a location where the expression would be defined. This can happen in a case like\n        //   let i of |\n        //            ^-- cursor\n        // In this case, backfill the value to be an empty expression and retrieve completions.\n        this.processExpressionCompletions(new EmptyExpr(\n            new ParseSpan(valueRelativePosition, valueRelativePosition),\n            new AbsoluteSourceSpan(this.position, this.position)));\n        return;\n      }\n    }\n  }\n}\n\ninterface AngularAttributes {\n  /**\n   * Attributes that support the * syntax. See https://angular.io/api/core/TemplateRef\n   */\n  templateRefs: Set<string>;\n  /**\n   * Attributes with the @Input annotation.\n   */\n  inputs: Set<string>;\n  /**\n   * Attributes with the @Output annotation.\n   */\n  outputs: Set<string>;\n  /**\n   * Attributes that support the [()] or bindon- syntax.\n   */\n  bananas: Set<string>;\n  /**\n   * General attributes that match the specified element.\n   */\n  others: Set<string>;\n}\n\n/**\n * Return all Angular-specific attributes for the element with `elementName`.\n * @param info\n * @param elementName\n */\nfunction angularAttributes(info: ng.AstResult, elementName: string): AngularAttributes {\n  const {selectors, map: selectorMap} = getSelectors(info);\n  const templateRefs = new Set<string>();\n  const inputs = new Set<string>();\n  const outputs = new Set<string>();\n  const bananas = new Set<string>();\n  const others = new Set<string>();\n  for (const selector of selectors) {\n    if (selector.element && selector.element !== elementName) {\n      continue;\n    }\n    const summary = selectorMap.get(selector)!;\n    const hasTemplateRef = isStructuralDirective(summary.type);\n    // attributes are listed in (attribute, value) pairs\n    for (let i = 0; i < selector.attrs.length; i += 2) {\n      const attr = selector.attrs[i];\n      if (hasTemplateRef) {\n        templateRefs.add(attr);\n      } else {\n        others.add(attr);\n      }\n    }\n    for (const input of Object.values(summary.inputs)) {\n      inputs.add(input);\n    }\n    for (const output of Object.values(summary.outputs)) {\n      outputs.add(output);\n    }\n  }\n  for (const name of inputs) {\n    // Add banana-in-a-box syntax\n    // https://angular.io/guide/template-syntax#two-way-binding-\n    if (outputs.has(`${name}Change`)) {\n      bananas.add(name);\n    }\n  }\n  return {templateRefs, inputs, outputs, bananas, others};\n}\n"]}
|