@zzzen/pyright-internal 1.2.0-dev.20230507 → 1.2.0-dev.20230514
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/dist/analyzer/backgroundAnalysisProgram.d.ts +1 -1
- package/dist/analyzer/checker.js +37 -2
- package/dist/analyzer/checker.js.map +1 -1
- package/dist/analyzer/constraintSolver.js +14 -15
- package/dist/analyzer/constraintSolver.js.map +1 -1
- package/dist/analyzer/constructors.js +246 -189
- package/dist/analyzer/constructors.js.map +1 -1
- package/dist/analyzer/dataClasses.js +2 -2
- package/dist/analyzer/dataClasses.js.map +1 -1
- package/dist/analyzer/docStringConversion.js +1 -1
- package/dist/analyzer/docStringConversion.js.map +1 -1
- package/dist/analyzer/enums.js +8 -0
- package/dist/analyzer/enums.js.map +1 -1
- package/dist/analyzer/importResolver.js +47 -29
- package/dist/analyzer/importResolver.js.map +1 -1
- package/dist/analyzer/namedTuples.js +2 -5
- package/dist/analyzer/namedTuples.js.map +1 -1
- package/dist/analyzer/program.d.ts +7 -17
- package/dist/analyzer/program.js +32 -247
- package/dist/analyzer/program.js.map +1 -1
- package/dist/analyzer/protocols.js +1 -1
- package/dist/analyzer/protocols.js.map +1 -1
- package/dist/analyzer/service.d.ts +4 -12
- package/dist/analyzer/service.js +12 -23
- package/dist/analyzer/service.js.map +1 -1
- package/dist/analyzer/sourceFile.d.ts +2 -11
- package/dist/analyzer/sourceFile.js +11 -74
- package/dist/analyzer/sourceFile.js.map +1 -1
- package/dist/analyzer/symbol.d.ts +3 -1
- package/dist/analyzer/symbol.js +5 -0
- package/dist/analyzer/symbol.js.map +1 -1
- package/dist/analyzer/typeEvaluator.js +362 -142
- package/dist/analyzer/typeEvaluator.js.map +1 -1
- package/dist/analyzer/typeEvaluatorTypes.d.ts +4 -0
- package/dist/analyzer/typeEvaluatorTypes.js.map +1 -1
- package/dist/analyzer/typePrinter.d.ts +3 -3
- package/dist/analyzer/typePrinter.js +247 -100
- package/dist/analyzer/typePrinter.js.map +1 -1
- package/dist/analyzer/typeUtils.d.ts +12 -7
- package/dist/analyzer/typeUtils.js +173 -48
- package/dist/analyzer/typeUtils.js.map +1 -1
- package/dist/analyzer/typeVarContext.d.ts +1 -2
- package/dist/analyzer/typeVarContext.js +14 -32
- package/dist/analyzer/typeVarContext.js.map +1 -1
- package/dist/analyzer/types.d.ts +3 -2
- package/dist/analyzer/types.js +13 -10
- package/dist/analyzer/types.js.map +1 -1
- package/dist/backgroundAnalysisBase.d.ts +1 -1
- package/dist/backgroundAnalysisBase.js +16 -0
- package/dist/backgroundAnalysisBase.js.map +1 -1
- package/dist/commands/dumpFileDebugInfoCommand.js +0 -1
- package/dist/commands/dumpFileDebugInfoCommand.js.map +1 -1
- package/dist/common/extensibility.d.ts +26 -3
- package/dist/common/extensibility.js.map +1 -1
- package/dist/common/logTracker.d.ts +2 -0
- package/dist/common/logTracker.js +8 -1
- package/dist/common/logTracker.js.map +1 -1
- package/dist/common/lspUtils.d.ts +4 -1
- package/dist/common/lspUtils.js +38 -1
- package/dist/common/lspUtils.js.map +1 -1
- package/dist/common/pythonVersion.d.ts +2 -1
- package/dist/common/pythonVersion.js +1 -0
- package/dist/common/pythonVersion.js.map +1 -1
- package/dist/common/workspaceEditUtils.d.ts +3 -3
- package/dist/common/workspaceEditUtils.js +10 -10
- package/dist/common/workspaceEditUtils.js.map +1 -1
- package/dist/languageServerBase.d.ts +2 -5
- package/dist/languageServerBase.js +33 -60
- package/dist/languageServerBase.js.map +1 -1
- package/dist/languageService/autoImporter.d.ts +50 -51
- package/dist/languageService/autoImporter.js +125 -210
- package/dist/languageService/autoImporter.js.map +1 -1
- package/dist/languageService/callHierarchyProvider.js +6 -32
- package/dist/languageService/callHierarchyProvider.js.map +1 -1
- package/dist/languageService/completionProvider.d.ts +40 -79
- package/dist/languageService/completionProvider.js +571 -811
- package/dist/languageService/completionProvider.js.map +1 -1
- package/dist/languageService/documentSymbolCollector.d.ts +2 -2
- package/dist/languageService/documentSymbolCollector.js +33 -23
- package/dist/languageService/documentSymbolCollector.js.map +1 -1
- package/dist/languageService/documentSymbolProvider.d.ts +13 -35
- package/dist/languageService/documentSymbolProvider.js +52 -264
- package/dist/languageService/documentSymbolProvider.js.map +1 -1
- package/dist/languageService/hoverProvider.d.ts +1 -3
- package/dist/languageService/hoverProvider.js +11 -97
- package/dist/languageService/hoverProvider.js.map +1 -1
- package/dist/languageService/referencesProvider.d.ts +3 -3
- package/dist/languageService/referencesProvider.js +5 -7
- package/dist/languageService/referencesProvider.js.map +1 -1
- package/dist/languageService/renameProvider.d.ts +0 -1
- package/dist/languageService/renameProvider.js +2 -6
- package/dist/languageService/renameProvider.js.map +1 -1
- package/dist/languageService/symbolIndexer.d.ts +31 -0
- package/dist/languageService/symbolIndexer.js +105 -0
- package/dist/languageService/symbolIndexer.js.map +1 -0
- package/dist/languageService/tooltipUtils.d.ts +8 -1
- package/dist/languageService/tooltipUtils.js +102 -1
- package/dist/languageService/tooltipUtils.js.map +1 -1
- package/dist/languageService/workspaceSymbolProvider.d.ts +17 -0
- package/dist/languageService/workspaceSymbolProvider.js +133 -0
- package/dist/languageService/workspaceSymbolProvider.js.map +1 -0
- package/dist/localization/localize.d.ts +16 -1
- package/dist/localization/localize.js +9 -1
- package/dist/localization/localize.js.map +1 -1
- package/dist/localization/package.nls.en-us.json +9 -1
- package/dist/parser/parser.js +3 -0
- package/dist/parser/parser.js.map +1 -1
- package/dist/pyright.js +26 -4
- package/dist/pyright.js.map +1 -1
- package/dist/tests/chainedSourceFiles.test.js +15 -20
- package/dist/tests/chainedSourceFiles.test.js.map +1 -1
- package/dist/tests/checker.test.js +14 -0
- package/dist/tests/checker.test.js.map +1 -1
- package/dist/tests/completions.test.js +11 -236
- package/dist/tests/completions.test.js.map +1 -1
- package/dist/tests/docStringConversion.test.js +36 -2
- package/dist/tests/docStringConversion.test.js.map +1 -1
- package/dist/tests/fourslash/completions.override2.fourslash.js +1 -16
- package/dist/tests/fourslash/completions.override2.fourslash.js.map +1 -1
- package/dist/tests/harness/fourslash/testState.d.ts +14 -8
- package/dist/tests/harness/fourslash/testState.js +25 -36
- package/dist/tests/harness/fourslash/testState.js.map +1 -1
- package/dist/tests/importResolver.test.js +81 -1
- package/dist/tests/importResolver.test.js.map +1 -1
- package/dist/tests/typeEvaluator2.test.js +12 -0
- package/dist/tests/typeEvaluator2.test.js.map +1 -1
- package/dist/tests/typeEvaluator3.test.js +4 -0
- package/dist/tests/typeEvaluator3.test.js.map +1 -1
- package/dist/tests/typeEvaluator5.test.js +21 -9
- package/dist/tests/typeEvaluator5.test.js.map +1 -1
- package/dist/tests/workspaceEditUtils.test.js +15 -10
- package/dist/tests/workspaceEditUtils.test.js.map +1 -1
- package/package.json +1 -1
- package/dist/languageService/importAdder.d.ts +0 -40
- package/dist/languageService/importAdder.js +0 -388
- package/dist/languageService/importAdder.js.map +0 -1
- package/dist/tests/fourslash/completions.commitChars.fourslash.d.ts +0 -1
- package/dist/tests/fourslash/completions.commitChars.fourslash.js +0 -81
- package/dist/tests/fourslash/completions.commitChars.fourslash.js.map +0 -1
- package/dist/tests/importAdder.test.d.ts +0 -1
- package/dist/tests/importAdder.test.js +0 -1325
- package/dist/tests/importAdder.test.js.map +0 -1
@@ -45,7 +45,7 @@ export declare class BackgroundAnalysisProgram {
|
|
45
45
|
startIndexing(indexOptions: IndexOptions): void;
|
46
46
|
refreshIndexing(refreshOptions?: RefreshOptions): void;
|
47
47
|
cancelIndexing(): void;
|
48
|
-
getIndexing(filePath: string): Map<string, import("../languageService/
|
48
|
+
getIndexing(filePath: string): Map<string, import("../languageService/symbolIndexer").IndexResults> | undefined;
|
49
49
|
getDiagnosticsForRange(filePath: string, range: Range, token: CancellationToken): Promise<Diagnostic[]>;
|
50
50
|
writeTypeStub(targetImportPath: string, targetIsSingleFile: boolean, stubPath: string, token: CancellationToken): Promise<any>;
|
51
51
|
invalidateAndForceReanalysis(rebuildUserFileIndexing: boolean, rebuildLibraryIndexing: boolean, refreshOptions?: RefreshOptions): void;
|
package/dist/analyzer/checker.js
CHANGED
@@ -213,7 +213,7 @@ class Checker extends parseTreeWalker_1.ParseTreeWalker {
|
|
213
213
|
this._validateMultipleInheritanceCompatibility(classTypeResult.classType, node.name);
|
214
214
|
this._validateConstructorConsistency(classTypeResult.classType);
|
215
215
|
this._validateFinalMemberOverrides(classTypeResult.classType);
|
216
|
-
this._validateInstanceVariableInitialization(classTypeResult.classType);
|
216
|
+
this._validateInstanceVariableInitialization(node, classTypeResult.classType);
|
217
217
|
this._validateFinalClassNotAbstract(classTypeResult.classType, node);
|
218
218
|
this._validateDataClassPostInit(classTypeResult.classType, node);
|
219
219
|
this._validateProtocolCompatibility(classTypeResult.classType, node);
|
@@ -3297,7 +3297,7 @@ class Checker extends parseTreeWalker_1.ParseTreeWalker {
|
|
3297
3297
|
}
|
3298
3298
|
// Reports the case where an instance variable is not declared or initialized
|
3299
3299
|
// within the class body or constructor method.
|
3300
|
-
_validateInstanceVariableInitialization(classType) {
|
3300
|
+
_validateInstanceVariableInitialization(node, classType) {
|
3301
3301
|
// This check doesn't apply to stub files.
|
3302
3302
|
if (this._fileInfo.isStubFile) {
|
3303
3303
|
return;
|
@@ -3313,7 +3313,14 @@ class Checker extends parseTreeWalker_1.ParseTreeWalker {
|
|
3313
3313
|
(types_1.ClassType.supportsAbstractMethods(classType) && !types_1.ClassType.isFinal(classType))) {
|
3314
3314
|
return;
|
3315
3315
|
}
|
3316
|
+
// If the class is final, see if it has any abstract base classes that define
|
3317
|
+
// variables. We need to make sure these are initialized.
|
3318
|
+
const abstractSymbols = new Map();
|
3319
|
+
if (types_1.ClassType.isFinal(classType)) {
|
3320
|
+
(0, typeUtils_1.getProtocolSymbolsRecursive)(classType, abstractSymbols, 512 /* SupportsAbstractMethods */);
|
3321
|
+
}
|
3316
3322
|
classType.details.fields.forEach((localSymbol, name) => {
|
3323
|
+
abstractSymbols.delete(name);
|
3317
3324
|
// This applies only to instance members.
|
3318
3325
|
if (!localSymbol.isInstanceMember()) {
|
3319
3326
|
return;
|
@@ -3365,6 +3372,31 @@ class Checker extends parseTreeWalker_1.ParseTreeWalker {
|
|
3365
3372
|
// Report the variable as uninitialized only on the first decl.
|
3366
3373
|
this._evaluator.addDiagnostic(this._fileInfo.diagnosticRuleSet.reportUninitializedInstanceVariable, diagnosticRules_1.DiagnosticRule.reportUninitializedInstanceVariable, localize_1.Localizer.Diagnostic.uninitializedInstanceVariable().format({ name: name }), decls[0].node);
|
3367
3374
|
});
|
3375
|
+
// See if there are any variables from abstract base classes
|
3376
|
+
// that are not initialized.
|
3377
|
+
const diagAddendum = new diagnostic_1.DiagnosticAddendum();
|
3378
|
+
abstractSymbols.forEach((member, name) => {
|
3379
|
+
const decls = member.symbol.getDeclarations();
|
3380
|
+
if (decls.length === 0 || !(0, types_1.isClass)(member.classType)) {
|
3381
|
+
return;
|
3382
|
+
}
|
3383
|
+
if (decls[0].type === 1 /* Variable */) {
|
3384
|
+
// If none of the declarations involve assignments, assume it's
|
3385
|
+
// not implemented in the protocol.
|
3386
|
+
if (!decls.some((decl) => decl.type === 1 /* Variable */ && !!decl.inferredTypeSource)) {
|
3387
|
+
// This is a variable declaration that is not implemented in the
|
3388
|
+
// protocol base class. Make sure it's implemented in the derived class.
|
3389
|
+
diagAddendum.addMessage(localize_1.Localizer.DiagnosticAddendum.uninitializedAbstractVariable().format({
|
3390
|
+
name,
|
3391
|
+
classType: member.classType.details.name,
|
3392
|
+
}));
|
3393
|
+
}
|
3394
|
+
}
|
3395
|
+
});
|
3396
|
+
if (!diagAddendum.isEmpty()) {
|
3397
|
+
this._evaluator.addDiagnostic(this._fileInfo.diagnosticRuleSet.reportUninitializedInstanceVariable, diagnosticRules_1.DiagnosticRule.reportUninitializedInstanceVariable, localize_1.Localizer.Diagnostic.uninitializedAbstractVariables().format({ classType: classType.details.name }) +
|
3398
|
+
diagAddendum.getString(), node.name);
|
3399
|
+
}
|
3368
3400
|
}
|
3369
3401
|
// Validates that the type variables used in a generic protocol class have
|
3370
3402
|
// the proper variance (invariant, covariant, contravariant). See PEP 544
|
@@ -3853,6 +3885,9 @@ class Checker extends parseTreeWalker_1.ParseTreeWalker {
|
|
3853
3885
|
if (!(0, types_1.isInstantiableClass)(baseClassAndSymbol.classType)) {
|
3854
3886
|
return;
|
3855
3887
|
}
|
3888
|
+
if (baseClassAndSymbol.symbol.isIgnoredForOverrideChecks()) {
|
3889
|
+
return;
|
3890
|
+
}
|
3856
3891
|
// If the base class doesn't provide a type declaration, we won't bother
|
3857
3892
|
// proceeding with additional checks. Type inference is too inaccurate
|
3858
3893
|
// in this case, plus it would be very slow.
|