mirror of
https://github.com/microsoft/TypeScript.git
synced 2026-02-06 02:33:53 -06:00
properly handle merged declarations across files
This commit is contained in:
parent
ba0a7c7786
commit
e5aa9cbc6f
@ -2487,7 +2487,7 @@ namespace ts {
|
||||
// Every class automatically contains a static property member named 'prototype',
|
||||
// the type of which is an instantiation of the class type with type Any supplied as a type argument for each type parameter.
|
||||
// It is an error to explicitly declare a static property member with the name 'prototype'.
|
||||
const classType = <InterfaceType>getDeclaredTypeOfSymbol(getMergedSymbol(prototype.parent));
|
||||
const classType = <InterfaceType>getDeclaredTypeOfSymbol(getParentOfSymbol(prototype));
|
||||
return classType.typeParameters ? createTypeReference(<GenericType>classType, map(classType.typeParameters, _ => anyType)) : classType;
|
||||
}
|
||||
|
||||
@ -5803,8 +5803,8 @@ namespace ts {
|
||||
}
|
||||
else if (targetPropFlags & NodeFlags.Protected) {
|
||||
const sourceDeclaredInClass = sourceProp.parent && sourceProp.parent.flags & SymbolFlags.Class;
|
||||
const sourceClass = sourceDeclaredInClass ? <InterfaceType>getDeclaredTypeOfSymbol(sourceProp.parent) : undefined;
|
||||
const targetClass = <InterfaceType>getDeclaredTypeOfSymbol(targetProp.parent);
|
||||
const sourceClass = sourceDeclaredInClass ? <InterfaceType>getDeclaredTypeOfSymbol(getParentOfSymbol(sourceProp)) : undefined;
|
||||
const targetClass = <InterfaceType>getDeclaredTypeOfSymbol(getParentOfSymbol(targetProp));
|
||||
if (!sourceClass || !hasBaseType(sourceClass, targetClass)) {
|
||||
if (reportErrors) {
|
||||
reportError(Diagnostics.Property_0_is_protected_but_type_1_is_not_a_class_derived_from_2,
|
||||
@ -8797,7 +8797,7 @@ namespace ts {
|
||||
*/
|
||||
function checkClassPropertyAccess(node: PropertyAccessExpression | QualifiedName, left: Expression | QualifiedName, type: Type, prop: Symbol): boolean {
|
||||
const flags = getDeclarationFlagsFromSymbol(prop);
|
||||
const declaringClass = <InterfaceType>getDeclaredTypeOfSymbol(getMergedSymbol(prop.parent));
|
||||
const declaringClass = <InterfaceType>getDeclaredTypeOfSymbol(getParentOfSymbol(prop));
|
||||
|
||||
if (left.kind === SyntaxKind.SuperKeyword) {
|
||||
const errorNode = node.kind === SyntaxKind.PropertyAccessExpression ?
|
||||
|
||||
34
tests/baselines/reference/mergedDeclarations5.js
Normal file
34
tests/baselines/reference/mergedDeclarations5.js
Normal file
@ -0,0 +1,34 @@
|
||||
//// [tests/cases/compiler/mergedDeclarations5.ts] ////
|
||||
|
||||
//// [a.ts]
|
||||
class A {
|
||||
protected foo() {}
|
||||
}
|
||||
//// [b.ts]
|
||||
interface A { }
|
||||
|
||||
class B extends A {
|
||||
protected foo() {}
|
||||
}
|
||||
|
||||
//// [a.js]
|
||||
var A = (function () {
|
||||
function A() {
|
||||
}
|
||||
A.prototype.foo = function () { };
|
||||
return A;
|
||||
}());
|
||||
//// [b.js]
|
||||
var __extends = (this && this.__extends) || function (d, b) {
|
||||
for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
|
||||
function __() { this.constructor = d; }
|
||||
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
||||
};
|
||||
var B = (function (_super) {
|
||||
__extends(B, _super);
|
||||
function B() {
|
||||
_super.apply(this, arguments);
|
||||
}
|
||||
B.prototype.foo = function () { };
|
||||
return B;
|
||||
}(A));
|
||||
18
tests/baselines/reference/mergedDeclarations5.symbols
Normal file
18
tests/baselines/reference/mergedDeclarations5.symbols
Normal file
@ -0,0 +1,18 @@
|
||||
=== tests/cases/compiler/a.ts ===
|
||||
class A {
|
||||
>A : Symbol(A, Decl(a.ts, 0, 0), Decl(b.ts, 0, 0))
|
||||
|
||||
protected foo() {}
|
||||
>foo : Symbol(foo, Decl(a.ts, 0, 9))
|
||||
}
|
||||
=== tests/cases/compiler/b.ts ===
|
||||
interface A { }
|
||||
>A : Symbol(A, Decl(a.ts, 0, 0), Decl(b.ts, 0, 0))
|
||||
|
||||
class B extends A {
|
||||
>B : Symbol(B, Decl(b.ts, 0, 15))
|
||||
>A : Symbol(A, Decl(a.ts, 0, 0), Decl(b.ts, 0, 0))
|
||||
|
||||
protected foo() {}
|
||||
>foo : Symbol(foo, Decl(b.ts, 2, 19))
|
||||
}
|
||||
18
tests/baselines/reference/mergedDeclarations5.types
Normal file
18
tests/baselines/reference/mergedDeclarations5.types
Normal file
@ -0,0 +1,18 @@
|
||||
=== tests/cases/compiler/a.ts ===
|
||||
class A {
|
||||
>A : A
|
||||
|
||||
protected foo() {}
|
||||
>foo : () => void
|
||||
}
|
||||
=== tests/cases/compiler/b.ts ===
|
||||
interface A { }
|
||||
>A : A
|
||||
|
||||
class B extends A {
|
||||
>B : B
|
||||
>A : A
|
||||
|
||||
protected foo() {}
|
||||
>foo : () => void
|
||||
}
|
||||
57
tests/baselines/reference/mergedDeclarations6.js
Normal file
57
tests/baselines/reference/mergedDeclarations6.js
Normal file
@ -0,0 +1,57 @@
|
||||
//// [tests/cases/compiler/mergedDeclarations6.ts] ////
|
||||
|
||||
//// [a.ts]
|
||||
|
||||
export class A {
|
||||
protected protected: any;
|
||||
|
||||
protected setProtected(val: any) {
|
||||
this.protected = val;
|
||||
}
|
||||
}
|
||||
|
||||
//// [b.ts]
|
||||
import {A} from './a';
|
||||
|
||||
declare module "./a" {
|
||||
interface A { }
|
||||
}
|
||||
|
||||
export class B extends A {
|
||||
protected setProtected() {
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
//// [a.js]
|
||||
define(["require", "exports"], function (require, exports) {
|
||||
"use strict";
|
||||
var A = (function () {
|
||||
function A() {
|
||||
}
|
||||
A.prototype.setProtected = function (val) {
|
||||
this.protected = val;
|
||||
};
|
||||
return A;
|
||||
}());
|
||||
exports.A = A;
|
||||
});
|
||||
//// [b.js]
|
||||
var __extends = (this && this.__extends) || function (d, b) {
|
||||
for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
|
||||
function __() { this.constructor = d; }
|
||||
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
|
||||
};
|
||||
define(["require", "exports", './a'], function (require, exports, a_1) {
|
||||
"use strict";
|
||||
var B = (function (_super) {
|
||||
__extends(B, _super);
|
||||
function B() {
|
||||
_super.apply(this, arguments);
|
||||
}
|
||||
B.prototype.setProtected = function () {
|
||||
};
|
||||
return B;
|
||||
}(a_1.A));
|
||||
exports.B = B;
|
||||
});
|
||||
38
tests/baselines/reference/mergedDeclarations6.symbols
Normal file
38
tests/baselines/reference/mergedDeclarations6.symbols
Normal file
@ -0,0 +1,38 @@
|
||||
=== tests/cases/compiler/a.ts ===
|
||||
|
||||
export class A {
|
||||
>A : Symbol(A, Decl(a.ts, 0, 0), Decl(b.ts, 2, 22))
|
||||
|
||||
protected protected: any;
|
||||
>protected : Symbol(protected, Decl(a.ts, 1, 16))
|
||||
|
||||
protected setProtected(val: any) {
|
||||
>setProtected : Symbol(setProtected, Decl(a.ts, 2, 29))
|
||||
>val : Symbol(val, Decl(a.ts, 4, 27))
|
||||
|
||||
this.protected = val;
|
||||
>this.protected : Symbol(protected, Decl(a.ts, 1, 16))
|
||||
>this : Symbol(A, Decl(a.ts, 0, 0), Decl(b.ts, 2, 22))
|
||||
>protected : Symbol(protected, Decl(a.ts, 1, 16))
|
||||
>val : Symbol(val, Decl(a.ts, 4, 27))
|
||||
}
|
||||
}
|
||||
|
||||
=== tests/cases/compiler/b.ts ===
|
||||
import {A} from './a';
|
||||
>A : Symbol(A, Decl(b.ts, 0, 8))
|
||||
|
||||
declare module "./a" {
|
||||
interface A { }
|
||||
>A : Symbol(A, Decl(a.ts, 0, 0), Decl(b.ts, 2, 22))
|
||||
}
|
||||
|
||||
export class B extends A {
|
||||
>B : Symbol(B, Decl(b.ts, 4, 1))
|
||||
>A : Symbol(A, Decl(b.ts, 0, 8))
|
||||
|
||||
protected setProtected() {
|
||||
>setProtected : Symbol(setProtected, Decl(b.ts, 6, 26))
|
||||
|
||||
}
|
||||
}
|
||||
39
tests/baselines/reference/mergedDeclarations6.types
Normal file
39
tests/baselines/reference/mergedDeclarations6.types
Normal file
@ -0,0 +1,39 @@
|
||||
=== tests/cases/compiler/a.ts ===
|
||||
|
||||
export class A {
|
||||
>A : A
|
||||
|
||||
protected protected: any;
|
||||
>protected : any
|
||||
|
||||
protected setProtected(val: any) {
|
||||
>setProtected : (val: any) => void
|
||||
>val : any
|
||||
|
||||
this.protected = val;
|
||||
>this.protected = val : any
|
||||
>this.protected : any
|
||||
>this : this
|
||||
>protected : any
|
||||
>val : any
|
||||
}
|
||||
}
|
||||
|
||||
=== tests/cases/compiler/b.ts ===
|
||||
import {A} from './a';
|
||||
>A : typeof A
|
||||
|
||||
declare module "./a" {
|
||||
interface A { }
|
||||
>A : A
|
||||
}
|
||||
|
||||
export class B extends A {
|
||||
>B : B
|
||||
>A : A
|
||||
|
||||
protected setProtected() {
|
||||
>setProtected : () => void
|
||||
|
||||
}
|
||||
}
|
||||
10
tests/cases/compiler/mergedDeclarations5.ts
Normal file
10
tests/cases/compiler/mergedDeclarations5.ts
Normal file
@ -0,0 +1,10 @@
|
||||
// @filename: a.ts
|
||||
class A {
|
||||
protected foo() {}
|
||||
}
|
||||
// @filename: b.ts
|
||||
interface A { }
|
||||
|
||||
class B extends A {
|
||||
protected foo() {}
|
||||
}
|
||||
23
tests/cases/compiler/mergedDeclarations6.ts
Normal file
23
tests/cases/compiler/mergedDeclarations6.ts
Normal file
@ -0,0 +1,23 @@
|
||||
// @module: amd
|
||||
|
||||
// @filename: a.ts
|
||||
export class A {
|
||||
protected protected: any;
|
||||
|
||||
protected setProtected(val: any) {
|
||||
this.protected = val;
|
||||
}
|
||||
}
|
||||
|
||||
// @filename: b.ts
|
||||
import {A} from './a';
|
||||
|
||||
declare module "./a" {
|
||||
interface A { }
|
||||
}
|
||||
|
||||
export class B extends A {
|
||||
protected setProtected() {
|
||||
|
||||
}
|
||||
}
|
||||
Loading…
x
Reference in New Issue
Block a user