-
Notifications
You must be signed in to change notification settings - Fork 185
/
Copy pathglobals.d.ts
109 lines (91 loc) · 3.67 KB
/
globals.d.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
/*! *****************************************************************************
Copyright (C) Microsoft. All rights reserved.
Licensed under the Apache License, Version 2.0 (the "License"); you may not use
this file except in compliance with the License. You may obtain a copy of the
License at http://www.apache.org/licenses/LICENSE-2.0
THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED
WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,
MERCHANTABLITY OR NON-INFRINGEMENT.
See the Apache Version 2.0 License for specific language governing permissions
and limitations under the License.
***************************************************************************** */
interface SymbolConstructor {
(description?: string): symbol;
for(key: string): symbol;
readonly iterator: symbol;
readonly toPrimitive: symbol;
}
declare var Symbol: SymbolConstructor;
interface Iterator<T> {
next(value?: any): __IteratorResult<T>;
throw?(value: any): __IteratorResult<T>;
return?(value?: T): __IteratorResult<T>;
}
type __IteratorResult<T> = { value: T, done: false } | { value: never, done: true };
interface Iterable<T> {
[Symbol.iterator](): Iterator<T>;
}
interface IterableIterator<T> extends Iterator<T> {
[Symbol.iterator](): IterableIterator<T>;
}
interface Map<K, V> extends Iterable<[K, V]> {
readonly size: number;
has(key: K): boolean;
get(key: K): V;
set(key: K, value?: V): this;
delete(key: K): boolean;
clear(): void;
keys(): IterableIterator<K>;
values(): IterableIterator<V>;
entries(): IterableIterator<[K, V]>;
}
interface MapConstructor {
new (): Map<any, any>;
new <K, V>(): Map<K, V>;
readonly prototype: Map<any, any>;
}
interface Set<T> extends Iterable<T> {
readonly size: number;
has(value: T): boolean;
add(value: T): this;
delete(value: T): boolean;
clear(): void;
keys(): IterableIterator<T>;
values(): IterableIterator<T>;
entries(): IterableIterator<[T, T]>;
}
interface SetConstructor {
new (): Set<any>;
new <T>(): Set<T>;
readonly prototype: Set<any>;
}
interface WeakMap<K extends object, V> {
clear(): void;
delete(key: K): boolean;
get(key: K): V;
has(key: K): boolean;
set(key: K, value?: V): WeakMap<K, V>;
}
interface WeakMapConstructor {
new (): WeakMap<any, any>;
new <K extends object, V>(): WeakMap<K, V>;
readonly prototype: WeakMap<object, any>;
}
declare var Map: MapConstructor;
declare var Set: SetConstructor;
declare var WeakMap: WeakMapConstructor;
// NOTE: These are not actually global, just shared between the Reflect*.ts variants
interface MetadataRegistry {
registerProvider(provider: MetadataProvider): void;
getProvider(O: object, P: string | symbol | undefined): MetadataProvider | undefined;
setProvider(O: object, P: string | symbol | undefined, provider: MetadataProvider): boolean;
}
interface MetadataProvider {
isProviderFor(O: object, P: string | symbol | undefined): boolean;
OrdinaryDefineOwnMetadata(MetadataKey: any, MetadataValue: any, O: object, P: string | symbol | undefined): void;
OrdinaryDeleteMetadata(MetadataKey: any, O: object, P: string | symbol | undefined): boolean;
OrdinaryHasOwnMetadata(MetadataKey: any, O: object, P: string | symbol | undefined): boolean;
OrdinaryGetOwnMetadata(MetadataKey: any, O: object, P: string | symbol | undefined): any;
OrdinaryOwnMetadataKeys(O: object, P: string | symbol | undefined): any[];
}