mirror of
https://github.com/denoland/deno.git
synced 2024-11-29 16:30:56 -05:00
bf9930066d
This PR is intentionally ugly. It duplicates all of the code in cli/js2/ into cli/tsc/ ... because it's very important that we all understand that this code is unnecessarily duplicated in our binary. I hope this ugliness provides the motivation to clean it up. The typescript git submodule is removed, because it's a very large repo and contains all sorts of stuff we don't need. Instead the necessary files are copied directly into the deno repo. Hence +200k lines. COMPILER_SNAPSHOT.bin size ``` master 3448139 this branch 3320972 ``` Fixes #6812
89 lines
2.8 KiB
TypeScript
89 lines
2.8 KiB
TypeScript
/*! *****************************************************************************
|
|
Copyright (c) Microsoft Corporation. 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.
|
|
***************************************************************************** */
|
|
|
|
|
|
|
|
/// <reference no-default-lib="true"/>
|
|
|
|
|
|
interface Map<K, V> {
|
|
clear(): void;
|
|
delete(key: K): boolean;
|
|
forEach(callbackfn: (value: V, key: K, map: Map<K, V>) => void, thisArg?: any): void;
|
|
get(key: K): V | undefined;
|
|
has(key: K): boolean;
|
|
set(key: K, value: V): this;
|
|
readonly size: number;
|
|
}
|
|
|
|
interface MapConstructor {
|
|
new(): Map<any, any>;
|
|
new<K, V>(entries?: readonly (readonly [K, V])[] | null): Map<K, V>;
|
|
readonly prototype: Map<any, any>;
|
|
}
|
|
declare var Map: MapConstructor;
|
|
|
|
interface ReadonlyMap<K, V> {
|
|
forEach(callbackfn: (value: V, key: K, map: ReadonlyMap<K, V>) => void, thisArg?: any): void;
|
|
get(key: K): V | undefined;
|
|
has(key: K): boolean;
|
|
readonly size: number;
|
|
}
|
|
|
|
interface WeakMap<K extends object, V> {
|
|
delete(key: K): boolean;
|
|
get(key: K): V | undefined;
|
|
has(key: K): boolean;
|
|
set(key: K, value: V): this;
|
|
}
|
|
|
|
interface WeakMapConstructor {
|
|
new <K extends object = object, V = any>(entries?: readonly [K, V][] | null): WeakMap<K, V>;
|
|
readonly prototype: WeakMap<object, any>;
|
|
}
|
|
declare var WeakMap: WeakMapConstructor;
|
|
|
|
interface Set<T> {
|
|
add(value: T): this;
|
|
clear(): void;
|
|
delete(value: T): boolean;
|
|
forEach(callbackfn: (value: T, value2: T, set: Set<T>) => void, thisArg?: any): void;
|
|
has(value: T): boolean;
|
|
readonly size: number;
|
|
}
|
|
|
|
interface SetConstructor {
|
|
new <T = any>(values?: readonly T[] | null): Set<T>;
|
|
readonly prototype: Set<any>;
|
|
}
|
|
declare var Set: SetConstructor;
|
|
|
|
interface ReadonlySet<T> {
|
|
forEach(callbackfn: (value: T, value2: T, set: ReadonlySet<T>) => void, thisArg?: any): void;
|
|
has(value: T): boolean;
|
|
readonly size: number;
|
|
}
|
|
|
|
interface WeakSet<T extends object> {
|
|
add(value: T): this;
|
|
delete(value: T): boolean;
|
|
has(value: T): boolean;
|
|
}
|
|
|
|
interface WeakSetConstructor {
|
|
new <T extends object = object>(values?: readonly T[] | null): WeakSet<T>;
|
|
readonly prototype: WeakSet<object>;
|
|
}
|
|
declare var WeakSet: WeakSetConstructor;
|