TypeScript/tests/baselines/reference/newOperatorConformance.symbols
2015-04-15 16:44:20 -07:00

136 lines
5.5 KiB
Plaintext

=== tests/cases/conformance/expressions/newOperator/newOperatorConformance.ts ===
class C0 {
>C0 : Symbol(C0, Decl(newOperatorConformance.ts, 0, 0))
}
class C1 {
>C1 : Symbol(C1, Decl(newOperatorConformance.ts, 3, 1))
constructor(n: number, s: string) { }
>n : Symbol(n, Decl(newOperatorConformance.ts, 5, 16))
>s : Symbol(s, Decl(newOperatorConformance.ts, 5, 26))
}
class T<T> {
>T : Symbol(T, Decl(newOperatorConformance.ts, 6, 1))
>T : Symbol(T, Decl(newOperatorConformance.ts, 8, 8))
constructor(n?: T) { }
>n : Symbol(n, Decl(newOperatorConformance.ts, 9, 16))
>T : Symbol(T, Decl(newOperatorConformance.ts, 8, 8))
}
var anyCtor: {
>anyCtor : Symbol(anyCtor, Decl(newOperatorConformance.ts, 12, 3))
new (): any;
};
var anyCtor1: {
>anyCtor1 : Symbol(anyCtor1, Decl(newOperatorConformance.ts, 16, 3))
new (n): any;
>n : Symbol(n, Decl(newOperatorConformance.ts, 17, 9))
};
interface nestedCtor {
>nestedCtor : Symbol(nestedCtor, Decl(newOperatorConformance.ts, 18, 2), Decl(newOperatorConformance.ts, 23, 3))
new (): nestedCtor;
>nestedCtor : Symbol(nestedCtor, Decl(newOperatorConformance.ts, 18, 2), Decl(newOperatorConformance.ts, 23, 3))
}
var nestedCtor: nestedCtor;
>nestedCtor : Symbol(nestedCtor, Decl(newOperatorConformance.ts, 18, 2), Decl(newOperatorConformance.ts, 23, 3))
>nestedCtor : Symbol(nestedCtor, Decl(newOperatorConformance.ts, 18, 2), Decl(newOperatorConformance.ts, 23, 3))
// Construct expression with no parentheses for construct signature with 0 parameters
var a = new C0;
>a : Symbol(a, Decl(newOperatorConformance.ts, 26, 3), Decl(newOperatorConformance.ts, 27, 3))
>C0 : Symbol(C0, Decl(newOperatorConformance.ts, 0, 0))
var a: C0;
>a : Symbol(a, Decl(newOperatorConformance.ts, 26, 3), Decl(newOperatorConformance.ts, 27, 3))
>C0 : Symbol(C0, Decl(newOperatorConformance.ts, 0, 0))
// Generic construct expression with no parentheses
var c1 = new T;
>c1 : Symbol(c1, Decl(newOperatorConformance.ts, 31, 3), Decl(newOperatorConformance.ts, 32, 3))
>T : Symbol(T, Decl(newOperatorConformance.ts, 6, 1))
var c1: T<{}>;
>c1 : Symbol(c1, Decl(newOperatorConformance.ts, 31, 3), Decl(newOperatorConformance.ts, 32, 3))
>T : Symbol(T, Decl(newOperatorConformance.ts, 6, 1))
// Construct expression where constructor is of type 'any' with no parentheses
var d = new anyCtor;
>d : Symbol(d, Decl(newOperatorConformance.ts, 35, 3), Decl(newOperatorConformance.ts, 36, 3), Decl(newOperatorConformance.ts, 39, 3))
>anyCtor : Symbol(anyCtor, Decl(newOperatorConformance.ts, 12, 3))
var d: any;
>d : Symbol(d, Decl(newOperatorConformance.ts, 35, 3), Decl(newOperatorConformance.ts, 36, 3), Decl(newOperatorConformance.ts, 39, 3))
// Construct expression where constructor is of type 'any' with > 1 arg
var d = new anyCtor1(undefined);
>d : Symbol(d, Decl(newOperatorConformance.ts, 35, 3), Decl(newOperatorConformance.ts, 36, 3), Decl(newOperatorConformance.ts, 39, 3))
>anyCtor1 : Symbol(anyCtor1, Decl(newOperatorConformance.ts, 16, 3))
>undefined : Symbol(undefined)
// Construct expression of type where apparent type has a construct signature with 0 arguments
function newFn1<T extends { new (): number }>(s: T) {
>newFn1 : Symbol(newFn1, Decl(newOperatorConformance.ts, 39, 32))
>T : Symbol(T, Decl(newOperatorConformance.ts, 42, 16))
>s : Symbol(s, Decl(newOperatorConformance.ts, 42, 46))
>T : Symbol(T, Decl(newOperatorConformance.ts, 42, 16))
var p = new s;
>p : Symbol(p, Decl(newOperatorConformance.ts, 43, 7), Decl(newOperatorConformance.ts, 44, 7))
>s : Symbol(s, Decl(newOperatorConformance.ts, 42, 46))
var p: number;
>p : Symbol(p, Decl(newOperatorConformance.ts, 43, 7), Decl(newOperatorConformance.ts, 44, 7))
}
// Construct expression of type where apparent type has a construct signature with 1 arguments
function newFn2<T extends { new (s: number): string}>(s: T) {
>newFn2 : Symbol(newFn2, Decl(newOperatorConformance.ts, 45, 1))
>T : Symbol(T, Decl(newOperatorConformance.ts, 48, 16))
>s : Symbol(s, Decl(newOperatorConformance.ts, 48, 33))
>s : Symbol(s, Decl(newOperatorConformance.ts, 48, 54))
>T : Symbol(T, Decl(newOperatorConformance.ts, 48, 16))
var p = new s(32);
>p : Symbol(p, Decl(newOperatorConformance.ts, 49, 7), Decl(newOperatorConformance.ts, 50, 7))
>s : Symbol(s, Decl(newOperatorConformance.ts, 48, 54))
var p: string;
>p : Symbol(p, Decl(newOperatorConformance.ts, 49, 7), Decl(newOperatorConformance.ts, 50, 7))
}
// Construct expression of void returning function
function fnVoid(): void { }
>fnVoid : Symbol(fnVoid, Decl(newOperatorConformance.ts, 51, 1))
var t = new fnVoid();
>t : Symbol(t, Decl(newOperatorConformance.ts, 55, 3), Decl(newOperatorConformance.ts, 56, 3))
>fnVoid : Symbol(fnVoid, Decl(newOperatorConformance.ts, 51, 1))
var t: any;
>t : Symbol(t, Decl(newOperatorConformance.ts, 55, 3), Decl(newOperatorConformance.ts, 56, 3))
// Chained new expressions
var nested = new (new (new nestedCtor())())();
>nested : Symbol(nested, Decl(newOperatorConformance.ts, 59, 3))
>nestedCtor : Symbol(nestedCtor, Decl(newOperatorConformance.ts, 18, 2), Decl(newOperatorConformance.ts, 23, 3))
var n = new nested();
>n : Symbol(n, Decl(newOperatorConformance.ts, 60, 3), Decl(newOperatorConformance.ts, 61, 3))
>nested : Symbol(nested, Decl(newOperatorConformance.ts, 59, 3))
var n = new nested();
>n : Symbol(n, Decl(newOperatorConformance.ts, 60, 3), Decl(newOperatorConformance.ts, 61, 3))
>nested : Symbol(nested, Decl(newOperatorConformance.ts, 59, 3))