diff options
author | Kitson Kelly <me@kitsonkelly.com> | 2020-04-12 01:42:02 +1000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-04-11 11:42:02 -0400 |
commit | fc4819e1e0624b9377913932202bc31f5a25bab4 (patch) | |
tree | 98604a5ce1ff29c1a900c0c37b7307072a48fa6a /cli/js/web/util.ts | |
parent | 2b362bef8523f3d8c05ce5d3d4b4a839b669568d (diff) |
refactor: Event and EventTarget implementations (#4707)
Refactors Event and EventTarget so that they better encapsulate their
non-public data as well as are more forward compatible with things like
DOM Nodes.
Moves `dom_types.ts` -> `dom_types.d.ts` which was always the intention,
it was a legacy of when we used to build the types from the code and the
limitations of the compiler. There was a lot of cruft in `dom_types`
which shouldn't have been there, and mis-alignment to the DOM standards.
This generally has been eliminated, though we still have some minor
differences from the DOM (like the removal of some deprecated
methods/properties).
Adds `DOMException`. Strictly it shouldn't inherit from `Error`, but
most browsers provide a stack trace when one is thrown, so the behaviour
in Deno actually better matches the browser.
`Event` still doesn't log to console like it does in the browser. I
wanted to get this raised and that could be an enhancement later on (it
currently doesn't either).
Diffstat (limited to 'cli/js/web/util.ts')
-rw-r--r-- | cli/js/web/util.ts | 32 |
1 files changed, 19 insertions, 13 deletions
diff --git a/cli/js/web/util.ts b/cli/js/web/util.ts index 2d63b4d60..32e73c443 100644 --- a/cli/js/web/util.ts +++ b/cli/js/web/util.ts @@ -11,6 +11,7 @@ export type TypedArray = | Float32Array | Float64Array; +// @internal export function isTypedArray(x: unknown): x is TypedArray { return ( x instanceof Int8Array || @@ -54,19 +55,8 @@ export function immutableDefine( }); } -// Returns values from a WeakMap to emulate private properties in JavaScript -export function getPrivateValue< - K extends object, - V extends object, - W extends keyof V ->(instance: K, weakMap: WeakMap<K, V>, key: W): V[W] { - if (weakMap.has(instance)) { - return weakMap.get(instance)![key]; - } - throw new TypeError("Illegal invocation"); -} - -export function hasOwnProperty<T>(obj: T, v: PropertyKey): boolean { +// @internal +export function hasOwnProperty(obj: unknown, v: PropertyKey): boolean { if (obj == null) { return false; } @@ -87,3 +77,19 @@ export function isIterable<T, P extends keyof T, K extends T[P]>( typeof ((o as unknown) as Iterable<[P, K]>)[Symbol.iterator] === "function" ); } + +// eslint-disable-next-line @typescript-eslint/no-explicit-any +interface GenericConstructor<T = any> { + prototype: T; +} + +/** A helper function which ensures accessors are enumerable, as they normally + * are not. */ +export function defineEnumerableProps( + Ctor: GenericConstructor, + props: string[] +): void { + for (const prop of props) { + Reflect.defineProperty(Ctor.prototype, prop, { enumerable: true }); + } +} |