@angular/language-service 11.2.7 → 11.2.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/ivy.js +1581 -856
- package/bundles/language-service.js +127 -63
- package/ivy/adapters.d.ts +1 -0
- package/ivy/adapters.js +32 -4
- package/ivy/compiler_factory.js +9 -3
- package/ivy/completions.d.ts +5 -0
- package/ivy/completions.js +60 -18
- package/ivy/language_service.d.ts +20 -1
- package/ivy/language_service.js +158 -124
- package/ivy/references.js +98 -82
- package/ivy/utils.js +2 -2
- package/package.json +1 -1
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* @license Angular v11.2.
|
|
2
|
+
* @license Angular v11.2.11
|
|
3
3
|
* Copyright Google LLC All Rights Reserved.
|
|
4
4
|
* License: MIT
|
|
5
5
|
*/
|
|
@@ -3914,6 +3914,21 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
3914
3914
|
* Use of this source code is governed by an MIT-style license that can be
|
|
3915
3915
|
* found in the LICENSE file at https://angular.io/license
|
|
3916
3916
|
*/
|
|
3917
|
+
/**
|
|
3918
|
+
* This is an R3 `Node`-like wrapper for a raw `html.Comment` node. We do not currently
|
|
3919
|
+
* require the implementation of a visitor for Comments as they are only collected at
|
|
3920
|
+
* the top-level of the R3 AST, and only if `Render3ParseOptions['collectCommentNodes']`
|
|
3921
|
+
* is true.
|
|
3922
|
+
*/
|
|
3923
|
+
class Comment {
|
|
3924
|
+
constructor(value, sourceSpan) {
|
|
3925
|
+
this.value = value;
|
|
3926
|
+
this.sourceSpan = sourceSpan;
|
|
3927
|
+
}
|
|
3928
|
+
visit(_visitor) {
|
|
3929
|
+
throw new Error('visit() not implemented for Comment');
|
|
3930
|
+
}
|
|
3931
|
+
}
|
|
3917
3932
|
class Text {
|
|
3918
3933
|
constructor(value, sourceSpan) {
|
|
3919
3934
|
this.value = value;
|
|
@@ -8785,7 +8800,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
8785
8800
|
return visitor.visitElement(this, context);
|
|
8786
8801
|
}
|
|
8787
8802
|
}
|
|
8788
|
-
class Comment {
|
|
8803
|
+
class Comment$1 {
|
|
8789
8804
|
constructor(value, sourceSpan) {
|
|
8790
8805
|
this.value = value;
|
|
8791
8806
|
this.sourceSpan = sourceSpan;
|
|
@@ -9843,7 +9858,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
9843
9858
|
const text = this._advanceIf(TokenType.RAW_TEXT);
|
|
9844
9859
|
this._advanceIf(TokenType.COMMENT_END);
|
|
9845
9860
|
const value = text != null ? text.parts[0].trim() : null;
|
|
9846
|
-
this._addToParent(new Comment(value, token.sourceSpan));
|
|
9861
|
+
this._addToParent(new Comment$1(value, token.sourceSpan));
|
|
9847
9862
|
}
|
|
9848
9863
|
_consumeExpansion(token) {
|
|
9849
9864
|
const switchValue = this._advance();
|
|
@@ -12537,7 +12552,11 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
12537
12552
|
if (isEmptyExpression(value)) {
|
|
12538
12553
|
return null;
|
|
12539
12554
|
}
|
|
12540
|
-
|
|
12555
|
+
// CSS custom properties are case-sensitive so we shouldn't normalize them.
|
|
12556
|
+
// See: https://www.w3.org/TR/css-variables-1/#defining-variables
|
|
12557
|
+
if (!isCssCustomProperty(name)) {
|
|
12558
|
+
name = hyphenate(name);
|
|
12559
|
+
}
|
|
12541
12560
|
const { property, hasOverrideFlag, suffix: bindingSuffix } = parseProperty(name);
|
|
12542
12561
|
suffix = typeof suffix === 'string' && suffix.length !== 0 ? suffix : bindingSuffix;
|
|
12543
12562
|
const entry = { name: property, suffix: suffix, value, sourceSpan, hasOverrideFlag };
|
|
@@ -12882,8 +12901,12 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
12882
12901
|
return Identifiers$1.stylePropInterpolateV;
|
|
12883
12902
|
}
|
|
12884
12903
|
}
|
|
12885
|
-
|
|
12886
|
-
|
|
12904
|
+
/**
|
|
12905
|
+
* Checks whether property name is a custom CSS property.
|
|
12906
|
+
* See: https://www.w3.org/TR/css-variables-1
|
|
12907
|
+
*/
|
|
12908
|
+
function isCssCustomProperty(name) {
|
|
12909
|
+
return name.startsWith('--');
|
|
12887
12910
|
}
|
|
12888
12911
|
|
|
12889
12912
|
/**
|
|
@@ -15001,26 +15024,33 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
15001
15024
|
EVENT: { start: '(', end: ')' },
|
|
15002
15025
|
};
|
|
15003
15026
|
const TEMPLATE_ATTR_PREFIX$2 = '*';
|
|
15004
|
-
function htmlAstToRender3Ast(htmlNodes, bindingParser) {
|
|
15005
|
-
const transformer = new HtmlAstToIvyAst(bindingParser);
|
|
15027
|
+
function htmlAstToRender3Ast(htmlNodes, bindingParser, options) {
|
|
15028
|
+
const transformer = new HtmlAstToIvyAst(bindingParser, options);
|
|
15006
15029
|
const ivyNodes = visitAll$1(transformer, htmlNodes);
|
|
15007
15030
|
// Errors might originate in either the binding parser or the html to ivy transformer
|
|
15008
15031
|
const allErrors = bindingParser.errors.concat(transformer.errors);
|
|
15009
|
-
|
|
15032
|
+
const result = {
|
|
15010
15033
|
nodes: ivyNodes,
|
|
15011
15034
|
errors: allErrors,
|
|
15012
15035
|
styleUrls: transformer.styleUrls,
|
|
15013
15036
|
styles: transformer.styles,
|
|
15014
|
-
ngContentSelectors: transformer.ngContentSelectors
|
|
15037
|
+
ngContentSelectors: transformer.ngContentSelectors
|
|
15015
15038
|
};
|
|
15039
|
+
if (options.collectCommentNodes) {
|
|
15040
|
+
result.commentNodes = transformer.commentNodes;
|
|
15041
|
+
}
|
|
15042
|
+
return result;
|
|
15016
15043
|
}
|
|
15017
15044
|
class HtmlAstToIvyAst {
|
|
15018
|
-
constructor(bindingParser) {
|
|
15045
|
+
constructor(bindingParser, options) {
|
|
15019
15046
|
this.bindingParser = bindingParser;
|
|
15047
|
+
this.options = options;
|
|
15020
15048
|
this.errors = [];
|
|
15021
15049
|
this.styles = [];
|
|
15022
15050
|
this.styleUrls = [];
|
|
15023
15051
|
this.ngContentSelectors = [];
|
|
15052
|
+
// This array will be populated if `Render3ParseOptions['collectCommentNodes']` is true
|
|
15053
|
+
this.commentNodes = [];
|
|
15024
15054
|
this.inI18nBlock = false;
|
|
15025
15055
|
}
|
|
15026
15056
|
// HTML visitor
|
|
@@ -15189,6 +15219,9 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
15189
15219
|
return null;
|
|
15190
15220
|
}
|
|
15191
15221
|
visitComment(comment) {
|
|
15222
|
+
if (this.options.collectCommentNodes) {
|
|
15223
|
+
this.commentNodes.push(new Comment(comment.value || '', comment.sourceSpan));
|
|
15224
|
+
}
|
|
15192
15225
|
return null;
|
|
15193
15226
|
}
|
|
15194
15227
|
// convert view engine `ParsedProperty` to a format suitable for IVY
|
|
@@ -15380,7 +15413,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
15380
15413
|
return node instanceof Text$2 && node.value.trim().length == 0;
|
|
15381
15414
|
}
|
|
15382
15415
|
function isCommentNode(node) {
|
|
15383
|
-
return node instanceof Comment;
|
|
15416
|
+
return node instanceof Comment$1;
|
|
15384
15417
|
}
|
|
15385
15418
|
function textContents(node) {
|
|
15386
15419
|
if (node.children.length !== 1 || !(node.children[0] instanceof Text$2)) {
|
|
@@ -17957,7 +17990,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
17957
17990
|
const parseResult = htmlParser.parse(template, templateUrl, Object.assign(Object.assign({ leadingTriviaChars: LEADING_TRIVIA_CHARS }, options), { tokenizeExpansionForms: true }));
|
|
17958
17991
|
if (!options.alwaysAttemptHtmlToR3AstConversion && parseResult.errors &&
|
|
17959
17992
|
parseResult.errors.length > 0) {
|
|
17960
|
-
|
|
17993
|
+
const parsedTemplate = {
|
|
17961
17994
|
interpolationConfig,
|
|
17962
17995
|
preserveWhitespaces,
|
|
17963
17996
|
template,
|
|
@@ -17969,6 +18002,10 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
17969
18002
|
styles: [],
|
|
17970
18003
|
ngContentSelectors: []
|
|
17971
18004
|
};
|
|
18005
|
+
if (options.collectCommentNodes) {
|
|
18006
|
+
parsedTemplate.commentNodes = [];
|
|
18007
|
+
}
|
|
18008
|
+
return parsedTemplate;
|
|
17972
18009
|
}
|
|
17973
18010
|
let rootNodes = parseResult.rootNodes;
|
|
17974
18011
|
// process i18n meta information (scan attributes, generate ids)
|
|
@@ -17979,7 +18016,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
17979
18016
|
const i18nMetaResult = i18nMetaVisitor.visitAllWithErrors(rootNodes);
|
|
17980
18017
|
if (!options.alwaysAttemptHtmlToR3AstConversion && i18nMetaResult.errors &&
|
|
17981
18018
|
i18nMetaResult.errors.length > 0) {
|
|
17982
|
-
|
|
18019
|
+
const parsedTemplate = {
|
|
17983
18020
|
interpolationConfig,
|
|
17984
18021
|
preserveWhitespaces,
|
|
17985
18022
|
template,
|
|
@@ -17991,6 +18028,10 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
17991
18028
|
styles: [],
|
|
17992
18029
|
ngContentSelectors: []
|
|
17993
18030
|
};
|
|
18031
|
+
if (options.collectCommentNodes) {
|
|
18032
|
+
parsedTemplate.commentNodes = [];
|
|
18033
|
+
}
|
|
18034
|
+
return parsedTemplate;
|
|
17994
18035
|
}
|
|
17995
18036
|
rootNodes = i18nMetaResult.rootNodes;
|
|
17996
18037
|
if (!preserveWhitespaces) {
|
|
@@ -18003,9 +18044,9 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
18003
18044
|
rootNodes = visitAll$1(new I18nMetaVisitor(interpolationConfig, /* keepI18nAttrs */ false), rootNodes);
|
|
18004
18045
|
}
|
|
18005
18046
|
}
|
|
18006
|
-
const { nodes, errors, styleUrls, styles, ngContentSelectors } = htmlAstToRender3Ast(rootNodes, bindingParser);
|
|
18047
|
+
const { nodes, errors, styleUrls, styles, ngContentSelectors, commentNodes } = htmlAstToRender3Ast(rootNodes, bindingParser, { collectCommentNodes: !!options.collectCommentNodes });
|
|
18007
18048
|
errors.push(...parseResult.errors, ...i18nMetaResult.errors);
|
|
18008
|
-
|
|
18049
|
+
const parsedTemplate = {
|
|
18009
18050
|
interpolationConfig,
|
|
18010
18051
|
preserveWhitespaces,
|
|
18011
18052
|
errors: errors.length > 0 ? errors : null,
|
|
@@ -18017,6 +18058,10 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
18017
18058
|
styles,
|
|
18018
18059
|
ngContentSelectors
|
|
18019
18060
|
};
|
|
18061
|
+
if (options.collectCommentNodes) {
|
|
18062
|
+
parsedTemplate.commentNodes = commentNodes;
|
|
18063
|
+
}
|
|
18064
|
+
return parsedTemplate;
|
|
18020
18065
|
}
|
|
18021
18066
|
const elementRegistry = new DomElementSchemaRegistry();
|
|
18022
18067
|
/**
|
|
@@ -19135,7 +19180,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
19135
19180
|
* Use of this source code is governed by an MIT-style license that can be
|
|
19136
19181
|
* found in the LICENSE file at https://angular.io/license
|
|
19137
19182
|
*/
|
|
19138
|
-
const VERSION$1 = new Version('11.2.
|
|
19183
|
+
const VERSION$1 = new Version('11.2.11');
|
|
19139
19184
|
|
|
19140
19185
|
/**
|
|
19141
19186
|
* @license
|
|
@@ -19683,6 +19728,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
19683
19728
|
* found in the LICENSE file at https://angular.io/license
|
|
19684
19729
|
*/
|
|
19685
19730
|
const ERROR_COMPONENT_TYPE = 'ngComponentType';
|
|
19731
|
+
const MISSING_NG_MODULE_METADATA_ERROR_DATA = 'ngMissingNgModuleMetadataErrorData';
|
|
19686
19732
|
// Design notes:
|
|
19687
19733
|
// - don't lazily create metadata:
|
|
19688
19734
|
// For some metadata, we need to do async work sometimes,
|
|
@@ -20150,7 +20196,16 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
20150
20196
|
const importedModuleSummary = this.getNgModuleSummary(importedModuleType, alreadyCollecting);
|
|
20151
20197
|
alreadyCollecting.delete(importedModuleType);
|
|
20152
20198
|
if (!importedModuleSummary) {
|
|
20153
|
-
|
|
20199
|
+
const err = syntaxError(`Unexpected ${this._getTypeDescriptor(importedType)} '${stringifyType(importedType)}' imported by the module '${stringifyType(moduleType)}'. Please add a @NgModule annotation.`);
|
|
20200
|
+
// If possible, record additional context for this error to enable more useful
|
|
20201
|
+
// diagnostics on the compiler side.
|
|
20202
|
+
if (importedType instanceof StaticSymbol) {
|
|
20203
|
+
err[MISSING_NG_MODULE_METADATA_ERROR_DATA] = {
|
|
20204
|
+
fileName: importedType.filePath,
|
|
20205
|
+
className: importedType.name,
|
|
20206
|
+
};
|
|
20207
|
+
}
|
|
20208
|
+
this._reportError(err, moduleType);
|
|
20154
20209
|
return;
|
|
20155
20210
|
}
|
|
20156
20211
|
importedModules.push(importedModuleSummary);
|
|
@@ -27957,6 +28012,25 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
27957
28012
|
return instance[SIMPLE_CHANGES_STORE] = store;
|
|
27958
28013
|
}
|
|
27959
28014
|
|
|
28015
|
+
/**
|
|
28016
|
+
* @license
|
|
28017
|
+
* Copyright Google LLC All Rights Reserved.
|
|
28018
|
+
*
|
|
28019
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
28020
|
+
* found in the LICENSE file at https://angular.io/license
|
|
28021
|
+
*/
|
|
28022
|
+
/**
|
|
28023
|
+
* Profiler function which wraps user code executed by the runtime.
|
|
28024
|
+
*
|
|
28025
|
+
* @param event ProfilerEvent corresponding to the execution context
|
|
28026
|
+
* @param instance component instance
|
|
28027
|
+
* @param hookOrListener lifecycle hook function or output listener. The value depends on the
|
|
28028
|
+
* execution context
|
|
28029
|
+
* @returns
|
|
28030
|
+
*/
|
|
28031
|
+
const profiler = function (event, instance, hookOrListener) {
|
|
28032
|
+
};
|
|
28033
|
+
|
|
27960
28034
|
/**
|
|
27961
28035
|
* @license
|
|
27962
28036
|
* Copyright Google LLC All Rights Reserved.
|
|
@@ -28660,11 +28734,19 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
28660
28734
|
(currentView[PREORDER_HOOK_FLAGS] >> 16 /* NumberOfInitHooksCalledShift */) &&
|
|
28661
28735
|
(currentView[FLAGS] & 3 /* InitPhaseStateMask */) === initPhase) {
|
|
28662
28736
|
currentView[FLAGS] += 2048 /* IndexWithinInitPhaseIncrementer */;
|
|
28663
|
-
|
|
28737
|
+
try {
|
|
28738
|
+
hook.call(directive);
|
|
28739
|
+
}
|
|
28740
|
+
finally {
|
|
28741
|
+
}
|
|
28664
28742
|
}
|
|
28665
28743
|
}
|
|
28666
28744
|
else {
|
|
28667
|
-
|
|
28745
|
+
try {
|
|
28746
|
+
hook.call(directive);
|
|
28747
|
+
}
|
|
28748
|
+
finally {
|
|
28749
|
+
}
|
|
28668
28750
|
}
|
|
28669
28751
|
}
|
|
28670
28752
|
|
|
@@ -32591,13 +32673,16 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
32591
32673
|
}
|
|
32592
32674
|
function executeTemplate(tView, lView, templateFn, rf, context) {
|
|
32593
32675
|
const prevSelectedIndex = getSelectedIndex();
|
|
32676
|
+
const isUpdatePhase = rf & 2 /* Update */;
|
|
32594
32677
|
try {
|
|
32595
32678
|
setSelectedIndex(-1);
|
|
32596
|
-
if (
|
|
32679
|
+
if (isUpdatePhase && lView.length > HEADER_OFFSET) {
|
|
32597
32680
|
// When we're updating, inherently select 0 so we don't
|
|
32598
32681
|
// have to generate that instruction for most update blocks.
|
|
32599
32682
|
selectIndexInternal(tView, lView, HEADER_OFFSET, isInCheckNoChangesMode());
|
|
32600
32683
|
}
|
|
32684
|
+
const preHookType = isUpdatePhase ? 2 /* TemplateUpdateStart */ : 0 /* TemplateCreateStart */;
|
|
32685
|
+
profiler(preHookType, context);
|
|
32601
32686
|
templateFn(rf, context);
|
|
32602
32687
|
}
|
|
32603
32688
|
finally {
|
|
@@ -35157,7 +35242,7 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
35157
35242
|
/**
|
|
35158
35243
|
* @publicApi
|
|
35159
35244
|
*/
|
|
35160
|
-
const VERSION$2 = new Version$1('11.2.
|
|
35245
|
+
const VERSION$2 = new Version$1('11.2.11');
|
|
35161
35246
|
|
|
35162
35247
|
/**
|
|
35163
35248
|
* @license
|
|
@@ -38425,58 +38510,37 @@ define(['exports', 'typescript/lib/tsserverlibrary', 'typescript', 'path'], func
|
|
|
38425
38510
|
super.next(value);
|
|
38426
38511
|
}
|
|
38427
38512
|
subscribe(observerOrNext, error, complete) {
|
|
38428
|
-
|
|
38429
|
-
let
|
|
38430
|
-
let
|
|
38513
|
+
var _a, _b, _c;
|
|
38514
|
+
let nextFn = observerOrNext;
|
|
38515
|
+
let errorFn = error || (() => null);
|
|
38516
|
+
let completeFn = complete;
|
|
38431
38517
|
if (observerOrNext && typeof observerOrNext === 'object') {
|
|
38432
|
-
|
|
38433
|
-
|
|
38434
|
-
|
|
38435
|
-
|
|
38436
|
-
};
|
|
38437
|
-
if (observerOrNext.error) {
|
|
38438
|
-
errorFn = this.__isAsync ? (err) => {
|
|
38439
|
-
setTimeout(() => observerOrNext.error(err));
|
|
38440
|
-
} : (err) => {
|
|
38441
|
-
observerOrNext.error(err);
|
|
38442
|
-
};
|
|
38443
|
-
}
|
|
38444
|
-
if (observerOrNext.complete) {
|
|
38445
|
-
completeFn = this.__isAsync ? () => {
|
|
38446
|
-
setTimeout(() => observerOrNext.complete());
|
|
38447
|
-
} : () => {
|
|
38448
|
-
observerOrNext.complete();
|
|
38449
|
-
};
|
|
38450
|
-
}
|
|
38518
|
+
const observer = observerOrNext;
|
|
38519
|
+
nextFn = (_a = observer.next) === null || _a === void 0 ? void 0 : _a.bind(observer);
|
|
38520
|
+
errorFn = (_b = observer.error) === null || _b === void 0 ? void 0 : _b.bind(observer);
|
|
38521
|
+
completeFn = (_c = observer.complete) === null || _c === void 0 ? void 0 : _c.bind(observer);
|
|
38451
38522
|
}
|
|
38452
|
-
|
|
38453
|
-
|
|
38454
|
-
|
|
38455
|
-
|
|
38456
|
-
observerOrNext(value);
|
|
38457
|
-
};
|
|
38458
|
-
if (error) {
|
|
38459
|
-
errorFn = this.__isAsync ? (err) => {
|
|
38460
|
-
setTimeout(() => error(err));
|
|
38461
|
-
} : (err) => {
|
|
38462
|
-
error(err);
|
|
38463
|
-
};
|
|
38523
|
+
if (this.__isAsync) {
|
|
38524
|
+
errorFn = _wrapInTimeout(errorFn);
|
|
38525
|
+
if (nextFn) {
|
|
38526
|
+
nextFn = _wrapInTimeout(nextFn);
|
|
38464
38527
|
}
|
|
38465
|
-
if (
|
|
38466
|
-
completeFn =
|
|
38467
|
-
setTimeout(() => complete());
|
|
38468
|
-
} : () => {
|
|
38469
|
-
complete();
|
|
38470
|
-
};
|
|
38528
|
+
if (completeFn) {
|
|
38529
|
+
completeFn = _wrapInTimeout(completeFn);
|
|
38471
38530
|
}
|
|
38472
38531
|
}
|
|
38473
|
-
const sink = super.subscribe(
|
|
38532
|
+
const sink = super.subscribe({ next: nextFn, error: errorFn, complete: completeFn });
|
|
38474
38533
|
if (observerOrNext instanceof Subscription) {
|
|
38475
38534
|
observerOrNext.add(sink);
|
|
38476
38535
|
}
|
|
38477
38536
|
return sink;
|
|
38478
38537
|
}
|
|
38479
38538
|
}
|
|
38539
|
+
function _wrapInTimeout(fn) {
|
|
38540
|
+
return (value) => {
|
|
38541
|
+
setTimeout(fn, undefined, value);
|
|
38542
|
+
};
|
|
38543
|
+
}
|
|
38480
38544
|
/**
|
|
38481
38545
|
* @publicApi
|
|
38482
38546
|
*/
|
package/ivy/adapters.d.ts
CHANGED
|
@@ -26,6 +26,7 @@ export declare class LanguageServiceAdapter implements NgCompilerAdapter {
|
|
|
26
26
|
*/
|
|
27
27
|
private readonly lastReadResourceVersion;
|
|
28
28
|
constructor(project: ts.server.Project);
|
|
29
|
+
resourceNameToFileName(url: string, fromFile: string, fallbackResolve?: (url: string, fromFile: string) => string | null): string | null;
|
|
29
30
|
isShim(sf: ts.SourceFile): boolean;
|
|
30
31
|
fileExists(fileName: string): boolean;
|
|
31
32
|
readFile(fileName: string): string | undefined;
|
package/ivy/adapters.js
CHANGED
|
@@ -22,6 +22,7 @@
|
|
|
22
22
|
var typescript_1 = require("@angular/compiler-cli/src/ngtsc/util/src/typescript");
|
|
23
23
|
var p = require("path");
|
|
24
24
|
var utils_1 = require("@angular/language-service/ivy/utils");
|
|
25
|
+
var PRE_COMPILED_STYLE_EXTENSIONS = ['.scss', '.sass', '.less', '.styl'];
|
|
25
26
|
var LanguageServiceAdapter = /** @class */ (function () {
|
|
26
27
|
function LanguageServiceAdapter(project) {
|
|
27
28
|
this.project = project;
|
|
@@ -38,6 +39,33 @@
|
|
|
38
39
|
this.lastReadResourceVersion = new Map();
|
|
39
40
|
this.rootDirs = typescript_1.getRootDirs(this, project.getCompilationSettings());
|
|
40
41
|
}
|
|
42
|
+
LanguageServiceAdapter.prototype.resourceNameToFileName = function (url, fromFile, fallbackResolve) {
|
|
43
|
+
var e_1, _a;
|
|
44
|
+
var _b;
|
|
45
|
+
// If we are trying to resolve a `.css` file, see if we can find a pre-compiled file with the
|
|
46
|
+
// same name instead. That way, we can provide go-to-definition for the pre-compiled files which
|
|
47
|
+
// would generally be the desired behavior.
|
|
48
|
+
if (url.endsWith('.css')) {
|
|
49
|
+
var styleUrl = p.resolve(fromFile, '..', url);
|
|
50
|
+
try {
|
|
51
|
+
for (var PRE_COMPILED_STYLE_EXTENSIONS_1 = tslib_1.__values(PRE_COMPILED_STYLE_EXTENSIONS), PRE_COMPILED_STYLE_EXTENSIONS_1_1 = PRE_COMPILED_STYLE_EXTENSIONS_1.next(); !PRE_COMPILED_STYLE_EXTENSIONS_1_1.done; PRE_COMPILED_STYLE_EXTENSIONS_1_1 = PRE_COMPILED_STYLE_EXTENSIONS_1.next()) {
|
|
52
|
+
var ext = PRE_COMPILED_STYLE_EXTENSIONS_1_1.value;
|
|
53
|
+
var precompiledFileUrl = styleUrl.replace(/\.css$/, ext);
|
|
54
|
+
if (this.fileExists(precompiledFileUrl)) {
|
|
55
|
+
return precompiledFileUrl;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
60
|
+
finally {
|
|
61
|
+
try {
|
|
62
|
+
if (PRE_COMPILED_STYLE_EXTENSIONS_1_1 && !PRE_COMPILED_STYLE_EXTENSIONS_1_1.done && (_a = PRE_COMPILED_STYLE_EXTENSIONS_1.return)) _a.call(PRE_COMPILED_STYLE_EXTENSIONS_1);
|
|
63
|
+
}
|
|
64
|
+
finally { if (e_1) throw e_1.error; }
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
return (_b = fallbackResolve === null || fallbackResolve === void 0 ? void 0 : fallbackResolve(url, fromFile)) !== null && _b !== void 0 ? _b : null;
|
|
68
|
+
};
|
|
41
69
|
LanguageServiceAdapter.prototype.isShim = function (sf) {
|
|
42
70
|
return shims_1.isShim(sf);
|
|
43
71
|
};
|
|
@@ -87,7 +115,7 @@
|
|
|
87
115
|
return snapshot.getText(0, snapshot.getLength());
|
|
88
116
|
};
|
|
89
117
|
LanguageServiceAdapter.prototype.getModifiedResourceFiles = function () {
|
|
90
|
-
var
|
|
118
|
+
var e_2, _a;
|
|
91
119
|
var modifiedFiles = new Set();
|
|
92
120
|
try {
|
|
93
121
|
for (var _b = tslib_1.__values(this.lastReadResourceVersion), _c = _b.next(); !_c.done; _c = _b.next()) {
|
|
@@ -97,12 +125,12 @@
|
|
|
97
125
|
}
|
|
98
126
|
}
|
|
99
127
|
}
|
|
100
|
-
catch (
|
|
128
|
+
catch (e_2_1) { e_2 = { error: e_2_1 }; }
|
|
101
129
|
finally {
|
|
102
130
|
try {
|
|
103
131
|
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
|
104
132
|
}
|
|
105
|
-
finally { if (
|
|
133
|
+
finally { if (e_2) throw e_2.error; }
|
|
106
134
|
}
|
|
107
135
|
return modifiedFiles.size > 0 ? modifiedFiles : undefined;
|
|
108
136
|
};
|
|
@@ -171,4 +199,4 @@
|
|
|
171
199
|
}());
|
|
172
200
|
exports.LSParseConfigHost = LSParseConfigHost;
|
|
173
201
|
});
|
|
174
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adapters.js","sourceRoot":"","sources":["../../../../../../packages/language-service/ivy/adapters.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\n/** @fileoverview provides adapters for communicating with the ng compiler */\n\nimport {ConfigurationHost} from '@angular/compiler-cli';\nimport {NgCompilerAdapter} from '@angular/compiler-cli/src/ngtsc/core/api';\nimport {AbsoluteFsPath, FileStats, PathSegment, PathString} from '@angular/compiler-cli/src/ngtsc/file_system';\nimport {isShim} from '@angular/compiler-cli/src/ngtsc/shims';\nimport {getRootDirs} from '@angular/compiler-cli/src/ngtsc/util/src/typescript';\nimport * as p from 'path';\nimport * as ts from 'typescript/lib/tsserverlibrary';\n\nimport {isTypeScriptFile} from './utils';\n\nexport class LanguageServiceAdapter implements NgCompilerAdapter {\n  readonly entryPoint = null;\n  readonly constructionDiagnostics: ts.Diagnostic[] = [];\n  readonly ignoreForEmit: Set<ts.SourceFile> = new Set();\n  readonly factoryTracker = null;      // no .ngfactory shims\n  readonly unifiedModulesHost = null;  // only used in Bazel\n  readonly rootDirs: AbsoluteFsPath[];\n\n  /**\n   * Map of resource filenames to the version of the file last read via `readResource`.\n   *\n   * Used to implement `getModifiedResourceFiles`.\n   */\n  private readonly lastReadResourceVersion = new Map<string, string>();\n\n  constructor(private readonly project: ts.server.Project) {\n    this.rootDirs = getRootDirs(this, project.getCompilationSettings());\n  }\n\n  isShim(sf: ts.SourceFile): boolean {\n    return isShim(sf);\n  }\n\n  fileExists(fileName: string): boolean {\n    return this.project.fileExists(fileName);\n  }\n\n  readFile(fileName: string): string|undefined {\n    return this.project.readFile(fileName);\n  }\n\n  getCurrentDirectory(): string {\n    return this.project.getCurrentDirectory();\n  }\n\n  getCanonicalFileName(fileName: string): string {\n    return this.project.projectService.toCanonicalFileName(fileName);\n  }\n\n  /**\n   * Return the real path of a symlink. This method is required in order to\n   * resolve symlinks in node_modules.\n   */\n  realpath(path: string): string {\n    return this.project.realpath?.(path) ?? path;\n  }\n\n  /**\n   * readResource() is an Angular-specific method for reading files that are not\n   * managed by the TS compiler host, namely templates and stylesheets.\n   * It is a method on ExtendedTsCompilerHost, see\n   * packages/compiler-cli/src/ngtsc/core/api/src/interfaces.ts\n   */\n  readResource(fileName: string): string {\n    if (isTypeScriptFile(fileName)) {\n      throw new Error(`readResource() should not be called on TS file: ${fileName}`);\n    }\n    // Calling getScriptSnapshot() will actually create a ScriptInfo if it does\n    // not exist! The same applies for getScriptVersion().\n    // getScriptInfo() will not create one if it does not exist.\n    // In this case, we *want* a script info to be created so that we could\n    // keep track of its version.\n    const snapshot = this.project.getScriptSnapshot(fileName);\n    if (!snapshot) {\n      // This would fail if the file does not exist, or readFile() fails for\n      // whatever reasons.\n      throw new Error(`Failed to get script snapshot while trying to read ${fileName}`);\n    }\n    const version = this.project.getScriptVersion(fileName);\n    this.lastReadResourceVersion.set(fileName, version);\n    return snapshot.getText(0, snapshot.getLength());\n  }\n\n  getModifiedResourceFiles(): Set<string>|undefined {\n    const modifiedFiles = new Set<string>();\n    for (const [fileName, oldVersion] of this.lastReadResourceVersion) {\n      if (this.project.getScriptVersion(fileName) !== oldVersion) {\n        modifiedFiles.add(fileName);\n      }\n    }\n    return modifiedFiles.size > 0 ? modifiedFiles : undefined;\n  }\n}\n\n/**\n * Used to read configuration files.\n *\n * A language service parse configuration host is independent of the adapter\n * because signatures of calls like `FileSystem#readFile` are a bit stricter\n * than those on the adapter.\n */\nexport class LSParseConfigHost implements ConfigurationHost {\n  constructor(private readonly serverHost: ts.server.ServerHost) {}\n  exists(path: AbsoluteFsPath): boolean {\n    return this.serverHost.fileExists(path) || this.serverHost.directoryExists(path);\n  }\n  readFile(path: AbsoluteFsPath): string {\n    const content = this.serverHost.readFile(path);\n    if (content === undefined) {\n      throw new Error(`LanguageServiceFS#readFile called on unavailable file ${path}`);\n    }\n    return content;\n  }\n  lstat(path: AbsoluteFsPath): FileStats {\n    return {\n      isFile: () => {\n        return this.serverHost.fileExists(path);\n      },\n      isDirectory: () => {\n        return this.serverHost.directoryExists(path);\n      },\n      isSymbolicLink: () => {\n        throw new Error(`LanguageServiceFS#lstat#isSymbolicLink not implemented`);\n      },\n    };\n  }\n  pwd(): AbsoluteFsPath {\n    return this.serverHost.getCurrentDirectory() as AbsoluteFsPath;\n  }\n  extname(path: AbsoluteFsPath|PathSegment): string {\n    return p.extname(path);\n  }\n  resolve(...paths: string[]): AbsoluteFsPath {\n    return p.resolve(...paths) as AbsoluteFsPath;\n  }\n  dirname<T extends PathString>(file: T): T {\n    return p.dirname(file) as T;\n  }\n  join<T extends PathString>(basePath: T, ...paths: string[]): T {\n    return p.join(basePath, ...paths) as T;\n  }\n}\n"]}
|
|
202
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"adapters.js","sourceRoot":"","sources":["../../../../../../packages/language-service/ivy/adapters.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\n/** @fileoverview provides adapters for communicating with the ng compiler */\n\nimport {ConfigurationHost} from '@angular/compiler-cli';\nimport {NgCompilerAdapter} from '@angular/compiler-cli/src/ngtsc/core/api';\nimport {AbsoluteFsPath, FileStats, PathSegment, PathString} from '@angular/compiler-cli/src/ngtsc/file_system';\nimport {isShim} from '@angular/compiler-cli/src/ngtsc/shims';\nimport {getRootDirs} from '@angular/compiler-cli/src/ngtsc/util/src/typescript';\nimport * as p from 'path';\nimport * as ts from 'typescript/lib/tsserverlibrary';\n\nimport {isTypeScriptFile} from './utils';\n\nconst PRE_COMPILED_STYLE_EXTENSIONS = ['.scss', '.sass', '.less', '.styl'];\n\nexport class LanguageServiceAdapter implements NgCompilerAdapter {\n  readonly entryPoint = null;\n  readonly constructionDiagnostics: ts.Diagnostic[] = [];\n  readonly ignoreForEmit: Set<ts.SourceFile> = new Set();\n  readonly factoryTracker = null;      // no .ngfactory shims\n  readonly unifiedModulesHost = null;  // only used in Bazel\n  readonly rootDirs: AbsoluteFsPath[];\n\n  /**\n   * Map of resource filenames to the version of the file last read via `readResource`.\n   *\n   * Used to implement `getModifiedResourceFiles`.\n   */\n  private readonly lastReadResourceVersion = new Map<string, string>();\n\n  constructor(private readonly project: ts.server.Project) {\n    this.rootDirs = getRootDirs(this, project.getCompilationSettings());\n  }\n\n  resourceNameToFileName(\n      url: string, fromFile: string,\n      fallbackResolve?: (url: string, fromFile: string) => string | null): string|null {\n    // If we are trying to resolve a `.css` file, see if we can find a pre-compiled file with the\n    // same name instead. That way, we can provide go-to-definition for the pre-compiled files which\n    // would generally be the desired behavior.\n    if (url.endsWith('.css')) {\n      const styleUrl = p.resolve(fromFile, '..', url);\n      for (const ext of PRE_COMPILED_STYLE_EXTENSIONS) {\n        const precompiledFileUrl = styleUrl.replace(/\\.css$/, ext);\n        if (this.fileExists(precompiledFileUrl)) {\n          return precompiledFileUrl;\n        }\n      }\n    }\n    return fallbackResolve?.(url, fromFile) ?? null;\n  }\n\n  isShim(sf: ts.SourceFile): boolean {\n    return isShim(sf);\n  }\n\n  fileExists(fileName: string): boolean {\n    return this.project.fileExists(fileName);\n  }\n\n  readFile(fileName: string): string|undefined {\n    return this.project.readFile(fileName);\n  }\n\n  getCurrentDirectory(): string {\n    return this.project.getCurrentDirectory();\n  }\n\n  getCanonicalFileName(fileName: string): string {\n    return this.project.projectService.toCanonicalFileName(fileName);\n  }\n\n  /**\n   * Return the real path of a symlink. This method is required in order to\n   * resolve symlinks in node_modules.\n   */\n  realpath(path: string): string {\n    return this.project.realpath?.(path) ?? path;\n  }\n\n  /**\n   * readResource() is an Angular-specific method for reading files that are not\n   * managed by the TS compiler host, namely templates and stylesheets.\n   * It is a method on ExtendedTsCompilerHost, see\n   * packages/compiler-cli/src/ngtsc/core/api/src/interfaces.ts\n   */\n  readResource(fileName: string): string {\n    if (isTypeScriptFile(fileName)) {\n      throw new Error(`readResource() should not be called on TS file: ${fileName}`);\n    }\n    // Calling getScriptSnapshot() will actually create a ScriptInfo if it does\n    // not exist! The same applies for getScriptVersion().\n    // getScriptInfo() will not create one if it does not exist.\n    // In this case, we *want* a script info to be created so that we could\n    // keep track of its version.\n    const snapshot = this.project.getScriptSnapshot(fileName);\n    if (!snapshot) {\n      // This would fail if the file does not exist, or readFile() fails for\n      // whatever reasons.\n      throw new Error(`Failed to get script snapshot while trying to read ${fileName}`);\n    }\n    const version = this.project.getScriptVersion(fileName);\n    this.lastReadResourceVersion.set(fileName, version);\n    return snapshot.getText(0, snapshot.getLength());\n  }\n\n  getModifiedResourceFiles(): Set<string>|undefined {\n    const modifiedFiles = new Set<string>();\n    for (const [fileName, oldVersion] of this.lastReadResourceVersion) {\n      if (this.project.getScriptVersion(fileName) !== oldVersion) {\n        modifiedFiles.add(fileName);\n      }\n    }\n    return modifiedFiles.size > 0 ? modifiedFiles : undefined;\n  }\n}\n\n/**\n * Used to read configuration files.\n *\n * A language service parse configuration host is independent of the adapter\n * because signatures of calls like `FileSystem#readFile` are a bit stricter\n * than those on the adapter.\n */\nexport class LSParseConfigHost implements ConfigurationHost {\n  constructor(private readonly serverHost: ts.server.ServerHost) {}\n  exists(path: AbsoluteFsPath): boolean {\n    return this.serverHost.fileExists(path) || this.serverHost.directoryExists(path);\n  }\n  readFile(path: AbsoluteFsPath): string {\n    const content = this.serverHost.readFile(path);\n    if (content === undefined) {\n      throw new Error(`LanguageServiceFS#readFile called on unavailable file ${path}`);\n    }\n    return content;\n  }\n  lstat(path: AbsoluteFsPath): FileStats {\n    return {\n      isFile: () => {\n        return this.serverHost.fileExists(path);\n      },\n      isDirectory: () => {\n        return this.serverHost.directoryExists(path);\n      },\n      isSymbolicLink: () => {\n        throw new Error(`LanguageServiceFS#lstat#isSymbolicLink not implemented`);\n      },\n    };\n  }\n  pwd(): AbsoluteFsPath {\n    return this.serverHost.getCurrentDirectory() as AbsoluteFsPath;\n  }\n  extname(path: AbsoluteFsPath|PathSegment): string {\n    return p.extname(path);\n  }\n  resolve(...paths: string[]): AbsoluteFsPath {\n    return p.resolve(...paths) as AbsoluteFsPath;\n  }\n  dirname<T extends PathString>(file: T): T {\n    return p.dirname(file) as T;\n  }\n  join<T extends PathString>(basePath: T, ...paths: string[]): T {\n    return p.join(basePath, ...paths) as T;\n  }\n}\n"]}
|
package/ivy/compiler_factory.js
CHANGED
|
@@ -47,14 +47,20 @@
|
|
|
47
47
|
var ticket_1 = core_1.resourceChangeTicket(this.compiler, modifiedResourceFiles);
|
|
48
48
|
this.compiler = core_1.NgCompiler.fromTicket(ticket_1, this.adapter);
|
|
49
49
|
}
|
|
50
|
+
else {
|
|
51
|
+
// The previous NgCompiler is being reused, but we still want to reset its performance
|
|
52
|
+
// tracker to capture only the operations that are needed to service the current request.
|
|
53
|
+
this.compiler.perfRecorder.reset();
|
|
54
|
+
}
|
|
50
55
|
return this.compiler;
|
|
51
56
|
}
|
|
52
57
|
var ticket;
|
|
53
58
|
if (this.compiler === null || this.lastKnownProgram === null) {
|
|
54
|
-
ticket = core_1.freshCompilationTicket(program, this.options, this.incrementalStrategy, this.programStrategy,
|
|
59
|
+
ticket = core_1.freshCompilationTicket(program, this.options, this.incrementalStrategy, this.programStrategy,
|
|
60
|
+
/* perfRecorder */ null, true, true);
|
|
55
61
|
}
|
|
56
62
|
else {
|
|
57
|
-
ticket = core_1.incrementalFromCompilerTicket(this.compiler, program, this.incrementalStrategy, this.programStrategy, modifiedResourceFiles);
|
|
63
|
+
ticket = core_1.incrementalFromCompilerTicket(this.compiler, program, this.incrementalStrategy, this.programStrategy, modifiedResourceFiles, /* perfRecorder */ null);
|
|
58
64
|
}
|
|
59
65
|
this.compiler = core_1.NgCompiler.fromTicket(ticket, this.adapter);
|
|
60
66
|
this.lastKnownProgram = program;
|
|
@@ -67,4 +73,4 @@
|
|
|
67
73
|
}());
|
|
68
74
|
exports.CompilerFactory = CompilerFactory;
|
|
69
75
|
});
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcGlsZXJfZmFjdG9yeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2xhbmd1YWdlLXNlcnZpY2UvaXZ5L2NvbXBpbGVyX2ZhY3RvcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7Ozs7OztHQU1HOzs7Ozs7Ozs7Ozs7O0lBRUgsNkRBQWdLO0lBRWhLLDJFQUE0RjtJQVE1Rjs7Ozs7Ozs7T0FRRztJQUNIO1FBS0UseUJBQ3FCLE9BQStCLEVBQy9CLGVBQTRDLEVBQzVDLE9BQTBCO1lBRjFCLFlBQU8sR0FBUCxPQUFPLENBQXdCO1lBQy9CLG9CQUFlLEdBQWYsZUFBZSxDQUE2QjtZQUM1QyxZQUFPLEdBQVAsT0FBTyxDQUFtQjtZQVA5Qix3QkFBbUIsR0FBRyxJQUFJLDZDQUErQixFQUFFLENBQUM7WUFDckUsYUFBUSxHQUFvQixJQUFJLENBQUM7WUFDakMscUJBQWdCLEdBQW9CLElBQUksQ0FBQztRQU05QyxDQUFDO1FBRUoscUNBQVcsR0FBWDs7WUFDRSxJQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsZUFBZSxDQUFDLFVBQVUsRUFBRSxDQUFDO1lBQ2xELElBQU0scUJBQXFCLFNBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyx3QkFBd0IsRUFBRSxtQ0FBSSxJQUFJLEdBQUcsRUFBRSxDQUFDO1lBRW5GLElBQUksSUFBSSxDQUFDLFFBQVEsS0FBSyxJQUFJLElBQUksT0FBTyxLQUFLLElBQUksQ0FBQyxnQkFBZ0IsRUFBRTtnQkFDL0QsSUFBSSxxQkFBcUIsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxFQUFFO29CQUNsQywwRUFBMEU7b0JBQzFFLElBQU0sUUFBTSxHQUFHLDJCQUFvQixDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUscUJBQXFCLENBQUMsQ0FBQztvQkFDMUUsSUFBSSxDQUFDLFFBQVEsR0FBRyxpQkFBVSxDQUFDLFVBQVUsQ0FBQyxRQUFNLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO2lCQUM3RDtxQkFBTTtvQkFDTCxzRkFBc0Y7b0JBQ3RGLHlGQUF5RjtvQkFDekYsSUFBSSxDQUFDLFFBQVEsQ0FBQyxZQUFZLENBQUMsS0FBSyxFQUFFLENBQUM7aUJBQ3BDO2dCQUVELE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQzthQUN0QjtZQUVELElBQUksTUFBeUIsQ0FBQztZQUM5QixJQUFJLElBQUksQ0FBQyxRQUFRLEtBQUssSUFBSSxJQUFJLElBQUksQ0FBQyxnQkFBZ0IsS0FBSyxJQUFJLEVBQUU7Z0JBQzVELE1BQU0sR0FBRyw2QkFBc0IsQ0FDM0IsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLG1CQUFtQixFQUFFLElBQUksQ0FBQyxlQUFlO2dCQUNyRSxrQkFBa0IsQ0FBQyxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDO2FBQzFDO2lCQUFNO2dCQUNMLE1BQU0sR0FBRyxvQ0FBNkIsQ0FDbEMsSUFBSSxDQUFDLFFBQVEsRUFBRSxPQUFPLEVBQUUsSUFBSSxDQUFDLG1CQUFtQixFQUFFLElBQUksQ0FBQyxlQUFlLEVBQ3RFLHFCQUFxQixFQUFFLGtCQUFrQixDQUFDLElBQUksQ0FBQyxDQUFDO2FBQ3JEO1lBQ0QsSUFBSSxDQUFDLFFBQVEsR0FBRyxpQkFBVSxDQUFDLFVBQVUsQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBQzVELElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxPQUFPLENBQUM7WUFDaEMsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDO1FBQ3ZCLENBQUM7UUFFRCxrREFBd0IsR0FBeEI7WUFDRSxJQUFJLENBQUMsZ0JBQWdCLEdBQUcsSUFBSSxDQUFDLGVBQWUsQ0FBQyxVQUFVLEVBQUUsQ0FBQztRQUM1RCxDQUFDO1FBQ0gsc0JBQUM7SUFBRCxDQUFDLEFBL0NELElBK0NDO0lBL0NZLDBDQUFlIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5cbmltcG9ydCB7Q29tcGlsYXRpb25UaWNrZXQsIGZyZXNoQ29tcGlsYXRpb25UaWNrZXQsIGluY3JlbWVudGFsRnJvbUNvbXBpbGVyVGlja2V0LCBOZ0NvbXBpbGVyLCByZXNvdXJjZUNoYW5nZVRpY2tldH0gZnJvbSAnQGFuZ3VsYXIvY29tcGlsZXItY2xpL3NyYy9uZ3RzYy9jb3JlJztcbmltcG9ydCB7TmdDb21waWxlck9wdGlvbnN9IGZyb20gJ0Bhbmd1bGFyL2NvbXBpbGVyLWNsaS9zcmMvbmd0c2MvY29yZS9hcGknO1xuaW1wb3J0IHtUcmFja2VkSW5jcmVtZW50YWxCdWlsZFN0cmF0ZWd5fSBmcm9tICdAYW5ndWxhci9jb21waWxlci1jbGkvc3JjL25ndHNjL2luY3JlbWVudGFsJztcbmltcG9ydCB7QWN0aXZlUGVyZlJlY29yZGVyfSBmcm9tICdAYW5ndWxhci9jb21waWxlci1jbGkvc3JjL25ndHNjL3BlcmYnO1xuaW1wb3J0IHtUeXBlQ2hlY2tpbmdQcm9ncmFtU3RyYXRlZ3l9IGZyb20gJ0Bhbmd1bGFyL2NvbXBpbGVyLWNsaS9zcmMvbmd0c2MvdHlwZWNoZWNrL2FwaSc7XG5pbXBvcnQgKiBhcyB0cyBmcm9tICd0eXBlc2NyaXB0L2xpYi90c3NlcnZlcmxpYnJhcnknO1xuXG5pbXBvcnQge0xhbmd1YWdlU2VydmljZUFkYXB0ZXJ9IGZyb20gJy4vYWRhcHRlcnMnO1xuaW1wb3J0IHtpc0V4dGVybmFsVGVtcGxhdGV9IGZyb20gJy4vdXRpbHMnO1xuXG4vKipcbiAqIE1hbmFnZXMgdGhlIGBOZ0NvbXBpbGVyYCBpbnN0YW5jZSB3aGljaCBiYWNrcyB0aGUgbGFuZ3VhZ2Ugc2VydmljZSwgdXBkYXRpbmcgb3IgcmVwbGFjaW5nIGl0IGFzXG4gKiBuZWVkZWQgdG8gcHJvZHVjZSBhbiB1cC10by1kYXRlIHVuZGVyc3RhbmRpbmcgb2YgdGhlIGN1cnJlbnQgcHJvZ3JhbS5cbiAqXG4gKiBUT0RPKGFseGh1Yik6IGN1cnJlbnRseSB0aGUgb3B0aW9ucyB1c2VkIGZvciB0aGUgY29tcGlsZXIgYXJlIHNwZWNpZmllZCBhdCBgQ29tcGlsZXJGYWN0b3J5YFxuICogY29uc3RydWN0aW9uLCBhbmQgYXJlIG5vdCBjaGFuZ2FibGUuIEluIGEgcmVhbCBwcm9qZWN0LCB1c2VycyBjYW4gdXBkYXRlIGB0c2NvbmZpZy5qc29uYC4gV2UgbmVlZFxuICogdG8gcHJvcGVybHkgaGFuZGxlIGEgY2hhbmdlIGluIHRoZSBjb21waWxlciBvcHRpb25zLCBlaXRoZXIgYnkgaGF2aW5nIGFuIEFQSSB0byB1cGRhdGUgdGhlXG4gKiBgQ29tcGlsZXJGYWN0b3J5YCB0byB1c2UgbmV3IG9wdGlvbnMsIG9yIGJ5IHJlcGxhY2luZyBpdCBlbnRpcmVseS5cbiAqL1xuZXhwb3J0IGNsYXNzIENvbXBpbGVyRmFjdG9yeSB7XG4gIHByaXZhdGUgcmVhZG9ubHkgaW5jcmVtZW50YWxTdHJhdGVneSA9IG5ldyBUcmFja2VkSW5jcmVtZW50YWxCdWlsZFN0cmF0ZWd5KCk7XG4gIHByaXZhdGUgY29tcGlsZXI6IE5nQ29tcGlsZXJ8bnVsbCA9IG51bGw7XG4gIHByaXZhdGUgbGFzdEtub3duUHJvZ3JhbTogdHMuUHJvZ3JhbXxudWxsID0gbnVsbDtcblxuICBjb25zdHJ1Y3RvcihcbiAgICAgIHByaXZhdGUgcmVhZG9ubHkgYWRhcHRlcjogTGFuZ3VhZ2VTZXJ2aWNlQWRhcHRlcixcbiAgICAgIHByaXZhdGUgcmVhZG9ubHkgcHJvZ3JhbVN0cmF0ZWd5OiBUeXBlQ2hlY2tpbmdQcm9ncmFtU3RyYXRlZ3ksXG4gICAgICBwcml2YXRlIHJlYWRvbmx5IG9wdGlvbnM6IE5nQ29tcGlsZXJPcHRpb25zLFxuICApIHt9XG5cbiAgZ2V0T3JDcmVhdGUoKTogTmdDb21waWxlciB7XG4gICAgY29uc3QgcHJvZ3JhbSA9IHRoaXMucHJvZ3JhbVN0cmF0ZWd5LmdldFByb2dyYW0oKTtcbiAgICBjb25zdCBtb2RpZmllZFJlc291cmNlRmlsZXMgPSB0aGlzLmFkYXB0ZXIuZ2V0TW9kaWZpZWRSZXNvdXJjZUZpbGVzKCkgPz8gbmV3IFNldCgpO1xuXG4gICAgaWYgKHRoaXMuY29tcGlsZXIgIT09IG51bGwgJiYgcHJvZ3JhbSA9PT0gdGhpcy5sYXN0S25vd25Qcm9ncmFtKSB7XG4gICAgICBpZiAobW9kaWZpZWRSZXNvdXJjZUZpbGVzLnNpemUgPiAwKSB7XG4gICAgICAgIC8vIE9ubHkgcmVzb3VyY2UgZmlsZXMgaGF2ZSBjaGFuZ2VkIHNpbmNlIHRoZSBsYXN0IE5nQ29tcGlsZXIgd2FzIGNyZWF0ZWQuXG4gICAgICAgIGNvbnN0IHRpY2tldCA9IHJlc291cmNlQ2hhbmdlVGlja2V0KHRoaXMuY29tcGlsZXIsIG1vZGlmaWVkUmVzb3VyY2VGaWxlcyk7XG4gICAgICAgIHRoaXMuY29tcGlsZXIgPSBOZ0NvbXBpbGVyLmZyb21UaWNrZXQodGlja2V0LCB0aGlzLmFkYXB0ZXIpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgLy8gVGhlIHByZXZpb3VzIE5nQ29tcGlsZXIgaXMgYmVpbmcgcmV1c2VkLCBidXQgd2Ugc3RpbGwgd2FudCB0byByZXNldCBpdHMgcGVyZm9ybWFuY2VcbiAgICAgICAgLy8gdHJhY2tlciB0byBjYXB0dXJlIG9ubHkgdGhlIG9wZXJhdGlvbnMgdGhhdCBhcmUgbmVlZGVkIHRvIHNlcnZpY2UgdGhlIGN1cnJlbnQgcmVxdWVzdC5cbiAgICAgICAgdGhpcy5jb21waWxlci5wZXJmUmVjb3JkZXIucmVzZXQoKTtcbiAgICAgIH1cblxuICAgICAgcmV0dXJuIHRoaXMuY29tcGlsZXI7XG4gICAgfVxuXG4gICAgbGV0IHRpY2tldDogQ29tcGlsYXRpb25UaWNrZXQ7XG4gICAgaWYgKHRoaXMuY29tcGlsZXIgPT09IG51bGwgfHwgdGhpcy5sYXN0S25vd25Qcm9ncmFtID09PSBudWxsKSB7XG4gICAgICB0aWNrZXQgPSBmcmVzaENvbXBpbGF0aW9uVGlja2V0KFxuICAgICAgICAgIHByb2dyYW0sIHRoaXMub3B0aW9ucywgdGhpcy5pbmNyZW1lbnRhbFN0cmF0ZWd5LCB0aGlzLnByb2dyYW1TdHJhdGVneSxcbiAgICAgICAgICAvKiBwZXJmUmVjb3JkZXIgKi8gbnVsbCwgdHJ1ZSwgdHJ1ZSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRpY2tldCA9IGluY3JlbWVudGFsRnJvbUNvbXBpbGVyVGlja2V0KFxuICAgICAgICAgIHRoaXMuY29tcGlsZXIsIHByb2dyYW0sIHRoaXMuaW5jcmVtZW50YWxTdHJhdGVneSwgdGhpcy5wcm9ncmFtU3RyYXRlZ3ksXG4gICAgICAgICAgbW9kaWZpZWRSZXNvdXJjZUZpbGVzLCAvKiBwZXJmUmVjb3JkZXIgKi8gbnVsbCk7XG4gICAgfVxuICAgIHRoaXMuY29tcGlsZXIgPSBOZ0NvbXBpbGVyLmZyb21UaWNrZXQodGlja2V0LCB0aGlzLmFkYXB0ZXIpO1xuICAgIHRoaXMubGFzdEtub3duUHJvZ3JhbSA9IHByb2dyYW07XG4gICAgcmV0dXJuIHRoaXMuY29tcGlsZXI7XG4gIH1cblxuICByZWdpc3Rlckxhc3RLbm93blByb2dyYW0oKSB7XG4gICAgdGhpcy5sYXN0S25vd25Qcm9ncmFtID0gdGhpcy5wcm9ncmFtU3RyYXRlZ3kuZ2V0UHJvZ3JhbSgpO1xuICB9XG59XG4iXX0=
|
package/ivy/completions.d.ts
CHANGED
|
@@ -100,4 +100,9 @@ export declare class CompletionBuilder<N extends TmplAstNode | AST> {
|
|
|
100
100
|
private getElementAttributeCompletionSymbol;
|
|
101
101
|
private isPipeCompletion;
|
|
102
102
|
private getPipeCompletions;
|
|
103
|
+
/**
|
|
104
|
+
* From the AST node of the cursor position, include completion of string literals, number
|
|
105
|
+
* literals, `true`, `false`, `null`, and `undefined`.
|
|
106
|
+
*/
|
|
107
|
+
private isValidNodeContextCompletion;
|
|
103
108
|
}
|