mirror of
https://github.com/microsoft/TypeScript.git
synced 2026-05-16 15:45:27 -05:00
Merge branch 'master' into computedProperties
This commit is contained in:
@@ -0,0 +1,10 @@
|
||||
declare module m {
|
||||
// type alias declaration here shouldnt make the module declaration instantiated
|
||||
type Selector = string| string[] |Function;
|
||||
|
||||
export interface IStatic {
|
||||
(selector: any /* Selector */): IInstance;
|
||||
}
|
||||
export interface IInstance { }
|
||||
}
|
||||
declare var m: m.IStatic; // Should be ok to have var 'm' as module is non instantiated
|
||||
@@ -1,7 +1,9 @@
|
||||
enum E { a, b }
|
||||
enum F { c, d }
|
||||
|
||||
var a: number;
|
||||
var b: E;
|
||||
var c: E | F;
|
||||
|
||||
var r1 = a + a;
|
||||
var r2 = a + b;
|
||||
@@ -11,4 +13,11 @@ var r4 = b + b;
|
||||
var r5 = 0 + a;
|
||||
var r6 = E.a + 0;
|
||||
var r7 = E.a + E.b;
|
||||
var r8 = E['a'] + E['b'];
|
||||
var r8 = E['a'] + E['b'];
|
||||
var r9 = E['a'] + F['c'];
|
||||
|
||||
var r10 = a + c;
|
||||
var r11 = c + a;
|
||||
var r12 = b + c;
|
||||
var r13 = c + b;
|
||||
var r14 = c + c;
|
||||
|
||||
@@ -0,0 +1,154 @@
|
||||
// operands of an enum type are treated as having the primitive type Number.
|
||||
|
||||
enum E {
|
||||
a,
|
||||
b
|
||||
}
|
||||
enum F {
|
||||
c,
|
||||
d
|
||||
}
|
||||
|
||||
var a: any;
|
||||
var b: number;
|
||||
var c: E | F;
|
||||
|
||||
// operator *
|
||||
var ra1 = c * a;
|
||||
var ra2 = c * b;
|
||||
var ra3 = c * c;
|
||||
var ra4 = a * c;
|
||||
var ra5 = b * c;
|
||||
var ra6 = E.a * a;
|
||||
var ra7 = E.a * b;
|
||||
var ra8 = E.a * E.b;
|
||||
var ra9 = E.a * 1;
|
||||
var ra10 = a * E.b;
|
||||
var ra11 = b * E.b;
|
||||
var ra12 = 1 * E.b;
|
||||
|
||||
// operator /
|
||||
var rb1 = c / a;
|
||||
var rb2 = c / b;
|
||||
var rb3 = c / c;
|
||||
var rb4 = a / c;
|
||||
var rb5 = b / c;
|
||||
var rb6 = E.a / a;
|
||||
var rb7 = E.a / b;
|
||||
var rb8 = E.a / E.b;
|
||||
var rb9 = E.a / 1;
|
||||
var rb10 = a / E.b;
|
||||
var rb11 = b / E.b;
|
||||
var rb12 = 1 / E.b;
|
||||
|
||||
// operator %
|
||||
var rc1 = c % a;
|
||||
var rc2 = c % b;
|
||||
var rc3 = c % c;
|
||||
var rc4 = a % c;
|
||||
var rc5 = b % c;
|
||||
var rc6 = E.a % a;
|
||||
var rc7 = E.a % b;
|
||||
var rc8 = E.a % E.b;
|
||||
var rc9 = E.a % 1;
|
||||
var rc10 = a % E.b;
|
||||
var rc11 = b % E.b;
|
||||
var rc12 = 1 % E.b;
|
||||
|
||||
// operator -
|
||||
var rd1 = c - a;
|
||||
var rd2 = c - b;
|
||||
var rd3 = c - c;
|
||||
var rd4 = a - c;
|
||||
var rd5 = b - c;
|
||||
var rd6 = E.a - a;
|
||||
var rd7 = E.a - b;
|
||||
var rd8 = E.a - E.b;
|
||||
var rd9 = E.a - 1;
|
||||
var rd10 = a - E.b;
|
||||
var rd11 = b - E.b;
|
||||
var rd12 = 1 - E.b;
|
||||
|
||||
// operator <<
|
||||
var re1 = c << a;
|
||||
var re2 = c << b;
|
||||
var re3 = c << c;
|
||||
var re4 = a << c;
|
||||
var re5 = b << c;
|
||||
var re6 = E.a << a;
|
||||
var re7 = E.a << b;
|
||||
var re8 = E.a << E.b;
|
||||
var re9 = E.a << 1;
|
||||
var re10 = a << E.b;
|
||||
var re11 = b << E.b;
|
||||
var re12 = 1 << E.b;
|
||||
|
||||
// operator >>
|
||||
var rf1 = c >> a;
|
||||
var rf2 = c >> b;
|
||||
var rf3 = c >> c;
|
||||
var rf4 = a >> c;
|
||||
var rf5 = b >> c;
|
||||
var rf6 = E.a >> a;
|
||||
var rf7 = E.a >> b;
|
||||
var rf8 = E.a >> E.b;
|
||||
var rf9 = E.a >> 1;
|
||||
var rf10 = a >> E.b;
|
||||
var rf11 = b >> E.b;
|
||||
var rf12 = 1 >> E.b;
|
||||
|
||||
// operator >>>
|
||||
var rg1 = c >>> a;
|
||||
var rg2 = c >>> b;
|
||||
var rg3 = c >>> c;
|
||||
var rg4 = a >>> c;
|
||||
var rg5 = b >>> c;
|
||||
var rg6 = E.a >>> a;
|
||||
var rg7 = E.a >>> b;
|
||||
var rg8 = E.a >>> E.b;
|
||||
var rg9 = E.a >>> 1;
|
||||
var rg10 = a >>> E.b;
|
||||
var rg11 = b >>> E.b;
|
||||
var rg12 = 1 >>> E.b;
|
||||
|
||||
// operator &
|
||||
var rh1 = c & a;
|
||||
var rh2 = c & b;
|
||||
var rh3 = c & c;
|
||||
var rh4 = a & c;
|
||||
var rh5 = b & c;
|
||||
var rh6 = E.a & a;
|
||||
var rh7 = E.a & b;
|
||||
var rh8 = E.a & E.b;
|
||||
var rh9 = E.a & 1;
|
||||
var rh10 = a & E.b;
|
||||
var rh11 = b & E.b;
|
||||
var rh12 = 1 & E.b;
|
||||
|
||||
// operator ^
|
||||
var ri1 = c ^ a;
|
||||
var ri2 = c ^ b;
|
||||
var ri3 = c ^ c;
|
||||
var ri4 = a ^ c;
|
||||
var ri5 = b ^ c;
|
||||
var ri6 = E.a ^ a;
|
||||
var ri7 = E.a ^ b;
|
||||
var ri8 = E.a ^ E.b;
|
||||
var ri9 = E.a ^ 1;
|
||||
var ri10 = a ^ E.b;
|
||||
var ri11 = b ^ E.b;
|
||||
var ri12 = 1 ^ E.b;
|
||||
|
||||
// operator |
|
||||
var rj1 = c | a;
|
||||
var rj2 = c | b;
|
||||
var rj3 = c | c;
|
||||
var rj4 = a | c;
|
||||
var rj5 = b | c;
|
||||
var rj6 = E.a | a;
|
||||
var rj7 = E.a | b;
|
||||
var rj8 = E.a | E.b;
|
||||
var rj9 = E.a | 1;
|
||||
var rj10 = a | E.b;
|
||||
var rj11 = b | E.b;
|
||||
var rj12 = 1 | E.b;
|
||||
@@ -1,3 +1,9 @@
|
||||
class A {
|
||||
a: number;
|
||||
}
|
||||
class B extends A {
|
||||
b: number;
|
||||
}
|
||||
enum Compass {
|
||||
North, South, East, West
|
||||
}
|
||||
@@ -6,8 +12,8 @@ var numIndex: { [n: number]: string } = { 3: 'three', 'three': 'three' };
|
||||
var strIndex: { [n: string]: Compass } = { 'N': Compass.North, 'E': Compass.East };
|
||||
var bothIndex:
|
||||
{
|
||||
[n: string]: HTMLElement;
|
||||
[m: number]: HTMLDivElement;
|
||||
[n: string]: A;
|
||||
[m: number]: B;
|
||||
};
|
||||
|
||||
function noIndex() { }
|
||||
@@ -20,6 +26,8 @@ var obj = {
|
||||
'literal property': 100
|
||||
};
|
||||
var anyVar: any = {};
|
||||
var stringOrNumber: string | number;
|
||||
var someObject: { name: string };
|
||||
|
||||
// Assign to a property access
|
||||
obj.y = 4;
|
||||
@@ -69,7 +77,7 @@ var kk = numIndex['what'];
|
||||
var kk: any;
|
||||
|
||||
// Bracket notation property access using value of other type on type with numeric index signature and no string index signature
|
||||
var ll = numIndex[window]; // Error
|
||||
var ll = numIndex[someObject]; // Error
|
||||
|
||||
// Bracket notation property access using string value on type with string index signature and no numeric index signature
|
||||
var mm = strIndex['N'];
|
||||
@@ -106,7 +114,7 @@ var tt = noIndex[<any>null];
|
||||
var tt: any;
|
||||
|
||||
// Bracket notation property access using values of other types on type with no index signatures
|
||||
var uu = noIndex[window]; // Error
|
||||
var uu = noIndex[someObject]; // Error
|
||||
|
||||
// Bracket notation property access using numeric value on type with numeric index signature and string index signature
|
||||
var vv = noIndex[32];
|
||||
@@ -114,19 +122,28 @@ var vv: any;
|
||||
|
||||
// Bracket notation property access using enum value on type with numeric index signature and string index signature
|
||||
var ww = bothIndex[Compass.East];
|
||||
var ww: HTMLDivElement;
|
||||
var ww: B;
|
||||
|
||||
// Bracket notation property access using value of type 'any' on type with numeric index signature and string index signature
|
||||
var xx = bothIndex[<any>null];
|
||||
var xx: HTMLDivElement;
|
||||
var xx: B;
|
||||
|
||||
// Bracket notation property access using string value on type with numeric index signature and string index signature
|
||||
var yy = bothIndex['foo'];
|
||||
var yy: HTMLElement;
|
||||
var yy: A;
|
||||
|
||||
// Bracket notation property access using numeric string value on type with numeric index signature and string index signature
|
||||
var zz = bothIndex['1.0'];
|
||||
var zz: HTMLElement;
|
||||
var zz: A;
|
||||
|
||||
// Bracket notation property access using value of other type on type with numeric index signature and no string index signature and string index signature
|
||||
var zzzz = bothIndex[window]; // Error
|
||||
var zzzz = bothIndex[someObject]; // Error
|
||||
|
||||
var x1 = numIndex[stringOrNumber];
|
||||
var x1: any;
|
||||
|
||||
var x2 = strIndex[stringOrNumber];
|
||||
var x2: Compass;
|
||||
|
||||
var x3 = bothIndex[stringOrNumber];
|
||||
var x3: A;
|
||||
|
||||
Reference in New Issue
Block a user