From 4b7bd01158da063170b243ba89d9198003742a39 Mon Sep 17 00:00:00 2001 From: Dan Korostelev Date: Wed, 5 Sep 2018 20:43:38 +0200 Subject: [PATCH 1/5] [js] move standard library types to js.lib --- src/filters/jsExceptions.ml | 4 +-- std/haxe/CallStack.hx | 6 ++-- std/js/Boot.hx | 10 +++--- std/js/Error.hx | 52 ++++------------------------ std/js/Function.hx | 29 +--------------- std/js/JsIterator.hx | 12 ++----- std/js/Map.hx | 22 +----------- std/js/Object.hx | 46 ++----------------------- std/js/Promise.hx | 32 ++--------------- std/js/RegExp.hx | 25 ++------------ std/js/Set.hx | 16 +-------- std/js/Symbol.hx | 39 +-------------------- std/js/_std/EReg.hx | 6 ++-- std/js/_std/Reflect.hx | 6 ++-- std/js/_std/Type.hx | 2 +- std/js/lib/Date.hx | 24 +++++++++++++ std/js/lib/Error.hx | 68 +++++++++++++++++++++++++++++++++++++ std/js/lib/Function.hx | 51 ++++++++++++++++++++++++++++ std/js/lib/Iterator.hx | 10 ++++++ std/js/lib/Map.hx | 46 +++++++++++++++++++++++++ std/js/lib/Object.hx | 66 +++++++++++++++++++++++++++++++++++ std/js/lib/Promise.hx | 53 +++++++++++++++++++++++++++++ std/js/lib/RegExp.hx | 46 +++++++++++++++++++++++++ std/js/lib/Set.hx | 39 +++++++++++++++++++++ std/js/lib/Symbol.hx | 61 +++++++++++++++++++++++++++++++++ 25 files changed, 502 insertions(+), 269 deletions(-) create mode 100644 std/js/lib/Date.hx create mode 100644 std/js/lib/Error.hx create mode 100644 std/js/lib/Function.hx create mode 100644 std/js/lib/Iterator.hx create mode 100644 std/js/lib/Map.hx create mode 100644 std/js/lib/Object.hx create mode 100644 std/js/lib/Promise.hx create mode 100644 std/js/lib/RegExp.hx create mode 100644 std/js/lib/Set.hx create mode 100644 std/js/lib/Symbol.hx diff --git a/src/filters/jsExceptions.ml b/src/filters/jsExceptions.ml index 54a7c874e5e..c805c4b5122 100644 --- a/src/filters/jsExceptions.ml +++ b/src/filters/jsExceptions.ml @@ -58,7 +58,7 @@ let follow = Abstract.follow_with_abstracts let rec is_js_error c = match c with - | { cl_path = ["js"],"Error" } -> true + | { cl_path = ["js";"lib"],"Error" } -> true | { cl_super = Some (csup,_) } -> is_js_error csup | _ -> false @@ -69,7 +69,7 @@ let find_cl com path = ) com.types let init ctx = - let cJsError = find_cl ctx.com (["js"],"Error") in + let cJsError = find_cl ctx.com (["js";"lib"],"Error") in let cHaxeError = find_cl ctx.com (["js";"_Boot"],"HaxeError") in let cStd = find_cl ctx.com ([],"Std") in let cBoot = find_cl ctx.com (["js"],"Boot") in diff --git a/std/haxe/CallStack.hx b/std/haxe/CallStack.hx index 21e8f29aa32..62aa00e1bf8 100644 --- a/std/haxe/CallStack.hx +++ b/std/haxe/CallStack.hx @@ -37,9 +37,9 @@ enum StackItem { **/ class CallStack { #if js - static var lastException:js.Error; + static var lastException:js.lib.Error; - static function getStack(e:js.Error):Array { + static function getStack(e:js.lib.Error):Array { if (e == null) return []; // https://code.google.com/p/v8/wiki/JavaScriptStackTraceApi var oldValue = (untyped Error).prepareStackTrace; @@ -97,7 +97,7 @@ class CallStack { return makeStack(s); #elseif js try { - throw new js.Error(); + throw new js.lib.Error(); } catch( e : Dynamic ) { var a = getStack(js.Lib.getOriginalException()); a.shift(); // remove Stack.callStack() diff --git a/std/js/Boot.hx b/std/js/Boot.hx index cdd9cab88de..1114cb82776 100644 --- a/std/js/Boot.hx +++ b/std/js/Boot.hx @@ -23,22 +23,22 @@ package js; import js.Syntax; // import it here so it's always available in the compiler -private class HaxeError extends js.Error { +private class HaxeError extends js.lib.Error { var val:Dynamic; @:pure public function new(val:Dynamic) { super(); this.val = val; - if ((cast js.Error).captureStackTrace) (cast js.Error).captureStackTrace(this, HaxeError); + if ((cast js.lib.Error).captureStackTrace) (cast js.lib.Error).captureStackTrace(this, HaxeError); } - public static function wrap(val:Dynamic):js.Error { - return if (js.Syntax.instanceof(val, js.Error)) val else new HaxeError(val); + public static function wrap(val:Dynamic):js.lib.Error { + return if (js.Syntax.instanceof(val, js.lib.Error)) val else new HaxeError(val); } static function __init__() { - js.Object.defineProperty((cast HaxeError).prototype, "message", {get: () -> (cast String)(js.Lib.nativeThis.val)}); + js.lib.Object.defineProperty((cast HaxeError).prototype, "message", {get: () -> (cast String)(js.Lib.nativeThis.val)}); } } diff --git a/std/js/Error.hx b/std/js/Error.hx index 70087d9dd1c..fe183f2a6bf 100644 --- a/std/js/Error.hx +++ b/std/js/Error.hx @@ -21,48 +21,10 @@ */ package js; -@:native("Error") -extern class Error -{ - var message : String; - var name : String; - var stack(default,null) : String; - - function new(?message : String) : Void; -} - -@:native("EvalError") -extern class EvalError extends Error -{ - function new(?message : String) : Void; -} - -@:native("RangeError") -extern class RangeError extends Error -{ - function new(?message : String) : Void; -} - -@:native("ReferenceError") -extern class ReferenceError extends Error -{ - function new(?message : String) : Void; -} - -@:native("SyntaxError") -extern class SyntaxError extends Error -{ - function new(?message : String) : Void; -} - -@:native("TypeError") -extern class TypeError extends Error -{ - function new(?message : String) : Void; -} - -@:native("URIError") -extern class URIError extends Error -{ - function new(?message : String) : Void; -} +@:deprecated typedef Error = js.lib.Error; +@:deprecated typedef EvalError = js.lib.Error.EvalError; +@:deprecated typedef RangeError = js.lib.Error.RangeError; +@:deprecated typedef ReferenceError = js.lib.Error.ReferenceError; +@:deprecated typedef SyntaxError = js.lib.Error.SyntaxError; +@:deprecated typedef TypeError = js.lib.Error.TypeError; +@:deprecated typedef URIError = js.lib.Error.URIError; diff --git a/std/js/Function.hx b/std/js/Function.hx index 41d672521c7..9d5d768f3ac 100644 --- a/std/js/Function.hx +++ b/std/js/Function.hx @@ -21,31 +21,4 @@ */ package js; -import haxe.extern.Rest; - -@:native("Function") -extern class Function { - /** Specifies the number of arguments expected by the function. **/ - var length(default,never):Int; - - /** The name of the function. **/ - var name:String; - - /** Creates a new Function object. **/ - function new(arg:String, rest:Rest); - - /** Calls a function and sets its this to the provided value, arguments can be passed as an Array object. **/ - function apply(thisArg:Dynamic, argsArray:Array):Dynamic; - - /** Calls (executes) a function and sets its this to the provided value, arguments can be passed as they are. **/ - function call(thisArg:Dynamic, args:Rest):Dynamic; - - /** - Creates a new function which, when called, has its this set to the provided value, - with a given sequence of arguments preceding any provided when the new function was called. - **/ - @:pure function bind(thisArg:Dynamic, args:Rest):Function; - - /** Returns a string representing the source code of the function. **/ - @:pure function toString():String; -} +@:deprecated typedef Function = js.lib.Function; diff --git a/std/js/JsIterator.hx b/std/js/JsIterator.hx index 34239dd86a4..8c7b0e4a97e 100644 --- a/std/js/JsIterator.hx +++ b/std/js/JsIterator.hx @@ -1,12 +1,4 @@ package js; -// prefixed with Js to avoid name clashes with standard Iterator structure - -typedef JsIterator = { - function next():JsIteratorStep; -} - -typedef JsIteratorStep = { - done:Bool, - ?value:T -} +@:deprecated typedef JsIterator = js.lib.Iterator; +@:deprecated typedef JsIteratorStep = js.lib.Iterator.JsIteratorStep; diff --git a/std/js/Map.hx b/std/js/Map.hx index 053bf8916b5..8c3b58fda20 100644 --- a/std/js/Map.hx +++ b/std/js/Map.hx @@ -21,24 +21,4 @@ */ package js; -@:native("Map") -extern class Map { - var size(default,null):Int; - @:pure function new(?iterable:Any); - @:pure function has(key:K):Bool; - @:pure function get(key:K):Null; - function set(key:K, value:V):Map; - function delete(key:K):Bool; - function clear():Void; - function forEach(callback:(value:V, key:K, map:Map)->Void, ?thisArg:Any):Void; - function keys():JsIterator; - function values():JsIterator; - function entries():JsIterator>; -} - -abstract MapEntry(Array) { - public var key(get,never):K; - public var value(get,never):V; - inline function get_key():K return this[0]; - inline function get_value():V return this[1]; -} +@:deprecated typedef Map = js.lib.Map; diff --git a/std/js/Object.hx b/std/js/Object.hx index 9dae81bdf42..51e90ae0696 100644 --- a/std/js/Object.hx +++ b/std/js/Object.hx @@ -21,46 +21,6 @@ */ package js; -import haxe.extern.Rest; -import haxe.DynamicAccess; - -@:native("Object") -extern class Object { - static function assign(target:T, sources:Rest<{}>):T; - @:pure static function create(proto:{}, ?propertiesObject:DynamicAccess):T; - static function defineProperties(obj:T, props:DynamicAccess):T; - static function defineProperty(obj:T, prop:String, descriptor:ObjectPropertyDescriptor):T; - static function freeze(obj:T):T; - @:pure static function getOwnPropertyDescriptor(obj:{}, prop:String):Null; - @:pure static function getOwnPropertyNames(obj:{}):Array; - @:pure static function getOwnPropertySymbols(obj:{}):Array; - @:pure static function getPrototypeOf(obj:{}):Null; - @:pure static function is(value1:T, value2:T):Bool; - @:pure static function isExtensible(obj:{}):Bool; - @:pure static function isFrozen(obj:{}):Bool; - @:pure static function isSealed(obj:{}):Bool; - @:pure static function keys(obj:{}):Array; - static function preventExtensions(obj:T):T; - static function seal(obj:T):T; - static function setPrototypeOf(obj:T, prototype:Null<{}>):T; - static var prototype(default,never):ObjectPrototype; - @:pure function new(?value:Any); -} - -typedef ObjectPrototype = { - var hasOwnProperty(default,never):Function; - var isPrototypeOf(default,never):Function; - var propertyIsEnumerable(default,never):Function; - var toLocaleString(default,never):Function; - var toString(default,never):Function; - var valueOf(default,never):Function; -} - -typedef ObjectPropertyDescriptor = { - @:optional var configurable:Bool; - @:optional var enumerable:Bool; - @:optional var value:Any; - @:optional var writable:Bool; - @:optional var get:Void->Any; - @:optional var set:Any->Void; -} +@:deprecated typedef Object = js.lib.Object; +@:deprecated typedef ObjectPrototype = js.lib.Object.ObjectPrototype; +@:deprecated typedef ObjectPropertyDescriptor = js.lib.Object.ObjectPropertyDescriptor; diff --git a/std/js/Promise.hx b/std/js/Promise.hx index 18c73c3938c..b3d600e96af 100644 --- a/std/js/Promise.hx +++ b/std/js/Promise.hx @@ -22,32 +22,6 @@ package js; -import haxe.extern.EitherType; - -@:native("Promise") -extern class Promise -{ - @:overload(function(promise : Promise) : Promise {}) - @:overload(function(thenable : Thenable) : Promise {}) - static function resolve( ?value : T ) : Promise; - - static function reject( ?reason : Dynamic ) : Promise; - - static function all( iterable : Array ) : Promise>; - - static function race( iterable : Array ) : Promise; - - /** @throws DOMError */ - function new( init : (resolve : (value : T) -> Void, reject: (reason : Dynamic) -> Void) -> Void ) : Void; - - function then( fulfillCallback : Null>, ?rejectCallback : EitherType Void, PromiseCallback> ) : Promise; - - @:native("catch") - function catchError( rejectCallback : EitherType Void, PromiseCallback> ) : Promise; -} - -typedef PromiseCallback = EitherType TOut, T -> Promise>; - -typedef Thenable = { - function then(resolve:T->Void, ?reject:Dynamic->Void):Void; -} +@:deprecated typedef Promise = js.lib.Promise; +@:deprecated typedef PromiseCallback = js.lib.Promise.PromiseCallback; +@:deprecated typedef Thenable = js.lib.Promise.Thenable; diff --git a/std/js/RegExp.hx b/std/js/RegExp.hx index 8f86fd08fcb..1d8e24c9f1c 100644 --- a/std/js/RegExp.hx +++ b/std/js/RegExp.hx @@ -21,26 +21,5 @@ */ package js; -/** - Native JavaScript regular expressions. - - For cross-platform regular expressions, use Haxe `EReg` class or - [regexp literals](https://haxe.org/manual/std-regex.html). -**/ -@:native("RegExp") -extern class RegExp { - var global(default,null):Bool; - var ignoreCase(default,null):Bool; - var multiline(default,null):Bool; - var source(default,null):String; - var lastIndex:Int; - function new(pattern:String, ?flags:String); - function exec(str:String):Null; - function test(str:String):Bool; - function toString():String; -} - -extern class RegExpMatch extends Array { - var index:Int; - var input:String; -} +@:deprecated typedef RegExp = js.lib.RegExp; +@:deprecated typedef RegExpMatch = js.lib.RegExp.RegExpMatch; diff --git a/std/js/Set.hx b/std/js/Set.hx index 0dc6d01b088..c00dad4e528 100644 --- a/std/js/Set.hx +++ b/std/js/Set.hx @@ -21,18 +21,4 @@ */ package js; -import js.Map.MapEntry; - -@:native("Set") -extern class Set { - var size(default,null):Int; - @:pure function new(?iterable:Any); - @:pure function has(value:T):Bool; - function add(value:T):Set; - function delete(value:T):Bool; - function clear():Void; - function forEach(callback:(value:T, key:T, set:Set)->Void, ?thisArg:Any):Void; - function keys():JsIterator; - function values():JsIterator; - function entries():JsIterator>; -} +@:deprecated typedef Set = js.lib.Set; \ No newline at end of file diff --git a/std/js/Symbol.hx b/std/js/Symbol.hx index 8159f9d5bbf..6f8d09fb355 100644 --- a/std/js/Symbol.hx +++ b/std/js/Symbol.hx @@ -21,41 +21,4 @@ */ package js; -@:native("Symbol") -extern class Symbol { - /** - To create a new primitive symbol, you write `new Symbol()` with an optional string as its `description`. - - NOTE: Unlike plain JavaScript, in Haxe `new Symbol()` syntax is used, however `Symbol(...)` expression - will be generated as required by JavaScript specification. - **/ - @:pure @:selfCall function new(?description:String); - - /** - Searches for existing symbols with the given key and returns it if found. - Otherwise a new symbol gets created in the global symbol registry with this key. - **/ - @:native("for") static function for_(key:String):Symbol; - - /** - Retrieves a shared symbol key from the global symbol registry for the given symbol. - **/ - @:pure static function keyFor(sym:Symbol):Null; - - /** - Returns a string containing the description of the Symbol. - **/ - @:pure function toString():String; - - /** - A method returning the default iterator for an object. - **/ - static var iterator(default,null):Symbol; - - /** - Retrieve symbol from a given `object`. - - NOTE: This is a Haxe-specific method that generates `object[symbol]` expression. - **/ - inline function ofObject(object:{}):Null return (cast object)[cast this]; -} +@:deprecated typedef Symbol = js.lib.Symbol; \ No newline at end of file diff --git a/std/js/_std/EReg.hx b/std/js/_std/EReg.hx index 69e3140a943..abd8bf54bc3 100644 --- a/std/js/_std/EReg.hx +++ b/std/js/_std/EReg.hx @@ -112,11 +112,11 @@ public static inline function escape( s : String ) : String { return (cast s).replace(escapeRe, "\\$&"); } - static var escapeRe = new js.RegExp("[.*+?^${}()|[\\]\\\\]", "g"); + static var escapeRe = new js.lib.RegExp("[.*+?^${}()|[\\]\\\\]", "g"); } @:native("RegExp") -private extern class HaxeRegExp extends js.RegExp { - var m:js.RegExp.RegExpMatch; +private extern class HaxeRegExp extends js.lib.RegExp { + var m:js.lib.RegExp.RegExpMatch; var s:String; } diff --git a/std/js/_std/Reflect.hx b/std/js/_std/Reflect.hx index b1e9ec3fe36..91eb0cb1073 100644 --- a/std/js/_std/Reflect.hx +++ b/std/js/_std/Reflect.hx @@ -23,7 +23,7 @@ @:pure public inline static function hasField( o : Dynamic, field : String ) : Bool { - return js.Object.prototype.hasOwnProperty.call(o, field); + return js.lib.Object.prototype.hasOwnProperty.call(o, field); } @:pure @@ -46,13 +46,13 @@ } public inline static function callMethod( o : Dynamic, func : haxe.Constraints.Function, args : Array ) : Dynamic { - return (cast func : js.Function).apply(o,args); + return (cast func : js.lib.Function).apply(o,args); } public static function fields( o : Dynamic ) : Array { var a = []; if (o != null) untyped { - var hasOwnProperty = js.Object.prototype.hasOwnProperty; + var hasOwnProperty = js.lib.Object.prototype.hasOwnProperty; __js__("for( var f in o ) {"); if( f != "__id__" && f != "hx__closures__" && hasOwnProperty.call(o, f) ) a.push(f); __js__("}"); diff --git a/std/js/_std/Type.hx b/std/js/_std/Type.hx index 24278e93f10..4e2e22eeaba 100644 --- a/std/js/_std/Type.hx +++ b/std/js/_std/Type.hx @@ -135,7 +135,7 @@ enum ValueType { } public static inline function createEmptyInstance( cl : Class ) : T { - return js.Object.create((cast cl).prototype); + return js.lib.Object.create((cast cl).prototype); } #end diff --git a/std/js/lib/Date.hx b/std/js/lib/Date.hx new file mode 100644 index 00000000000..35c6f056aa8 --- /dev/null +++ b/std/js/lib/Date.hx @@ -0,0 +1,24 @@ +/* + * Copyright (C)2005-2018 Haxe Foundation + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER + * DEALINGS IN THE SOFTWARE. + */ +package js; + +@:deprecated typedef Date = js.lib.Date; diff --git a/std/js/lib/Error.hx b/std/js/lib/Error.hx new file mode 100644 index 00000000000..7fbfd4c3439 --- /dev/null +++ b/std/js/lib/Error.hx @@ -0,0 +1,68 @@ +/* + * Copyright (C)2005-2018 Haxe Foundation + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER + * DEALINGS IN THE SOFTWARE. + */ +package js.lib; + +@:native("Error") +extern class Error +{ + var message : String; + var name : String; + var stack(default,null) : String; + + function new(?message : String) : Void; +} + +@:native("EvalError") +extern class EvalError extends Error +{ + function new(?message : String) : Void; +} + +@:native("RangeError") +extern class RangeError extends Error +{ + function new(?message : String) : Void; +} + +@:native("ReferenceError") +extern class ReferenceError extends Error +{ + function new(?message : String) : Void; +} + +@:native("SyntaxError") +extern class SyntaxError extends Error +{ + function new(?message : String) : Void; +} + +@:native("TypeError") +extern class TypeError extends Error +{ + function new(?message : String) : Void; +} + +@:native("URIError") +extern class URIError extends Error +{ + function new(?message : String) : Void; +} diff --git a/std/js/lib/Function.hx b/std/js/lib/Function.hx new file mode 100644 index 00000000000..62924e0aebc --- /dev/null +++ b/std/js/lib/Function.hx @@ -0,0 +1,51 @@ +/* + * Copyright (C)2005-2018 Haxe Foundation + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER + * DEALINGS IN THE SOFTWARE. + */ +package js.lib; + +import haxe.extern.Rest; + +@:native("Function") +extern class Function { + /** Specifies the number of arguments expected by the function. **/ + var length(default,never):Int; + + /** The name of the function. **/ + var name:String; + + /** Creates a new Function object. **/ + function new(arg:String, rest:Rest); + + /** Calls a function and sets its this to the provided value, arguments can be passed as an Array object. **/ + function apply(thisArg:Dynamic, argsArray:Array):Dynamic; + + /** Calls (executes) a function and sets its this to the provided value, arguments can be passed as they are. **/ + function call(thisArg:Dynamic, args:Rest):Dynamic; + + /** + Creates a new function which, when called, has its this set to the provided value, + with a given sequence of arguments preceding any provided when the new function was called. + **/ + @:pure function bind(thisArg:Dynamic, args:Rest):Function; + + /** Returns a string representing the source code of the function. **/ + @:pure function toString():String; +} diff --git a/std/js/lib/Iterator.hx b/std/js/lib/Iterator.hx new file mode 100644 index 00000000000..c361acd4fbf --- /dev/null +++ b/std/js/lib/Iterator.hx @@ -0,0 +1,10 @@ +package js.lib; + +typedef Iterator = { + function next():IteratorStep; +} + +typedef IteratorStep = { + done:Bool, + ?value:T +} diff --git a/std/js/lib/Map.hx b/std/js/lib/Map.hx new file mode 100644 index 00000000000..6662b3b1d38 --- /dev/null +++ b/std/js/lib/Map.hx @@ -0,0 +1,46 @@ +/* + * Copyright (C)2005-2018 Haxe Foundation + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER + * DEALINGS IN THE SOFTWARE. + */ +package js.lib; + +import js.lib.Iterator; + +@:native("Map") +extern class Map { + var size(default,null):Int; + @:pure function new(?iterable:Any); + @:pure function has(key:K):Bool; + @:pure function get(key:K):Null; + function set(key:K, value:V):Map; + function delete(key:K):Bool; + function clear():Void; + function forEach(callback:(value:V, key:K, map:Map)->Void, ?thisArg:Any):Void; + function keys():Iterator; + function values():Iterator; + function entries():Iterator>; +} + +abstract MapEntry(Array) { + public var key(get,never):K; + public var value(get,never):V; + inline function get_key():K return this[0]; + inline function get_value():V return this[1]; +} diff --git a/std/js/lib/Object.hx b/std/js/lib/Object.hx new file mode 100644 index 00000000000..4f81a4f4173 --- /dev/null +++ b/std/js/lib/Object.hx @@ -0,0 +1,66 @@ +/* + * Copyright (C)2005-2018 Haxe Foundation + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER + * DEALINGS IN THE SOFTWARE. + */ +package js.lib; + +import haxe.extern.Rest; +import haxe.DynamicAccess; + +@:native("Object") +extern class Object { + static function assign(target:T, sources:Rest<{}>):T; + @:pure static function create(proto:{}, ?propertiesObject:DynamicAccess):T; + static function defineProperties(obj:T, props:DynamicAccess):T; + static function defineProperty(obj:T, prop:String, descriptor:ObjectPropertyDescriptor):T; + static function freeze(obj:T):T; + @:pure static function getOwnPropertyDescriptor(obj:{}, prop:String):Null; + @:pure static function getOwnPropertyNames(obj:{}):Array; + @:pure static function getOwnPropertySymbols(obj:{}):Array; + @:pure static function getPrototypeOf(obj:{}):Null; + @:pure static function is(value1:T, value2:T):Bool; + @:pure static function isExtensible(obj:{}):Bool; + @:pure static function isFrozen(obj:{}):Bool; + @:pure static function isSealed(obj:{}):Bool; + @:pure static function keys(obj:{}):Array; + static function preventExtensions(obj:T):T; + static function seal(obj:T):T; + static function setPrototypeOf(obj:T, prototype:Null<{}>):T; + static var prototype(default,never):ObjectPrototype; + @:pure function new(?value:Any); +} + +typedef ObjectPrototype = { + var hasOwnProperty(default,never):Function; + var isPrototypeOf(default,never):Function; + var propertyIsEnumerable(default,never):Function; + var toLocaleString(default,never):Function; + var toString(default,never):Function; + var valueOf(default,never):Function; +} + +typedef ObjectPropertyDescriptor = { + @:optional var configurable:Bool; + @:optional var enumerable:Bool; + @:optional var value:Any; + @:optional var writable:Bool; + @:optional var get:Void->Any; + @:optional var set:Any->Void; +} diff --git a/std/js/lib/Promise.hx b/std/js/lib/Promise.hx new file mode 100644 index 00000000000..4dd0f8d7fc4 --- /dev/null +++ b/std/js/lib/Promise.hx @@ -0,0 +1,53 @@ +/* + * Copyright (C)2005-2018 Haxe Foundation + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER + * DEALINGS IN THE SOFTWARE. + */ + +package js.lib; + +import haxe.extern.EitherType; + +@:native("Promise") +extern class Promise +{ + @:overload(function(promise : Promise) : Promise {}) + @:overload(function(thenable : Thenable) : Promise {}) + static function resolve( ?value : T ) : Promise; + + static function reject( ?reason : Dynamic ) : Promise; + + static function all( iterable : Array ) : Promise>; + + static function race( iterable : Array ) : Promise; + + /** @throws DOMError */ + function new( init : (resolve : (value : T) -> Void, reject: (reason : Dynamic) -> Void) -> Void ) : Void; + + function then( fulfillCallback : Null>, ?rejectCallback : EitherType Void, PromiseCallback> ) : Promise; + + @:native("catch") + function catchError( rejectCallback : EitherType Void, PromiseCallback> ) : Promise; +} + +typedef PromiseCallback = EitherType TOut, T -> Promise>; + +typedef Thenable = { + function then(resolve:T->Void, ?reject:Dynamic->Void):Void; +} diff --git a/std/js/lib/RegExp.hx b/std/js/lib/RegExp.hx new file mode 100644 index 00000000000..10010258daf --- /dev/null +++ b/std/js/lib/RegExp.hx @@ -0,0 +1,46 @@ +/* + * Copyright (C)2005-2018 Haxe Foundation + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER + * DEALINGS IN THE SOFTWARE. + */ + package js.lib; + +/** + Native JavaScript regular expressions. + + For cross-platform regular expressions, use Haxe `EReg` class or + [regexp literals](https://haxe.org/manual/std-regex.html). +**/ +@:native("RegExp") +extern class RegExp { + var global(default,null):Bool; + var ignoreCase(default,null):Bool; + var multiline(default,null):Bool; + var source(default,null):String; + var lastIndex:Int; + function new(pattern:String, ?flags:String); + function exec(str:String):Null; + function test(str:String):Bool; + function toString():String; +} + +extern class RegExpMatch extends Array { + var index:Int; + var input:String; +} diff --git a/std/js/lib/Set.hx b/std/js/lib/Set.hx new file mode 100644 index 00000000000..5bc066a945f --- /dev/null +++ b/std/js/lib/Set.hx @@ -0,0 +1,39 @@ +/* + * Copyright (C)2005-2018 Haxe Foundation + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER + * DEALINGS IN THE SOFTWARE. + */ +package js.lib; + +import js.lib.Map.MapEntry; +import js.lib.Iterator; + +@:native("Set") +extern class Set { + var size(default,null):Int; + @:pure function new(?iterable:Any); + @:pure function has(value:T):Bool; + function add(value:T):Set; + function delete(value:T):Bool; + function clear():Void; + function forEach(callback:(value:T, key:T, set:Set)->Void, ?thisArg:Any):Void; + function keys():Iterator; + function values():Iterator; + function entries():Iterator>; +} diff --git a/std/js/lib/Symbol.hx b/std/js/lib/Symbol.hx new file mode 100644 index 00000000000..75a84de97c1 --- /dev/null +++ b/std/js/lib/Symbol.hx @@ -0,0 +1,61 @@ +/* + * Copyright (C)2005-2018 Haxe Foundation + * + * Permission is hereby granted, free of charge, to any person obtaining a + * copy of this software and associated documentation files (the "Software"), + * to deal in the Software without restriction, including without limitation + * the rights to use, copy, modify, merge, publish, distribute, sublicense, + * and/or sell copies of the Software, and to permit persons to whom the + * Software is furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING + * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER + * DEALINGS IN THE SOFTWARE. + */ +package js.lib; + +@:native("Symbol") +extern class Symbol { + /** + To create a new primitive symbol, you write `new Symbol()` with an optional string as its `description`. + + NOTE: Unlike plain JavaScript, in Haxe `new Symbol()` syntax is used, however `Symbol(...)` expression + will be generated as required by JavaScript specification. + **/ + @:pure @:selfCall function new(?description:String); + + /** + Searches for existing symbols with the given key and returns it if found. + Otherwise a new symbol gets created in the global symbol registry with this key. + **/ + @:native("for") static function for_(key:String):Symbol; + + /** + Retrieves a shared symbol key from the global symbol registry for the given symbol. + **/ + @:pure static function keyFor(sym:Symbol):Null; + + /** + Returns a string containing the description of the Symbol. + **/ + @:pure function toString():String; + + /** + A method returning the default iterator for an object. + **/ + static var iterator(default,null):Symbol; + + /** + Retrieve symbol from a given `object`. + + NOTE: This is a Haxe-specific method that generates `object[symbol]` expression. + **/ + inline function ofObject(object:{}):Null return (cast object)[cast this]; +} From 8faf783ebaf77281065ecff12e71b5e970c1693f Mon Sep 17 00:00:00 2001 From: Alexander Kuzmenko Date: Tue, 16 Apr 2019 13:08:31 +0300 Subject: [PATCH 2/5] fixed `js.lib.Date` --- std/js/Date.hx | 263 +------------------------------------------- std/js/lib/Date.hx | 265 ++++++++++++++++++++++++++++++++++++++++++++- 2 files changed, 264 insertions(+), 264 deletions(-) diff --git a/std/js/Date.hx b/std/js/Date.hx index 8a4b2ed5089..1a24b7ce9af 100644 --- a/std/js/Date.hx +++ b/std/js/Date.hx @@ -21,265 +21,4 @@ */ package js; -import Date in HaxeDate; - -/** - Creates a JavaScript Date instance that represents a single moment in time. Date objects are based on a time value that is the number of milliseconds since 1 January 1970 UTC. -**/ -@:native("Date") -extern class Date -{ - @:overload(function(value:Float):Void {}) - @:overload(function(dateString:String):Void {}) - @:overload(function(year:Int, month:Int, ?day:Int, ?hours:Int, ?minutes:Int, ?seconds:Int, ?milliseconds:Int):Void {}) - function new() : Void; - - /** - Cast Haxe's Date to js.Date. - **/ - static public inline function fromHaxeDate(date:HaxeDate):js.Date { - return cast date; - } - - /** - Cast js.Date to Haxe's Date. - **/ - static public inline function toHaxeDate(date:Date):HaxeDate { - return cast date; - } - - /** - Returns the numeric value corresponding to the current time - the number of milliseconds elapsed since January 1, 1970 00:00:00 UTC, with leap seconds ignored - **/ - static function now() : Float; - - /** - Parses a string representation of a date and returns the number of milliseconds since 1 January, 1970, 00:00:00, UTC, with leap seconds ignored. - **/ - static function parse( str:String ) : Float; - - /** - Returns the number of milliseconds since January 1, 1970, 00:00:00 UTC, with leap seconds ignored. - **/ - static function UTC( year:Int, month:Int, ?day:Int, ?hours:Int, ?minutes:Int, ?seconds:Int, ?milliseconds:Int ) : Float; - - /** - Returns the day of the month (1-31) for the specified date according to local time. - **/ - function getDate() : Int; - - /** - Returns the day of the week (0-6) for the specified date according to local time. - **/ - function getDay() : Int; - - /** - Returns the year (4 digits for 4-digit years) of the specified date according to local time. - **/ - function getFullYear() : Int; - - /** - Returns the hour (0-23) in the specified date according to local time. - **/ - function getHours() : Int; - - /** - Returns the milliseconds (0-999) in the specified date according to local time. - **/ - function getMilliseconds() : Int; - - /** - Returns the minutes (0-59) in the specified date according to local time. - **/ - function getMinutes() : Int; - - /** - Returns the month (0-11) in the specified date according to local time. - **/ - function getMonth() : Int; - - /** - Returns the seconds (0-59) in the specified date according to local time. - **/ - function getSeconds() : Int; - - /** - Returns the numeric value of the specified date as the number of milliseconds since January 1, 1970, 00:00:00 UTC (negative for prior times). - **/ - function getTime() : Float; - - /** - Returns the time-zone offset in minutes for the current locale. - **/ - function getTimezoneOffset() : Int; - - /** - Returns the day (date) of the month (1-31) in the specified date according to universal time. - **/ - function getUTCDate() : Int; - - /** - Returns the day of the week (0-6) in the specified date according to universal time. - **/ - function getUTCDay() : Int; - - /** - Returns the year (4 digits for 4-digit years) in the specified date according to universal time. - **/ - function getUTCFullYear() : Int; - - /** - Returns the hours (0-23) in the specified date according to universal time. - **/ - function getUTCHours() : Int; - - /** - Returns the milliseconds (0-999) in the specified date according to universal time. - **/ - function getUTCMilliseconds() : Int; - - /** - Returns the minutes (0-59) in the specified date according to universal time. - **/ - function getUTCMinutes() : Int; - - /** - Returns the month (0-11) in the specified date according to universal time. - **/ - function getUTCMonth() : Int; - - /** - Returns the seconds (0-59) in the specified date according to universal time. - **/ - function getUTCSeconds() : Int; - - /** - Sets the day of the month for a specified date according to local time. - **/ - function setDate( value:Int ) : Void; - - /** - Sets the full year (e.g. 4 digits for 4-digit years) for a specified date according to local time. - **/ - function setFullYear( value:Int ) : Void; - - /** - Sets the hours for a specified date according to local time. - **/ - function setHours( value:Int ) : Void; - - /** - Sets the milliseconds for a specified date according to local time. - **/ - function setMilliseconds( value:Int ) : Void; - - /** - Sets the minutes for a specified date according to local time. - **/ - function setMinutes( value:Int ) : Void; - - /** - Sets the month for a specified date according to local time. - **/ - function setMonth( value:Int ) : Void; - - /** - Sets the seconds for a specified date according to local time. - **/ - function setSeconds( value:Int ) : Void; - - /** - Sets the Date object to the time represented by a number of milliseconds since January 1, 1970, 00:00:00 UTC, allowing for negative numbers for times prior. - **/ - function setTime( value:Float ) : Void; - - /** - Sets the day of the month for a specified date according to universal time. - **/ - function setUTCDate( value:Int ) : Void; - - /** - Sets the full year (e.g. 4 digits for 4-digit years) for a specified date according to universal time. - **/ - function setUTCFullYear( value:Int ) : Void; - - /** - Sets the hour for a specified date according to universal time. - **/ - function setUTCHours( value:Int ) : Void; - - /** - Sets the milliseconds for a specified date according to universal time. - **/ - function setUTCMilliseconds( value:Int ) : Void; - - /** - Sets the minutes for a specified date according to universal time. - **/ - function setUTCMinutes( value:Int ) : Void; - - /** - Sets the month for a specified date according to universal time. - **/ - function setUTCMonth( value:Int ) : Void; - - /** - Sets the seconds for a specified date according to universal time. - **/ - function setUTCSeconds( value:Int ) : Void; - - /** - Returns the "date" portion of the Date as a human-readable string. - **/ - function toDateString() : String; - - /** - Converts a date to a string following the ISO 8601 Extended Format. - **/ - function toISOString() : String; - - /** - Returns a string representing the Date using toISOString(). Intended for use by JSON.stringify(). - **/ - function toJSON() : String; - - /** - Returns a string with a locality sensitive representation of the date portion of this date based on system settings. - **/ - function toLocaleDateString( ?locales:String, ?options:Dynamic ) : String; - - /** - Converts a date to a string, using a format string. - **/ - function toLocaleFormat( format:String ) : String; - - /** - Returns a string with a locality sensitive representation of this date. Overrides the Object.prototype.toLocaleString() method. - **/ - function toLocaleString( ?locales:String, ?options:Dynamic ) : String; - - /** - Returns a string with a locality sensitive representation of the time portion of this date based on system settings. - **/ - function toLocaleTimeString( ?locales:String, ?options:Dynamic ) : String; - - /** - Returns a string representing the source for an equivalent Date object; you can use this value to create a new object. Overrides the Object.prototype.toSource() method. - **/ - function toSource() : String; - - /** - Returns a string representing the specified Date object. Overrides the Object.prototype.toString() method. - **/ - function toString() : String; - - /** - Returns the "time" portion of the Date as a human-readable string. - **/ - function toTimeString() : String; - - /** - Converts a date to a string using the UTC timezone. - **/ - function toUTCString() : String; -} \ No newline at end of file +@:deprecated Date = js.lib.Date; \ No newline at end of file diff --git a/std/js/lib/Date.hx b/std/js/lib/Date.hx index 35c6f056aa8..f6aaccf752c 100644 --- a/std/js/lib/Date.hx +++ b/std/js/lib/Date.hx @@ -19,6 +19,267 @@ * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER * DEALINGS IN THE SOFTWARE. */ -package js; +package js.lib; -@:deprecated typedef Date = js.lib.Date; +import Date in HaxeDate; + +/** + Creates a JavaScript Date instance that represents a single moment in time. Date objects are based on a time value that is the number of milliseconds since 1 January 1970 UTC. +**/ +@:native("Date") +extern class Date +{ + @:overload(function(value:Float):Void {}) + @:overload(function(dateString:String):Void {}) + @:overload(function(year:Int, month:Int, ?day:Int, ?hours:Int, ?minutes:Int, ?seconds:Int, ?milliseconds:Int):Void {}) + function new() : Void; + + /** + Cast Haxe's Date to js.Date. + **/ + static public inline function fromHaxeDate(date:HaxeDate):js.Date { + return cast date; + } + + /** + Cast js.Date to Haxe's Date. + **/ + static public inline function toHaxeDate(date:Date):HaxeDate { + return cast date; + } + + /** + Returns the numeric value corresponding to the current time - the number of milliseconds elapsed since January 1, 1970 00:00:00 UTC, with leap seconds ignored + **/ + static function now() : Float; + + /** + Parses a string representation of a date and returns the number of milliseconds since 1 January, 1970, 00:00:00, UTC, with leap seconds ignored. + **/ + static function parse( str:String ) : Float; + + /** + Returns the number of milliseconds since January 1, 1970, 00:00:00 UTC, with leap seconds ignored. + **/ + static function UTC( year:Int, month:Int, ?day:Int, ?hours:Int, ?minutes:Int, ?seconds:Int, ?milliseconds:Int ) : Float; + + /** + Returns the day of the month (1-31) for the specified date according to local time. + **/ + function getDate() : Int; + + /** + Returns the day of the week (0-6) for the specified date according to local time. + **/ + function getDay() : Int; + + /** + Returns the year (4 digits for 4-digit years) of the specified date according to local time. + **/ + function getFullYear() : Int; + + /** + Returns the hour (0-23) in the specified date according to local time. + **/ + function getHours() : Int; + + /** + Returns the milliseconds (0-999) in the specified date according to local time. + **/ + function getMilliseconds() : Int; + + /** + Returns the minutes (0-59) in the specified date according to local time. + **/ + function getMinutes() : Int; + + /** + Returns the month (0-11) in the specified date according to local time. + **/ + function getMonth() : Int; + + /** + Returns the seconds (0-59) in the specified date according to local time. + **/ + function getSeconds() : Int; + + /** + Returns the numeric value of the specified date as the number of milliseconds since January 1, 1970, 00:00:00 UTC (negative for prior times). + **/ + function getTime() : Float; + + /** + Returns the time-zone offset in minutes for the current locale. + **/ + function getTimezoneOffset() : Int; + + /** + Returns the day (date) of the month (1-31) in the specified date according to universal time. + **/ + function getUTCDate() : Int; + + /** + Returns the day of the week (0-6) in the specified date according to universal time. + **/ + function getUTCDay() : Int; + + /** + Returns the year (4 digits for 4-digit years) in the specified date according to universal time. + **/ + function getUTCFullYear() : Int; + + /** + Returns the hours (0-23) in the specified date according to universal time. + **/ + function getUTCHours() : Int; + + /** + Returns the milliseconds (0-999) in the specified date according to universal time. + **/ + function getUTCMilliseconds() : Int; + + /** + Returns the minutes (0-59) in the specified date according to universal time. + **/ + function getUTCMinutes() : Int; + + /** + Returns the month (0-11) in the specified date according to universal time. + **/ + function getUTCMonth() : Int; + + /** + Returns the seconds (0-59) in the specified date according to universal time. + **/ + function getUTCSeconds() : Int; + + /** + Sets the day of the month for a specified date according to local time. + **/ + function setDate( value:Int ) : Void; + + /** + Sets the full year (e.g. 4 digits for 4-digit years) for a specified date according to local time. + **/ + function setFullYear( value:Int ) : Void; + + /** + Sets the hours for a specified date according to local time. + **/ + function setHours( value:Int ) : Void; + + /** + Sets the milliseconds for a specified date according to local time. + **/ + function setMilliseconds( value:Int ) : Void; + + /** + Sets the minutes for a specified date according to local time. + **/ + function setMinutes( value:Int ) : Void; + + /** + Sets the month for a specified date according to local time. + **/ + function setMonth( value:Int ) : Void; + + /** + Sets the seconds for a specified date according to local time. + **/ + function setSeconds( value:Int ) : Void; + + /** + Sets the Date object to the time represented by a number of milliseconds since January 1, 1970, 00:00:00 UTC, allowing for negative numbers for times prior. + **/ + function setTime( value:Float ) : Void; + + /** + Sets the day of the month for a specified date according to universal time. + **/ + function setUTCDate( value:Int ) : Void; + + /** + Sets the full year (e.g. 4 digits for 4-digit years) for a specified date according to universal time. + **/ + function setUTCFullYear( value:Int ) : Void; + + /** + Sets the hour for a specified date according to universal time. + **/ + function setUTCHours( value:Int ) : Void; + + /** + Sets the milliseconds for a specified date according to universal time. + **/ + function setUTCMilliseconds( value:Int ) : Void; + + /** + Sets the minutes for a specified date according to universal time. + **/ + function setUTCMinutes( value:Int ) : Void; + + /** + Sets the month for a specified date according to universal time. + **/ + function setUTCMonth( value:Int ) : Void; + + /** + Sets the seconds for a specified date according to universal time. + **/ + function setUTCSeconds( value:Int ) : Void; + + /** + Returns the "date" portion of the Date as a human-readable string. + **/ + function toDateString() : String; + + /** + Converts a date to a string following the ISO 8601 Extended Format. + **/ + function toISOString() : String; + + /** + Returns a string representing the Date using toISOString(). Intended for use by JSON.stringify(). + **/ + function toJSON() : String; + + /** + Returns a string with a locality sensitive representation of the date portion of this date based on system settings. + **/ + function toLocaleDateString( ?locales:String, ?options:Dynamic ) : String; + + /** + Converts a date to a string, using a format string. + **/ + function toLocaleFormat( format:String ) : String; + + /** + Returns a string with a locality sensitive representation of this date. Overrides the Object.prototype.toLocaleString() method. + **/ + function toLocaleString( ?locales:String, ?options:Dynamic ) : String; + + /** + Returns a string with a locality sensitive representation of the time portion of this date based on system settings. + **/ + function toLocaleTimeString( ?locales:String, ?options:Dynamic ) : String; + + /** + Returns a string representing the source for an equivalent Date object; you can use this value to create a new object. Overrides the Object.prototype.toSource() method. + **/ + function toSource() : String; + + /** + Returns a string representing the specified Date object. Overrides the Object.prototype.toString() method. + **/ + function toString() : String; + + /** + Returns the "time" portion of the Date as a human-readable string. + **/ + function toTimeString() : String; + + /** + Converts a date to a string using the UTC timezone. + **/ + function toUTCString() : String; +} From d10e0a0ca2261db5d24fbd47dbe5aa9ec4206280 Mon Sep 17 00:00:00 2001 From: Alexander Kuzmenko Date: Tue, 16 Apr 2019 22:21:27 +0300 Subject: [PATCH 3/5] fixed js.Date typedef --- std/js/Date.hx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/std/js/Date.hx b/std/js/Date.hx index 1a24b7ce9af..f6e8b8a97d3 100644 --- a/std/js/Date.hx +++ b/std/js/Date.hx @@ -21,4 +21,4 @@ */ package js; -@:deprecated Date = js.lib.Date; \ No newline at end of file +@:deprecated typedef Date = js.lib.Date; \ No newline at end of file From c04ffeb5bd568a536b7a07eca553a29c38b4d94b Mon Sep 17 00:00:00 2001 From: Alexander Kuzmenko Date: Tue, 16 Apr 2019 23:11:51 +0300 Subject: [PATCH 4/5] removed js.Date and js.Map --- std/js/Date.hx | 24 ------------------------ std/js/Map.hx | 24 ------------------------ 2 files changed, 48 deletions(-) delete mode 100644 std/js/Date.hx delete mode 100644 std/js/Map.hx diff --git a/std/js/Date.hx b/std/js/Date.hx deleted file mode 100644 index f6e8b8a97d3..00000000000 --- a/std/js/Date.hx +++ /dev/null @@ -1,24 +0,0 @@ -/* - * Copyright (C)2005-2019 Haxe Foundation - * - * Permission is hereby granted, free of charge, to any person obtaining a - * copy of this software and associated documentation files (the "Software"), - * to deal in the Software without restriction, including without limitation - * the rights to use, copy, modify, merge, publish, distribute, sublicense, - * and/or sell copies of the Software, and to permit persons to whom the - * Software is furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE - * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING - * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER - * DEALINGS IN THE SOFTWARE. - */ -package js; - -@:deprecated typedef Date = js.lib.Date; \ No newline at end of file diff --git a/std/js/Map.hx b/std/js/Map.hx deleted file mode 100644 index e68044c4c52..00000000000 --- a/std/js/Map.hx +++ /dev/null @@ -1,24 +0,0 @@ -/* - * Copyright (C)2005-2019 Haxe Foundation - * - * Permission is hereby granted, free of charge, to any person obtaining a - * copy of this software and associated documentation files (the "Software"), - * to deal in the Software without restriction, including without limitation - * the rights to use, copy, modify, merge, publish, distribute, sublicense, - * and/or sell copies of the Software, and to permit persons to whom the - * Software is furnished to do so, subject to the following conditions: - * - * The above copyright notice and this permission notice shall be included in - * all copies or substantial portions of the Software. - * - * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR - * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, - * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE - * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER - * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING - * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER - * DEALINGS IN THE SOFTWARE. - */ -package js; - -@:deprecated typedef Map = js.lib.Map; From 7cd9a561ee3980811aed740efb0723e733b16316 Mon Sep 17 00:00:00 2001 From: Alexander Kuzmenko Date: Wed, 17 Apr 2019 11:09:15 +0300 Subject: [PATCH 5/5] updated `js.*` references to `js.lib.*` --- std/haxe/Timer.hx | 2 +- std/js/Boot.hx | 4 +- std/js/_std/Type.hx | 6 +- std/js/html/Animation.hx | 40 +++--- std/js/html/Cache.hx | 2 + std/js/html/CacheStorage.hx | 12 +- std/js/html/Directory.hx | 4 +- std/js/html/FontFace.hx | 24 ++-- std/js/html/FontFaceSet.hx | 12 +- std/js/html/MediaDevices.hx | 6 +- std/js/html/MediaElement.hx | 88 +++++++------ std/js/html/MediaStreamTrack.hx | 42 +++--- std/js/html/Navigator.hx | 26 ++-- std/js/html/Permissions.hx | 4 +- std/js/html/Request.hx | 28 ++-- std/js/html/Response.hx | 24 ++-- std/js/html/ScreenOrientation.hx | 14 +- std/js/html/ServiceWorkerContainer.hx | 18 +-- std/js/html/ServiceWorkerRegistration.hx | 24 ++-- std/js/html/StorageManager.hx | 8 +- std/js/html/SubtleCrypto.hx | 26 ++-- std/js/html/Window.hx | 160 ++++++++++++----------- std/js/html/eme/MediaKeySession.hx | 30 +++-- std/js/html/eme/MediaKeySystemAccess.hx | 10 +- std/js/html/eme/MediaKeys.hx | 8 +- std/js/html/push/PushManager.hx | 8 +- std/js/html/push/PushSubscription.hx | 14 +- std/js/lib/Date.hx | 6 +- std/js/lib/Object.hx | 2 +- tests/server/src/Vfs.hx | 6 +- tests/unit/src/unit/issues/Issue3499.hx | 4 +- tests/unit/src/unit/issues/Issue4644.hx | 2 +- 32 files changed, 357 insertions(+), 307 deletions(-) diff --git a/std/haxe/Timer.hx b/std/haxe/Timer.hx index 7de7669cc06..3e79febe531 100644 --- a/std/haxe/Timer.hx +++ b/std/haxe/Timer.hx @@ -172,7 +172,7 @@ class Timer { #elseif (neko || php) return Sys.time(); #elseif js - return js.Date.now() / 1000; + return js.lib.Date.now() / 1000; #elseif cpp return untyped __global__.__time_stamp(); #elseif python diff --git a/std/js/Boot.hx b/std/js/Boot.hx index 6798670711f..9946b174eb8 100644 --- a/std/js/Boot.hx +++ b/std/js/Boot.hx @@ -161,7 +161,7 @@ class Boot { return false; if( cc == cl ) return true; - if( js.Object.prototype.hasOwnProperty.call(cc, "__interfaces__") ) { + if( js.lib.Object.prototype.hasOwnProperty.call(cc, "__interfaces__") ) { var intf : Dynamic = cc.__interfaces__; for( i in 0...intf.length ) { var i : Dynamic = intf[i]; @@ -220,7 +220,7 @@ class Boot { else throw "Cannot cast " +Std.string(o) + " to " +Std.string(t); } - static var __toStr:js.Function; + static var __toStr:js.lib.Function; static function __init__() { Boot.__toStr = (cast {}).toString; } diff --git a/std/js/_std/Type.hx b/std/js/_std/Type.hx index 6027d04d637..ab1df228034 100644 --- a/std/js/_std/Type.hx +++ b/std/js/_std/Type.hx @@ -138,7 +138,7 @@ enum ValueType { } public static inline function createEmptyInstance(cl:Class):T { - return js.Object.create((cast cl).prototype); + return js.lib.Object.create((cast cl).prototype); } #end public static function createEnum(e:Enum, constr:String, ?params:Array):T { @@ -166,7 +166,7 @@ enum ValueType { public static function getInstanceFields(c:Class):Array { var result = []; while (c != null) { - for (name in js.Object.getOwnPropertyNames((cast c).prototype)) { + for (name in js.lib.Object.getOwnPropertyNames((cast c).prototype)) { switch name { case "constructor" | "__class__" | "__properties__": // skip special names @@ -181,7 +181,7 @@ enum ValueType { } public static function getClassFields(c:Class):Array { - var a = js.Object.getOwnPropertyNames(cast c); + var a = js.lib.Object.getOwnPropertyNames(cast c); a.remove("__id__"); a.remove("hx__closures__"); a.remove("__name__"); diff --git a/std/js/html/Animation.hx b/std/js/html/Animation.hx index 2f50062ffd9..fbaab563fb4 100644 --- a/std/js/html/Animation.hx +++ b/std/js/html/Animation.hx @@ -24,6 +24,8 @@ package js.html; +import js.lib.Promise; + /** The `Animation` interface of the Web Animations API represents a single animation player and provides playback controls and a timeline for an animation node or source. @@ -33,98 +35,98 @@ package js.html; **/ @:native("Animation") extern class Animation extends EventTarget { - + /** Gets and sets the `String` used to identify the animation. **/ var id : String; - + /** Gets and sets the `AnimationEffectReadOnly` associated with this animation. This will usually be a `KeyframeEffect` object. **/ var effect : AnimationEffect; - + /** Gets or sets the `AnimationTimeline` associated with this animation. **/ var timeline : AnimationTimeline; - + /** Gets or sets the scheduled time when an animation's playback should begin. **/ var startTime : Float; - + /** The current time value of the animation in milliseconds, whether running or paused. If the animation lacks a `AnimationTimeline`, is inactive or hasn't been played yet, its value is `null`. **/ var currentTime : Float; - + /** Gets or sets the playback rate of the animation. **/ var playbackRate : Float; - + /** Returns an enumerated value describing the playback state of an animation. **/ var playState(default,null) : AnimationPlayState; - + /** Indicates whether the animation is currently waiting for an asynchronous operation such as initiating playback or pausing a running animation. **/ var pending(default,null) : Bool; - + /** Returns the current ready Promise for this animation. **/ var ready(default,null) : Promise; - + /** Returns the current finished Promise for this animation. **/ var finished(default,null) : Promise; - + /** Gets and sets the event handler for the `finish` event. **/ var onfinish : haxe.Constraints.Function; - + /** Gets and sets the event handler for the `cancel` event. **/ var oncancel : haxe.Constraints.Function; - + /** @throws DOMError */ function new( ?effect : AnimationEffect, ?timeline : AnimationTimeline ) : Void; - + /** Clears all `KeyframeEffect` caused by this animation and aborts its playback. **/ function cancel() : Void; - + /** Seeks either end of an animation, depending on whether the animation is playing or reversing. @throws DOMError **/ function finish() : Void; - + /** Starts or resumes playing of an animation, or begins the animation again if it previously finished. @throws DOMError **/ function play() : Void; - + /** Suspends playing of an animation. @throws DOMError **/ function pause() : Void; - + /** Sets the speed of an animation after first synchronizing its playback position. **/ function updatePlaybackRate( playbackRate : Float ) : Void; - + /** Reverses playback direction, stopping at the start of the animation. If the animation is finished or unplayed, it will play from end to beginning. @throws DOMError diff --git a/std/js/html/Cache.hx b/std/js/html/Cache.hx index d525245685b..93b9bd6d39d 100644 --- a/std/js/html/Cache.hx +++ b/std/js/html/Cache.hx @@ -24,6 +24,8 @@ package js.html; +import js.lib.Promise; + /** The `Cache` interface provides a storage mechanism for `Request` / `Response` object pairs that are cached, for example as part of the `ServiceWorker` life cycle. Note that the `Cache` interface is exposed to windowed scopes as well as workers. You don't have to use it in conjunction with service workers, even though it is defined in the service worker spec. diff --git a/std/js/html/CacheStorage.hx b/std/js/html/CacheStorage.hx index 28429e75806..8a7546b07f0 100644 --- a/std/js/html/CacheStorage.hx +++ b/std/js/html/CacheStorage.hx @@ -24,6 +24,8 @@ package js.html; +import js.lib.Promise; + /** The `CacheStorage` interface represents the storage for `Cache` objects. @@ -35,28 +37,28 @@ package js.html; extern class CacheStorage { /** @throws DOMError */ function new( namespace : CacheStorageNamespace, principal : Dynamic/*MISSING Principal*/ ) : Void; - + /** Checks if a given `Request` is a key in any of the `Cache` objects that the `CacheStorage` object tracks, and returns a `Promise` that resolves to that match. **/ @:overload( function( request : String, ?options : CacheQueryOptions) : Promise {} ) function match( request : Request, ?options : CacheQueryOptions ) : Promise; - + /** Returns a `Promise` that resolves to `true` if a `Cache` object matching the `cacheName` exists. **/ function has( cacheName : String ) : Promise; - + /** Returns a `Promise` that resolves to the `Cache` object matching the `cacheName` (a new cache is created if it doesn't already exist.) **/ function open( cacheName : String ) : Promise; - + /** Finds the `Cache` object matching the `cacheName`, and if found, deletes the `Cache` object and returns a `Promise` that resolves to `true`. If no `Cache` object is found, it returns `false`. **/ function delete( cacheName : String ) : Promise; - + /** Returns a `Promise` that will resolve with an array containing strings corresponding to all of the named `Cache` objects tracked by the `CacheStorage`. Use this method to iterate over a list of all the `Cache` objects. **/ diff --git a/std/js/html/Directory.hx b/std/js/html/Directory.hx index 271c061e7c0..719d3559727 100644 --- a/std/js/html/Directory.hx +++ b/std/js/html/Directory.hx @@ -24,11 +24,13 @@ package js.html; +import js.lib.Promise; + @:native("Directory") extern class Directory { var name(default,null) : String; var path(default,null) : String; - + /** @throws DOMError */ function new( path : String ) : Void; /** @throws DOMError */ diff --git a/std/js/html/FontFace.hx b/std/js/html/FontFace.hx index ab4c77b975a..7110e6a3845 100644 --- a/std/js/html/FontFace.hx +++ b/std/js/html/FontFace.hx @@ -24,6 +24,8 @@ package js.html; +import js.lib.Promise; + /** The `FontFace` interface represents a single usable font face. It allows control of the source of the font face, being a URL to an external resource, or a buffer; it also allows control of when the font face is loaded and its current status. @@ -33,57 +35,57 @@ package js.html; **/ @:native("FontFace") extern class FontFace { - + /** Is a `CSSOMString` that contains the family of the font. It is equivalent to the `@font-face/font-family` descriptor. **/ var family : String; - + /** Is a `CSSOMString` that contains the style of the font. It is equivalent to the `@font-face/font-style` descriptor. **/ var style : String; - + /** Is a `CSSOMString` that contains the weight of the font. It is equivalent to the `@font-face/font-weight` descriptor. **/ var weight : String; - + /** Is a `CSSOMString` that contains how the font stretches. It is equivalent to the `@font-face/font-stretch` descriptor. **/ var stretch : String; - + /** Is a `CSSOMString` that contains the range of code encompassed the font. It is equivalent to the `@font-face/unicode-range` descriptor. **/ var unicodeRange : String; - + /** Is a `CSSOMString` that contains the variant of the font. It is equivalent to the `@font-face/font-variant` descriptor. **/ var variant : String; - + /** Is a `CSSOMString` that contains the features of the font. It is equivalent to the `@font-face/font-feature-settings`descriptor. **/ var featureSettings : String; - + /** Returns an enumerated value indicating the status of the font. It can be one of the following: `"unloaded"`, `"loading"`, `"loaded"`, or `"error"`. **/ var status(default,null) : FontFaceLoadStatus; - + /** Returns a `Promise` to a `FontFace` that fulfills when the font is completely loaded and rejects when an error happens. **/ var loaded(default,null) : Promise; - + /** @throws DOMError */ @:overload( function( family : String, source : js.lib.ArrayBuffer, ?descriptors : FontFaceDescriptors) : FontFace {} ) @:overload( function( family : String, source : js.lib.ArrayBufferView, ?descriptors : FontFaceDescriptors) : FontFace {} ) function new( family : String, source : String, ?descriptors : FontFaceDescriptors ) : Void; - + /** Loads the font, returning a `Promise` to a `FontFace` that fulfills when the font is completely loaded and rejects when an error happens. @throws DOMError diff --git a/std/js/html/FontFaceSet.hx b/std/js/html/FontFaceSet.hx index 16b038048c6..85f5de51690 100644 --- a/std/js/html/FontFaceSet.hx +++ b/std/js/html/FontFaceSet.hx @@ -24,6 +24,8 @@ package js.html; +import js.lib.Promise; + /** The `FontFaceSet` interface of the CSS Font Loading API manages the loading of font-faces and querying of their download status. @@ -34,28 +36,28 @@ package js.html; @:native("FontFaceSet") extern class FontFaceSet extends EventTarget { var size(default,null) : Int; - + /** An `EventListener` called whenever an event of type `loading` is fired, indicating a font-face set has started loading. **/ var onloading : haxe.Constraints.Function; - + /** An `EventListener` called whenever an event of type `loadingdone` is fired, indicating that a font face set has finished loading. **/ var onloadingdone : haxe.Constraints.Function; - + /** An `EventListener` called whenever an event of type `loadingerror` is fired, indicating that an error occurred whilst loading a font-face set. **/ var onloadingerror : haxe.Constraints.Function; var ready(default,null) : Promise; - + /** Indicates the font-face's loading status. It will be one of `'loading'` or `'loaded'`. **/ var status(default,null) : FontFaceSetLoadStatus; - + /** @throws DOMError */ function add( font : FontFace ) : Void; function has( font : FontFace ) : Bool; diff --git a/std/js/html/MediaDevices.hx b/std/js/html/MediaDevices.hx index 851c992d311..2bdef74379a 100644 --- a/std/js/html/MediaDevices.hx +++ b/std/js/html/MediaDevices.hx @@ -24,6 +24,8 @@ package js.html; +import js.lib.Promise; + /** The `MediaDevices` interface provides access to connected media input devices like cameras and microphones, as well as screen sharing. In essence, it lets you obtain access to any hardware source of media data. @@ -33,12 +35,12 @@ package js.html; **/ @:native("MediaDevices") extern class MediaDevices extends EventTarget { - + /** The event handler for the `devicechange` event. This event is delivered to the `MediaDevices` object when a media input or output device is attached to or removed from the user's computer. **/ var ondevicechange : haxe.Constraints.Function; - + function getSupportedConstraints() : MediaTrackSupportedConstraints; /** @throws DOMError */ function enumerateDevices() : Promise>; diff --git a/std/js/html/MediaElement.hx b/std/js/html/MediaElement.hx index ac5f485f6f8..9ef5ac73957 100644 --- a/std/js/html/MediaElement.hx +++ b/std/js/html/MediaElement.hx @@ -24,6 +24,8 @@ package js.html; +import js.lib.Promise; + /** The `HTMLMediaElement` interface adds to `HTMLElement` the properties and methods needed to support basic media-related capabilities that are common to audio and video. @@ -42,198 +44,198 @@ extern class MediaElement extends Element { static inline var HAVE_CURRENT_DATA : Int = 2; static inline var HAVE_FUTURE_DATA : Int = 3; static inline var HAVE_ENOUGH_DATA : Int = 4; - - + + /** Returns a `MediaError` object for the most recent error, or `null` if there has not been an error. **/ var error(default,null) : MediaError; - + /** Is a `DOMString` that reflects the `src` HTML attribute, which contains the URL of a media resource to use. **/ var src : String; - + /** Returns a `DOMString` with the absolute URL of the chosen media resource. **/ var currentSrc(default,null) : String; - + /** Is a `DOMString` indicating the CORS setting for this media element. **/ var crossOrigin : String; - + /** Returns a `unsigned short` (enumeration) indicating the current state of fetching the media over the network. **/ var networkState(default,null) : Int; - + /** Is a `DOMString` that reflects the `preload` HTML attribute, indicating what data should be preloaded, if any. Possible values are: `none`, `metadata`, `auto`. **/ var preload : String; - + /** Returns a `TimeRanges` object that indicates the ranges of the media source that the browser has buffered (if any) at the moment the `buffered` property is accessed. **/ var buffered(default,null) : TimeRanges; - + /** Returns a `unsigned short` (enumeration) indicating the readiness state of the media. **/ var readyState(default,null) : Int; - + /** Returns a `Boolean` that indicates whether the media is in the process of seeking to a new position. **/ var seeking(default,null) : Bool; - + /** Is a `double` indicating the current playback time in seconds. Setting this value seeks the media to the new time. **/ var currentTime : Float; - + /** Returns a `double` indicating the length of the media in seconds, or 0 if no media data is available. **/ var duration(default,null) : Float; - + /** Returns a `Boolean` that indicates whether the media element is paused. **/ var paused(default,null) : Bool; - + /** Is a `double` indicating the default playback rate for the media. **/ var defaultPlaybackRate : Float; - + /** Is a `double` that indicates the rate at which the media is being played back.  **/ var playbackRate : Float; - + /** Returns a `TimeRanges` object that contains the ranges of the media source that the browser has played, if any. **/ var played(default,null) : TimeRanges; - + /** Returns a `TimeRanges` object that contains the time ranges that the user is able to seek to, if any. **/ var seekable(default,null) : TimeRanges; - + /** Returns a `Boolean` that indicates whether the media element has finished playing. **/ var ended(default,null) : Bool; - + /** A `Boolean` that reflects the `autoplay` HTML attribute, indicating whether playback should automatically begin as soon as enough media is available to do so without interruption. Sites which automatically play audio (or videos with an audio track) can be an unpleasant experience for users, so it should be avoided when possible. If you must offer autoplay functionality, you should make it opt-in (requiring a user to specifically enable it). However, this can be useful when creating media elements whose source will be set at a later time, under user control. - + **/ var autoplay : Bool; - + /** Is a `Boolean` that reflects the `loop` HTML attribute, which indicates whether the media element should start over when it reaches the end. **/ var loop : Bool; - + /** Is a `Boolean` that reflects the `controls` HTML attribute, indicating whether user interface items for controlling the resource should be displayed. **/ var controls : Bool; - + /** Is a `double` indicating the audio volume, from 0.0 (silent) to 1.0 (loudest). **/ var volume : Float; - + /** Is a `Boolean` that determines whether audio is muted. `true` if the audio is muted and `false` otherwise. **/ var muted : Bool; - + /** Is a `Boolean` that reflects the `muted` HTML attribute, which indicates whether the media element's audio output should be muted by default. **/ var defaultMuted : Bool; - + /** A `AudioTrackList` that lists the `AudioTrack` objects contained in the element. **/ var audioTracks(default,null) : AudioTrackList; - + /** Returns the list of `VideoTrack` objects contained in the element. - + Gecko supports only single track playback, and the parsing of tracks' metadata is only available for media with the Ogg container format. - - + + **/ var videoTracks(default,null) : VideoTrackList; - + /** Returns the list of `TextTrack` objects contained in the element. **/ var textTracks(default,null) : TextTrackList; - + /** Is a `MediaStream` representing the media to play or that has played in the current `HTMLMediaElement`, or `null` if not assigned. **/ var srcObject : MediaStream; - + /** Returns a `MediaKeys` object or `null`. MediaKeys is a set of keys that an associated HTMLMediaElement can use for decryption of media data during playback. **/ var mediaKeys(default,null) : js.html.eme.MediaKeys; - + /** Sets the `EventHandler` called when the media is encrypted. **/ var onencrypted : haxe.Constraints.Function; - + /** Sets the `EventHandler` called when playback is blocked while waiting for an encryption key. **/ var onwaitingforkey : haxe.Constraints.Function; - - + + /** Resets the media element and restarts the media resource. Any pending events are discarded. How much media data is fetched is still affected by the `preload` attribute. This method can be useful for releasing resources after any `src` attribute and `source` element descendants have been removed. Otherwise, it is usually unnecessary to use this method, unless required to rescan `source` element children after dynamic changes. **/ function load() : Void; - + /** Determines whether the specified media type can be played back. **/ function canPlayType( type : String ) : String; - + /** Directly seeks to the given time. @throws DOMError **/ function fastSeek( time : Float ) : Void; - + /** Begins playback of the media. @throws DOMError **/ function play() : Promise; - + /** Pauses the media playback. @throws DOMError **/ function pause() : Void; - + /** Adds a text track (such as a track for subtitles) to a media element. **/ function addTextTrack( kind : TextTrackKind, label : String = "", language : String = "" ) : TextTrack; - + /** Returns `Promise`. Sets the `MediaKeys` keys to use when decrypting media during playback. **/ diff --git a/std/js/html/MediaStreamTrack.hx b/std/js/html/MediaStreamTrack.hx index e686256b036..255bfc10fec 100644 --- a/std/js/html/MediaStreamTrack.hx +++ b/std/js/html/MediaStreamTrack.hx @@ -24,6 +24,8 @@ package js.html; +import js.lib.Promise; + /** The `MediaStreamTrack` interface represents a single media track within a stream; typically, these are audio or video tracks, but other track types may exist as well. @@ -33,82 +35,82 @@ package js.html; **/ @:native("MediaStreamTrack") extern class MediaStreamTrack extends EventTarget { - + /** Returns a `DOMString` set to `"audio"` if the track is an audio track and to `"video"`, if it is a video track. It doesn't change if the track is deassociated from its source. **/ var kind(default,null) : String; - + /** Returns a `DOMString` containing a unique identifier (GUID) for the track; it is generated by the browser. **/ var id(default,null) : String; - + /** Returns a `DOMString` containing a user agent-assigned label that identifies the track source, as in `"internal microphone"`. The string may be left empty and is empty as long as no source has been connected. When the track is deassociated from its source, the label is not changed. **/ var label(default,null) : String; - + /** A Boolean whose value of `true` if the track is enabled, that is allowed to render the media source stream; or `false` if it is disabled, that is not rendering the media source stream but silence and blackness. If the track has been disconnected, this value can be changed but has no more effect. Note: You can implement standard "mute" functionality by setting `enabled` to `false`. The `muted` property refers to a condition in which there's no media because of a technical issue. - + **/ var enabled : Bool; - + /** Returns a Boolean value indicating whether the track is unable to provide media data due to a technical issue. Note: You can implement standard "mute" functionality by setting `enabled` to `false`, and unmute the media by setting it back to `true` again. - + **/ var muted(default,null) : Bool; - + /** An `EventHandler` containing the action to perform when an `mute` event is fired on the object, that is when the streaming is terminating. **/ var onmute : haxe.Constraints.Function; - + /** An `EventHandler` containing the action to perform when an `unmute` event is fired on the object, that is when a  `MediaStreamTrack` object is removed from it. **/ var onunmute : haxe.Constraints.Function; - + /** Returns an enumerated value giving the status of the track. This will be one of the following values: - + `"live"` which indicates that an input is connected and does its best-effort in providing real-time data. In that case, the output of data can be switched on or off using the `MediaStreamTrack.enabled` attribute. `"ended"` which indicates that the input is not giving any more data and will never provide new data. - - + + **/ var readyState(default,null) : MediaStreamTrackState; - + /** An `EventHandler` containing the action to perform when an `ended_(MediaStream)` event is fired on the object, that is when a  `MediaStreamTrack` object is removed from it. **/ var onended : haxe.Constraints.Function; - - + + /** Returns a duplicate of the `MediaStreamTrack`. **/ function clone() : MediaStreamTrack; - + /** Stops playing the source associated to the track, both the source and the track are deassociated. The track state is set to `ended`. **/ function stop() : Void; - + /** Returns a `MediaTrackConstraints` object containing the currently set constraints for the track; the returned value matches the constraints last set using `MediaStreamTrack.applyConstraints`. **/ function getConstraints() : MediaTrackConstraints; - + /** Returns a `MediaTrackSettings` object containing the current values of each of the `MediaStreamTrack`'s constrainable properties. **/ function getSettings() : MediaTrackSettings; - + /** Lets the application specify the ideal and/or ranges of acceptable values for any number of the available constrainable properties of the `MediaStreamTrack`. @throws DOMError diff --git a/std/js/html/Navigator.hx b/std/js/html/Navigator.hx index b7c44026001..5f2701dab12 100644 --- a/std/js/html/Navigator.hx +++ b/std/js/html/Navigator.hx @@ -24,6 +24,8 @@ package js.html; +import js.lib.Promise; + /** The `Navigator` interface represents the state and the identity of the user agent. It allows scripts to query it and to register themselves to carry on some activities. @@ -33,61 +35,61 @@ package js.html; **/ @:native("Navigator") extern class Navigator { - + /** Returns a `Permissions` object that can be used to query and update permission status of APIs covered by the Permissions API. **/ var permissions(default,null) : Permissions; var mimeTypes(default,null) : MimeTypeArray; var plugins(default,null) : PluginArray; - + /** Reports the value of the user's do-not-track preference. When this value is "yes", your web site or application should not track the user. **/ var doNotTrack(default,null) : String; var maxTouchPoints(default,null) : Int; - + /** Returns a string that represents the current operating system. **/ var oscpu(default,null) : String; - + /** Returns the vendor name of the current browser (e.g., "Netscape6"). **/ var vendor(default,null) : String; - + /** Returns the vendor version number (e.g. "6.1"). **/ var vendorSub(default,null) : String; - + /** Returns the build number of the current browser (e.g., "20060909"). **/ var productSub(default,null) : String; - + /** Returns false if setting a cookie will be ignored and true otherwise. **/ var cookieEnabled(default,null) : Bool; - + /** Returns the build identifier of the browser (e.g., "2006090803"). **/ var buildID(default,null) : String; - + /** Returns a reference to a `MediaDevices` object which can then be used to get information about available media devices (`MediaDevices.enumerateDevices()`), find out what constrainable properties are supported for media on the user's computer and user agent (`MediaDevices.getSupportedConstraints()`), and to request access to media using `MediaDevices.getUserMedia()`. **/ var mediaDevices(default,null) : MediaDevices; - + /** Returns a `ServiceWorkerContainer` object, which provides access to registration, removal, upgrade, and communication with the `ServiceWorker` objects for the associated document. **/ var serviceWorker(default,null) : ServiceWorkerContainer; var hardwareConcurrency(default,null) : Int; - + /** Returns a `Geolocation` object allowing accessing the location of the device. **/ @@ -102,7 +104,7 @@ extern class Navigator { var languages(default,null) : Array; var onLine(default,null) : Bool; var storage(default,null) : StorageManager; - + @:overload( function( duration : Int ) : Bool {} ) function vibrate( pattern : Array ) : Bool; function javaEnabled() : Bool; diff --git a/std/js/html/Permissions.hx b/std/js/html/Permissions.hx index 5dfcd66e07e..52a61226fb3 100644 --- a/std/js/html/Permissions.hx +++ b/std/js/html/Permissions.hx @@ -24,6 +24,8 @@ package js.html; +import js.lib.Promise; + /** Documentation [Permissions](https://developer.mozilla.org/en-US/docs/Web/API/Permissions) by [Mozilla Contributors](https://developer.mozilla.org/en-US/docs/Web/API/Permissions$history), licensed under [CC-BY-SA 2.5](https://creativecommons.org/licenses/by-sa/2.5/). @@ -31,7 +33,7 @@ package js.html; **/ @:native("Permissions") extern class Permissions { - + /** Returns the user permission status for a given API. @throws DOMError diff --git a/std/js/html/Request.hx b/std/js/html/Request.hx index d69f93036c8..3c0f7abf921 100644 --- a/std/js/html/Request.hx +++ b/std/js/html/Request.hx @@ -24,6 +24,8 @@ package js.html; +import js.lib.Promise; + /** The `Request` interface of the Fetch API represents a resource request. @@ -33,68 +35,68 @@ package js.html; **/ @:native("Request") extern class Request { - + /** Contains the request's method (`GET`, `POST`, etc.) **/ var method(default,null) : String; - + /** Contains the URL of the request. **/ var url(default,null) : String; - + /** Contains the associated `Headers` object of the request. **/ var headers(default,null) : Headers; - + /** Returns a string from the `RequestDestination` enum describing the request's destination. This is a string indicating the type of content being requested. **/ var destination(default,null) : RequestDestination; - + /** Contains the referrer of the request (e.g., `client`). **/ var referrer(default,null) : String; - + /** Contains the referrer policy of the request (e.g., `no-referrer`). **/ var referrerPolicy(default,null) : ReferrerPolicy; - + /** Contains the mode of the request (e.g., `cors`, `no-cors`, `same-origin`, `navigate`.) **/ var mode(default,null) : RequestMode; - + /** Contains the credentials of the request (e.g., `"omit"`, `"same-origin"`, `"include"`). The default is `"same-origin"`. **/ var credentials(default,null) : RequestCredentials; - + /** Contains the cache mode of the request (e.g., `default`, `reload`, `no-cache`). **/ var cache(default,null) : RequestCache; - + /** Contains the mode for how redirects are handled. It may be one of `follow`, `error`, or `manual`. **/ var redirect(default,null) : RequestRedirect; - + /** Contains the subresource integrity value of the request (e.g., `sha256-BpfBw7ivV8q2jLiT13fxDYAe2tJllusRSZ273h2nFSE=`). **/ var integrity(default,null) : String; var signal(default,null) : AbortSignal; var bodyUsed(default,null) : Bool; - + /** @throws DOMError */ @:overload( function( input : String, ?init : RequestInit) : Request {} ) function new( input : Request, ?init : RequestInit ) : Void; - + /** Creates a copy of the current `Request` object. @throws DOMError diff --git a/std/js/html/Response.hx b/std/js/html/Response.hx index ae82e48c94c..006bf5fdd06 100644 --- a/std/js/html/Response.hx +++ b/std/js/html/Response.hx @@ -24,6 +24,8 @@ package js.html; +import js.lib.Promise; + /** The `Response` interface of the Fetch API represents the response to a request. @@ -33,54 +35,54 @@ package js.html; **/ @:native("Response") extern class Response { - + /** Returns a new `Response` object associated with a network error. **/ static function error() : Response; - + /** Creates a new response with a different URL. @throws DOMError **/ static function redirect( url : String, status : Int = 302 ) : Response; - + /** Contains the type of the response (e.g., `basic`, `cors`). **/ var type(default,null) : ResponseType; - + /** Contains the URL of the response. **/ var url(default,null) : String; - + /** Indicates whether or not the response is the result of a redirect; that is, its URL list has more than one entry. **/ var redirected(default,null) : Bool; - + /** Contains the status code of the response (e.g., `200` for a success). **/ var status(default,null) : Int; - + /** Contains a boolean stating whether the response was successful (status in the range 200-299) or not. **/ var ok(default,null) : Bool; - + /** Contains the status message corresponding to the status code (e.g., `OK` for `200`). **/ var statusText(default,null) : String; - + /** Contains the `Headers` object associated with the response. **/ var headers(default,null) : Headers; var bodyUsed(default,null) : Bool; - + /** @throws DOMError */ @:overload( function( ?body : js.lib.ArrayBufferView, ?init : ResponseInit) : Response {} ) @:overload( function( ?body : js.lib.ArrayBuffer, ?init : ResponseInit) : Response {} ) @@ -89,7 +91,7 @@ extern class Response { @:overload( function( ?body : Dynamic/*MISSING ReadableStream*/, ?init : ResponseInit) : Response {} ) @:overload( function( ?body : String, ?init : ResponseInit) : Response {} ) function new( ?body : Blob, ?init : ResponseInit ) : Void; - + /** Creates a clone of a `Response` object. @throws DOMError diff --git a/std/js/html/ScreenOrientation.hx b/std/js/html/ScreenOrientation.hx index 9dc4daf9fff..10a580e511d 100644 --- a/std/js/html/ScreenOrientation.hx +++ b/std/js/html/ScreenOrientation.hx @@ -24,6 +24,8 @@ package js.html; +import js.lib.Promise; + /** The `ScreenOrientation` interface of the the Screen Orientation API provides information about the current orientation of the document. @@ -33,29 +35,29 @@ package js.html; **/ @:native("ScreenOrientation") extern class ScreenOrientation extends EventTarget { - + /** Returns the document's current orientation type, one of "portrait-primary", "portrait-secondary", "landscape-primary", or "landscape-secondary". **/ var type(default,null) : OrientationType; - + /** Returns the document's current orientation angle. **/ var angle(default,null) : Int; - + /** Fired whenever is the `EventHandler` called when the screen changes orientation. **/ var onchange : haxe.Constraints.Function; - - + + /** Locks the orientation of the containing document to its default orientation and returns a `Promise`.  @throws DOMError **/ function lock( orientation : OrientationLockType ) : Promise; - + /** Unlocks the orientation of the containing document from its default orientation. @throws DOMError diff --git a/std/js/html/ServiceWorkerContainer.hx b/std/js/html/ServiceWorkerContainer.hx index 7b04948d492..af1cdde5f4d 100644 --- a/std/js/html/ServiceWorkerContainer.hx +++ b/std/js/html/ServiceWorkerContainer.hx @@ -24,6 +24,8 @@ package js.html; +import js.lib.Promise; + /** The `ServiceWorkerContainer` interface of the ServiceWorker API provides an object representing the service worker as an overall unit in the network ecosystem, including facilities to register, unregister and update service workers, and access the state of service workers and their registrations. @@ -33,39 +35,39 @@ package js.html; **/ @:native("ServiceWorkerContainer") extern class ServiceWorkerContainer extends EventTarget { - + /** Returns a `ServiceWorker` object if its state is `activated` (the same object returned by `ServiceWorkerRegistration.active`). This property returns `null` during a force-refresh request (Shift + refresh) or if there is no active worker. **/ var controller(default,null) : ServiceWorker; - + /** Provides a way of delaying code execution until a service worker is active. It returns a `Promise` that will never reject, and which waits indefinitely until the `ServiceWorkerRegistration` associated with the current page has an `ServiceWorkerRegistration.active` worker. Once that condition is met, it resolves with the `ServiceWorkerRegistration`. **/ var ready(default,null) : Promise; - + /** Fired whenever a `controllerchange` event occurs — when the document's associated `ServiceWorkerRegistration` acquires a new `ServiceWorkerRegistration.active` worker. **/ var oncontrollerchange : haxe.Constraints.Function; - + /** Fired whenever an `error` event occurs in the associated service workers. **/ var onerror : haxe.Constraints.Function; - + /** Fired whenever a `message` event occurs — when incoming messages are received to the `ServiceWorkerContainer` object (e.g. via a `MessagePort.postMessage()` call.) **/ var onmessage : haxe.Constraints.Function; - + function register( scriptURL : String, ?options : RegistrationOptions ) : Promise; - + /** Gets a `ServiceWorkerRegistration` object whose scope matches the provided document URL.  If the method can't return a `ServiceWorkerRegistration`, it returns a `Promise`.  **/ function getRegistration( documentURL : String = "" ) : Promise; - + /** Returns all `ServiceWorkerRegistration` objects associated with a `ServiceWorkerContainer` in an array.  If the method can't return `ServiceWorkerRegistration` objects, it returns a `Promise`.  **/ diff --git a/std/js/html/ServiceWorkerRegistration.hx b/std/js/html/ServiceWorkerRegistration.hx index a5b958b599d..f431d128afd 100644 --- a/std/js/html/ServiceWorkerRegistration.hx +++ b/std/js/html/ServiceWorkerRegistration.hx @@ -24,6 +24,8 @@ package js.html; +import js.lib.Promise; + /** The `ServiceWorkerRegistration` interface of the ServiceWorker API represents the service worker registration. You register a service worker to control one or more pages that share the same origin. @@ -33,57 +35,57 @@ package js.html; **/ @:native("ServiceWorkerRegistration") extern class ServiceWorkerRegistration extends EventTarget { - + /** Returns a service worker whose state is `installing`. This is initially set to `null`. **/ var installing(default,null) : ServiceWorker; - + /** Returns a service worker whose state is `waiting`. This is initially set to `null`. **/ var waiting(default,null) : ServiceWorker; - + /** Returns a service worker whose state is either `activating` or `activated`. This is initially set to `null`. An active worker will control a `ServiceWorkerClient` if the client's URL falls within the scope of the registration (the `scope` option set when `ServiceWorkerContainer.register` is first called.) **/ var active(default,null) : ServiceWorker; - + /** Returns a unique identifier for a service worker registration. This must be on the same origin as the document that registers the `ServiceWorker`. **/ var scope(default,null) : String; var updateViaCache(default,null) : ServiceWorkerUpdateViaCache; - + /** An `EventListener` property called whenever an event of type `updatefound` is fired; it is fired any time the `ServiceWorkerRegistration.installing` property acquires a new service worker. **/ var onupdatefound : haxe.Constraints.Function; - + /** Returns a reference to the `PushManager` interface for managing push subscriptions including subscribing, getting an active subscription, and accessing push permission status. **/ var pushManager(default,null) : js.html.push.PushManager; - - + + /** Checks the server for an updated version of the service worker without consulting caches. @throws DOMError **/ function update() : Promise; - + /** Unregisters the service worker registration and returns a `Promise`. The service worker will finish any ongoing operations before it is unregistered. @throws DOMError **/ function unregister() : Promise; - + /** Displays the notification with the requested title. @throws DOMError **/ function showNotification( title : String, ?options : NotificationOptions ) : Promise; - + /** Returns a `Promise` that resolves to an array of `Notification` objects. @throws DOMError diff --git a/std/js/html/StorageManager.hx b/std/js/html/StorageManager.hx index 083dd73eb50..27fc26ec4b7 100644 --- a/std/js/html/StorageManager.hx +++ b/std/js/html/StorageManager.hx @@ -24,6 +24,8 @@ package js.html; +import js.lib.Promise; + /** The `StorageManager` interface of the the Storage API provides an interface for managing persistance permissions and estimating available storage. You can get a reference to this interface using either `navigator.storage` or `WorkerNavigator.storage`. @@ -33,19 +35,19 @@ package js.html; **/ @:native("StorageManager") extern class StorageManager { - + /** Returns a `Promise` that resolves to `true` if persistence has already been granted for your site's storage. @throws DOMError **/ function persisted() : Promise; - + /** Returns a `Promise` that resolves to `true` if the user agent is able to persist your site's storage. @throws DOMError **/ function persist() : Promise; - + /** Returns a `StorageEstimate` object containing usage and quota numbers for your origin. @throws DOMError diff --git a/std/js/html/SubtleCrypto.hx b/std/js/html/SubtleCrypto.hx index ae75e95ed98..0771ca6e060 100644 --- a/std/js/html/SubtleCrypto.hx +++ b/std/js/html/SubtleCrypto.hx @@ -24,6 +24,8 @@ package js.html; +import js.lib.Promise; + /** The `SubtleCrypto` interface represents a set of cryptographic primitives. It is available via the `Crypto.subtle` properties available in a window context (via `Window.crypto`). @@ -33,77 +35,77 @@ package js.html; **/ @:native("SubtleCrypto") extern class SubtleCrypto { - + /** Returns a `Promise` of the encrypted data corresponding to the clear text, algorithm and key given as parameters. @throws DOMError **/ function encrypt( algorithm : haxe.extern.EitherType, key : CryptoKey, data : haxe.extern.EitherType ) : Promise; - + /** Returns a `Promise` of the clear data corresponding to the encrypted text, algorithm and key given as parameters. @throws DOMError **/ function decrypt( algorithm : haxe.extern.EitherType, key : CryptoKey, data : haxe.extern.EitherType ) : Promise; - + /** Returns a `Promise` of the signature corresponding to the text, algorithm and key given as parameters. @throws DOMError **/ function sign( algorithm : haxe.extern.EitherType, key : CryptoKey, data : haxe.extern.EitherType ) : Promise; - + /** Returns a `Promise` of a `Boolean` value indicating if the signature given as parameter matches the text, algorithm and key also given as parameters. @throws DOMError **/ function verify( algorithm : haxe.extern.EitherType, key : CryptoKey, signature : haxe.extern.EitherType, data : haxe.extern.EitherType ) : Promise; - + /** Returns a `Promise` of a digest generated from the algorithm and text given as parameters. @throws DOMError **/ function digest( algorithm : haxe.extern.EitherType, data : haxe.extern.EitherType ) : Promise; - + /** Returns a `Promise` of a newly generated `CryptoKey`, for symmetrical algorithms, or a `CryptoKeyPair`, containing two newly generated keys, for asymmetrical algorithm, that matches the algorithm, the usages and the extractability given as parameters. @throws DOMError **/ @:overload( function( algorithm : String, extractable : Bool, keyUsages : Array) : Promise {} ) function generateKey( algorithm : Dynamic, extractable : Bool, keyUsages : Array ) : Promise; - + /** Returns a `Promise` of a newly generated `CryptoKey` derived from a master key and a specific algorithm given as parameters. @throws DOMError **/ function deriveKey( algorithm : haxe.extern.EitherType, baseKey : CryptoKey, derivedKeyType : haxe.extern.EitherType, extractable : Bool, keyUsages : Array ) : Promise; - + /** Returns a `Promise` of a newly generated buffer of pseudo-random bits derived from a master key and a specific algorithm given as parameters. @throws DOMError **/ @:overload( function( algorithm : String, baseKey : CryptoKey, length : Int) : Promise {} ) function deriveBits( algorithm : Dynamic, baseKey : CryptoKey, length : Int ) : Promise; - + /** Returns a `Promise` of a `CryptoKey` corresponding to the format, the algorithm, the raw key data, the usages and the extractability given as parameters. @throws DOMError **/ @:overload( function( format : String, keyData : Dynamic, algorithm : String, extractable : Bool, keyUsages : Array) : Promise {} ) function importKey( format : String, keyData : Dynamic, algorithm : Dynamic, extractable : Bool, keyUsages : Array ) : Promise; - + /** Returns a `Promise` of a buffer containing the key in the format requested. @throws DOMError **/ function exportKey( format : String, key : CryptoKey ) : Promise; - + /** Returns a `Promise` of a wrapped symmetric key for usage (transfer, storage) in insecure environments. The wrapped buffer returned is in the format given in parameters, and contains the key wrapped by the given wrapping key with the given algorithm. @throws DOMError **/ @:overload( function( format : String, key : CryptoKey, wrappingKey : CryptoKey, wrapAlgorithm : String) : Promise {} ) function wrapKey( format : String, key : CryptoKey, wrappingKey : CryptoKey, wrapAlgorithm : Dynamic ) : Promise; - + /** Returns a `Promise` of a `CryptoKey` corresponding to the wrapped key given in parameter. @throws DOMError diff --git a/std/js/html/Window.hx b/std/js/html/Window.hx index 4b8a6c37513..ded540ed9aa 100644 --- a/std/js/html/Window.hx +++ b/std/js/html/Window.hx @@ -24,6 +24,8 @@ package js.html; +import js.lib.Promise; + /** The `Window` interface represents a window containing a DOM document; the `document` property points to the DOM document loaded in that window. @@ -33,197 +35,197 @@ package js.html; **/ @:native("Window") extern class Window extends EventTarget { - + /** Returns a reference to the current window. **/ var window(default,null) : Window; - + /** Returns an object reference to the window object itself. **/ var self(default,null) : Window; - + /** Returns a reference to the document that the window contains. **/ var document(default,null) : HTMLDocument; - + /** Gets/sets the name of the window. **/ var name : String; - + /** Gets/sets the location, or current URL, of the window object. **/ var location(default,null) : Location; - + /** Returns a reference to the history object. **/ var history(default,null) : History; - + /** Returns the locationbar object, whose visibility can be toggled in the window. **/ var locationbar(default,null) : BarProp; - + /** Returns the menubar object, whose visibility can be toggled in the window. **/ var menubar(default,null) : BarProp; - + /** Returns the personalbar object, whose visibility can be toggled in the window. **/ var personalbar(default,null) : BarProp; - + /** Returns the scrollbars object, whose visibility can be toggled in the window. **/ var scrollbars(default,null) : BarProp; - + /** Returns the statusbar object, whose visibility can be toggled in the window. **/ var statusbar(default,null) : BarProp; - + /** Returns the toolbar object, whose visibility can be toggled in the window. **/ var toolbar(default,null) : BarProp; - + /** Gets/sets the text in the statusbar at the bottom of the browser. **/ var status : String; - + /** This property indicates whether the current window is closed or not. **/ var closed(default,null) : Bool; - + /** Returns the current event, which is the event currently being handled by the JavaScript code's context, or `undefined` if no event is currently being handled. The `Event` object passed directly to event handlers should be used instead whenever possible. **/ var event(default,null) : Dynamic; - + /** Returns an array of the subframes in the current window. **/ var frames(default,null) : Window; - + /** Returns the number of frames in the window. See also `window.frames`. **/ var length(default,null) : Int; - + /** Returns a reference to the topmost window in the window hierarchy. This property is read only. **/ var top(default,null) : Window; - + /** Returns a reference to the window that opened this current window. **/ var opener : Dynamic; - + /** Returns a reference to the parent of the current window or subframe. **/ var parent(default,null) : Window; - + /** Returns the element in which the window is embedded, or null if the window is not embedded. **/ var frameElement(default,null) : Element; - + /** Returns a reference to the navigator object. **/ var navigator(default,null) : Navigator; - + /** Returns a reference to the console object which provides access to the browser's debugging console. **/ var console(default,null) : ConsoleInstance; - + /** Returns a reference to the screen object associated with the window. **/ var screen(default,null) : Screen; - + /** Gets the width of the content area of the browser window including, if rendered, the vertical scrollbar. **/ var innerWidth : Dynamic; - + /** Gets the height of the content area of the browser window including, if rendered, the horizontal scrollbar. **/ var innerHeight : Dynamic; - + /** Returns the number of pixels that the document has already been scrolled horizontally. **/ var scrollX(default,null) : Float; - + /** An alias for `window.scrollX`. **/ var pageXOffset(default,null) : Float; - + /** Returns the number of pixels that the document has already been scrolled vertically. **/ var scrollY(default,null) : Float; - + /** An alias for `window.scrollY` **/ var pageYOffset(default,null) : Float; - + /** Returns the horizontal distance of the left border of the user's browser from the left side of the screen. **/ var screenX : Dynamic; - + /** Returns the vertical distance of the top border of the user's browser from the top side of the screen. **/ var screenY : Dynamic; - + /** Gets the width of the outside of the browser window. **/ var outerWidth : Dynamic; - + /** Gets the height of the outside of the browser window. **/ var outerHeight : Dynamic; - + /** Returns a `Performance` object, which includes the `Performance.timing` and `Performance.navigation` attributes, each of which is an object providing performance-related data. See also Using Navigation Timing for additional information and examples. **/ var performance(default,null) : Performance; - + /** Returns the ratio between physical pixels and device independent pixels in the current display. **/ var devicePixelRatio(default,null) : Float; - + /** The maximum offset that the window can be scrolled to horizontally, that is the document width minus the viewport width. **/ var scrollMaxX(default,null) : Int; - + /** The maximum offset that the window can be scrolled to vertically (i.e., the document height minus the viewport height). **/ var scrollMaxY(default,null) : Int; - + /** This property indicates whether the window is displayed in full screen or not. **/ @@ -234,18 +236,18 @@ extern class Window extends EventTarget { var ondeviceproximity : haxe.Constraints.Function; var onuserproximity : haxe.Constraints.Function; var ondevicelight : haxe.Constraints.Function; - + /** Returns a reference to the content element in the current window. Since Firefox 57 (initially Nightly-only), both versions are only available from chrome (privileged) code, and not available to the web anymore. **/ var content(default,null) : Dynamic; - + /** Returns the orientation in degrees (in 90 degree increments) of the viewport relative to the device's natural orientation. **/ var orientation(default,null) : Int; var onorientationchange : haxe.Constraints.Function; - + /** Returns the browser crypto object. **/ @@ -333,7 +335,7 @@ extern class Window extends EventTarget { var onwebkitanimationstart : haxe.Constraints.Function; var onwebkittransitionend : haxe.Constraints.Function; var onerror : haxe.extern.EitherType -> String -> Int -> Int -> Dynamic -> Dynamic; - + /** Returns a `SpeechSynthesis` object, which is the entry point into using Web Speech API speech synthesis functionality. **/ @@ -356,207 +358,207 @@ extern class Window extends EventTarget { var onpopstate : haxe.Constraints.Function; var onstorage : haxe.Constraints.Function; var onunload : haxe.Constraints.Function; - + /** Returns a reference to the local storage object used to store data that may only be accessed by the origin that created it. **/ var localStorage(default,null) : Storage; var origin(default,null) : String; - + /** Indicates whether a context is capable of using features that require secure contexts. **/ var isSecureContext(default,null) : Bool; var indexedDB(default,null) : js.html.idb.Factory; var caches(default,null) : CacheStorage; - + /** Returns a reference to the session storage object used to store data that may only be accessed by the origin that created it. **/ var sessionStorage(default,null) : Storage; - - + + /** Closes the current window. @throws DOMError **/ function close() : Void; - + /** This method stops window loading. @throws DOMError **/ function stop() : Void; - + /** Sets focus on the current window. @throws DOMError **/ function focus() : Void; - + /** Sets focus away from the window. @throws DOMError **/ function blur() : Void; - + /** Opens a new window. @throws DOMError **/ function open( url : String = "", target : String = "", features : String = "" ) : Window; - + /** Displays an alert dialog. @throws DOMError **/ @:overload( function() : Void {} ) function alert( message : String ) : Void; - + /** Displays a dialog with a message that the user needs to respond to. @throws DOMError **/ function confirm( message : String = "" ) : Bool; - + /** Returns the text entered by the user in a prompt dialog. @throws DOMError **/ function prompt( message : String = "", default_ : String = "" ) : String; - + /** Opens the Print Dialog to print the current document. @throws DOMError **/ function print() : Void; - + /** Provides a secure means for one window to send a string of data to another window, which need not be within the same domain as the first. @throws DOMError **/ function postMessage( message : Dynamic, targetOrigin : String, ?transfer : Array ) : Void; - + /** Registers the window to capture all events of the specified type. **/ function captureEvents() : Void; - + /** Releases the window from trapping events of a specific type. **/ function releaseEvents() : Void; - + /** Returns the selection object representing the selected item(s). @throws DOMError **/ function getSelection() : Selection; - + /** Gets computed style for the specified element. Computed style indicates the computed values of all CSS properties of the element. @throws DOMError **/ function getComputedStyle( elt : Element, pseudoElt : String = "" ) : CSSStyleDeclaration; - + /** Returns a `MediaQueryList` object representing the specified media query string. @throws DOMError **/ function matchMedia( query : String ) : MediaQueryList; - + /** Moves the window to the specified coordinates. @throws DOMError **/ function moveTo( x : Int, y : Int ) : Void; - + /** Moves the current window by a specified amount. @throws DOMError **/ function moveBy( x : Int, y : Int ) : Void; - + /** Dynamically resizes window. @throws DOMError **/ function resizeTo( x : Int, y : Int ) : Void; - + /** Resizes the current window by a certain amount. @throws DOMError **/ function resizeBy( x : Int, y : Int ) : Void; - + /** Scrolls the window to a particular place in the document. **/ @:overload( function( x : Float, y : Float ) : Void {} ) function scroll( ?options : ScrollToOptions ) : Void; - + /** Scrolls to a particular set of coordinates in the document. **/ @:overload( function( x : Float, y : Float ) : Void {} ) function scrollTo( ?options : ScrollToOptions ) : Void; - + /** Scrolls the document in the window by the given amount. **/ @:overload( function( x : Float, y : Float ) : Void {} ) function scrollBy( ?options : ScrollToOptions ) : Void; - + /** Tells the browser that an animation is in progress, requesting that the browser schedule a repaint of the window for the next animation frame. @throws DOMError **/ function requestAnimationFrame( callback : Float -> Void ) : Int; - + /** Enables you to cancel a callback previously scheduled with `Window.requestAnimationFrame`. @throws DOMError **/ function cancelAnimationFrame( handle : Int ) : Void; - + /** Gets default computed style for the specified element, ignoring author stylesheets. @throws DOMError **/ function getDefaultComputedStyle( elt : Element, pseudoElt : String = "" ) : CSSStyleDeclaration; - + /** Scrolls the document by the given number of lines. **/ function scrollByLines( numLines : Int, ?options : ScrollOptions ) : Void; - + /** Scrolls the current document by the specified number of pages. **/ function scrollByPages( numPages : Int, ?options : ScrollOptions ) : Void; - + /** Sizes the window according to its content. @throws DOMError **/ function sizeToContent() : Void; - + /** Updates the state of commands of the current chrome window (UI). **/ function updateCommands( action : String, ?sel : Selection, reason : Int = 0 ) : Void; - + /** Searches for a given string in a window. @throws DOMError **/ function find( str : String = "", caseSensitive : Bool = false, backwards : Bool = false, wrapAround : Bool = false, wholeWord : Bool = false, searchInFrames : Bool = false, showDialog : Bool = false ) : Bool; - + /** Writes a message to the console. **/ function dump( str : String ) : Void; - + /** Toggles a user's ability to resize a window. **/ diff --git a/std/js/html/eme/MediaKeySession.hx b/std/js/html/eme/MediaKeySession.hx index bcd3c612c06..ce8c74db453 100644 --- a/std/js/html/eme/MediaKeySession.hx +++ b/std/js/html/eme/MediaKeySession.hx @@ -24,6 +24,8 @@ package js.html.eme; +import js.lib.Promise; + /** The `MediaKeySession` interface of the EncryptedMediaExtensions API represents a context for message exchange with a content decryption module (CDM). @@ -34,62 +36,62 @@ package js.html.eme; @:native("MediaKeySession") extern class MediaKeySession extends js.html.EventTarget { var error(default,null) : MediaKeyError; - + /** Contains a unique string generated by the CDM for the current media object and its associated keys or licenses. **/ var sessionId(default,null) : String; - + /** The time after which the keys in the current session can no longer be used to decrypt media data, or `NaN` if no such time exists. This value is determined by the CDM and measured in milliseconds since January 1, 1970, UTC. This value may change during a session lifetime, such as when an action triggers the start of a window. **/ var expiration(default,null) : Float; - + /** Returns a `Promise` signaling when a `MediaKeySession` closes. This promise can only be fulfilled and is never rejected. Closing a session means that licenses and keys associated with it are no longer valid for decrypting media data.  **/ var closed(default,null) : Promise; - + /** Contains a reference to a read-only `MediaKeyStatusMap` of the current session's keys and their statuses. **/ var keyStatuses(default,null) : MediaKeyStatusMap; - + /** Sets the `EventHandler` called when there has been a change in the keys in a session or their statuses. **/ var onkeystatuseschange : haxe.Constraints.Function; - + /** Sets the `EventHandler` called when the content decryption module has generated a message for the session. **/ var onmessage : haxe.Constraints.Function; - - + + /** Returns a `Promise` after generating a media request based on initialization data. **/ @:overload( function( initDataType : String, initData : js.lib.ArrayBuffer) : Promise {} ) function generateRequest( initDataType : String, initData : js.lib.ArrayBufferView ) : Promise; - + /** Returns a `Promise` that resolves to a boolean value after loading data for a specified session object.  **/ function load( sessionId : String ) : Promise; - + /** Returns a `Promise` after loading messages and licenses to the CDM. **/ @:overload( function( response : js.lib.ArrayBuffer) : Promise {} ) function update( response : js.lib.ArrayBufferView ) : Promise; - + /** - + Returns a `Promise` after notifying the current media session is no longer needed and that the CDM should release any resources associated with this object and close it. - + **/ function close() : Promise; - + /** Returns a `Promise` after removing any session data associated with the current object. **/ diff --git a/std/js/html/eme/MediaKeySystemAccess.hx b/std/js/html/eme/MediaKeySystemAccess.hx index b81ee77f724..54b4910fbb9 100644 --- a/std/js/html/eme/MediaKeySystemAccess.hx +++ b/std/js/html/eme/MediaKeySystemAccess.hx @@ -24,6 +24,8 @@ package js.html.eme; +import js.lib.Promise; + /** The `MediaKeySystemAccess` interface of the EncryptedMediaExtensions API provides access to a Key System for decryption and/or a content protection provider. You can request an instance of this object using the `Navigator.requestMediaKeySystemAccess` method. @@ -33,18 +35,18 @@ package js.html.eme; **/ @:native("MediaKeySystemAccess") extern class MediaKeySystemAccess { - + /** Returns a `DOMString` identifying the key system being used. **/ var keySystem(default,null) : String; - - + + /** Returns a `MediaKeySystemConfiguration` object with the supported combination of configuration options. **/ function getConfiguration() : MediaKeySystemConfiguration; - + /** Returns a `Promise` that resolves to a new `MediaKeys` object. **/ diff --git a/std/js/html/eme/MediaKeys.hx b/std/js/html/eme/MediaKeys.hx index 6ad3546aec8..b6811483fc3 100644 --- a/std/js/html/eme/MediaKeys.hx +++ b/std/js/html/eme/MediaKeys.hx @@ -24,6 +24,8 @@ package js.html.eme; +import js.lib.Promise; + /** The `MediaKeys` interface of EncryptedMediaExtensions API the represents a set of keys that an associated `HTMLMediaElement` can use for decryption of media data during playback. @@ -34,14 +36,14 @@ package js.html.eme; @:native("MediaKeys") extern class MediaKeys { var keySystem(default,null) : String; - - + + /** Returns a new `MediaKeySession` object, which represents a context for message exchange with a content decryption module (CDM). @throws DOMError **/ function createSession( sessionType : MediaKeySessionType = TEMPORARY ) : MediaKeySession; - + /** Returns a `Promise` to a server certificate to be used to encrypt messages to the license server. **/ diff --git a/std/js/html/push/PushManager.hx b/std/js/html/push/PushManager.hx index c98a87faa3f..3a13e17c5cf 100644 --- a/std/js/html/push/PushManager.hx +++ b/std/js/html/push/PushManager.hx @@ -24,6 +24,8 @@ package js.html.push; +import js.lib.Promise; + /** The `PushManager` interface of the Push API provides a way to receive notifications from third-party servers as well as request URLs for push notifications. @@ -35,19 +37,19 @@ package js.html.push; extern class PushManager { /** @throws DOMError */ function new( scope : String ) : Void; - + /** Subscribes to a push service. It returns a `Promise` that resolves to a `PushSubscription` object containing details of a push subscription. A new push subscription is created if the current service worker does not have an existing subscription. @throws DOMError **/ function subscribe( ?options : PushSubscriptionOptionsInit ) : Promise; - + /** Retrieves an existing push subscription. It returns a `Promise` that resolves to a `PushSubscription` object containing details of an existing subscription. If no existing subscription exists, this resolves to a `null` value. @throws DOMError **/ function getSubscription() : Promise; - + /** Returns a `Promise` that resolves to the permission state of the current `PushManager`, which will be one of `'granted'`, `'denied'`, or `'prompt'`. @throws DOMError diff --git a/std/js/html/push/PushSubscription.hx b/std/js/html/push/PushSubscription.hx index b2e44bd768d..4893d414913 100644 --- a/std/js/html/push/PushSubscription.hx +++ b/std/js/html/push/PushSubscription.hx @@ -24,6 +24,8 @@ package js.html.push; +import js.lib.Promise; + /** The `PushSubscription` interface of the Push API provides a subcription's URL endpoint and allows unsubscription from a push service. @@ -33,32 +35,32 @@ package js.html.push; **/ @:native("PushSubscription") extern class PushSubscription { - + /** A `USVString` containing the endpoint associated with the push subscription. **/ var endpoint(default,null) : String; - + /** An object containing the options used to create the subscription. **/ var options(default,null) : PushSubscriptionOptions; - + /** @throws DOMError */ function new( initDict : PushSubscriptionInit ) : Void; - + /** Returns an `ArrayBuffer` which contains the client's public key, which can then be sent to a server and used in encrypting push message data. @throws DOMError **/ function getKey( name : PushEncryptionKeyName ) : js.lib.ArrayBuffer; - + /** Starts the asynchronous process of unsubscribing from the push service, returning a `Promise` that resolves to a `Boolean` when the current subscription is successfully unregistered. @throws DOMError **/ function unsubscribe() : Promise; - + /** Standard serializer — returns a JSON representation of the subscription properties. @throws DOMError diff --git a/std/js/lib/Date.hx b/std/js/lib/Date.hx index f6aaccf752c..0a4f0fefd33 100644 --- a/std/js/lib/Date.hx +++ b/std/js/lib/Date.hx @@ -35,14 +35,14 @@ extern class Date function new() : Void; /** - Cast Haxe's Date to js.Date. + Cast Haxe's Date to js.lib.Date. **/ - static public inline function fromHaxeDate(date:HaxeDate):js.Date { + static public inline function fromHaxeDate(date:HaxeDate):js.lib.Date { return cast date; } /** - Cast js.Date to Haxe's Date. + Cast js.lib.Date to Haxe's Date. **/ static public inline function toHaxeDate(date:Date):HaxeDate { return cast date; diff --git a/std/js/lib/Object.hx b/std/js/lib/Object.hx index 3a3b8e5e708..60b1a5fc8b9 100644 --- a/std/js/lib/Object.hx +++ b/std/js/lib/Object.hx @@ -24,7 +24,7 @@ package js.lib; import haxe.extern.Rest; import haxe.DynamicAccess; /** - The `js.Object` constructor creates an object wrapper. + The `js.lib.Object` constructor creates an object wrapper. Documentation [Object](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object) by [Mozilla Contributors](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object$history), licensed under [CC-BY-SA 2.5](https://creativecommons.org/licenses/by-sa/2.5/). **/ diff --git a/tests/server/src/Vfs.hx b/tests/server/src/Vfs.hx index ec9ff1c2756..5a83ee8f860 100644 --- a/tests/server/src/Vfs.hx +++ b/tests/server/src/Vfs.hx @@ -2,6 +2,8 @@ import js.node.Fs; import sys.FileSystem; import haxe.io.Path; +using DateTools; + class Vfs { var physicalPath:String; @@ -17,8 +19,8 @@ class Vfs { var path = getPhysicalPath(path); FileSystem.createDirectory(path.dir); var file = Fs.openSync(path.dir + "/" + path.file + "." + path.ext, 'a'); - var last = Date.fromString(Fs.fstatSync(file).mtime.toTimeString().substr(0, 8)); - var notNow = js.Date.fromHaxeDate(DateTools.delta(last, 1000)); + var last = Date.fromString(Fs.fstatSync(file).mtime.format("%T")); + var notNow = last.delta(1000); Fs.futimesSync(file, notNow, notNow); Fs.closeSync(file); } diff --git a/tests/unit/src/unit/issues/Issue3499.hx b/tests/unit/src/unit/issues/Issue3499.hx index 90e7e9a13f8..9e2078205e9 100644 --- a/tests/unit/src/unit/issues/Issue3499.hx +++ b/tests/unit/src/unit/issues/Issue3499.hx @@ -2,7 +2,7 @@ package unit.issues; #if js -private typedef PathSimple = haxe.extern.EitherType; +private typedef PathSimple = haxe.extern.EitherType; private typedef Path = haxe.extern.EitherType>; #end @@ -10,7 +10,7 @@ private typedef Path = haxe.extern.EitherType>; class Issue3499 extends Test { #if js function test() { - var a:Path = ["", new js.RegExp("")]; + var a:Path = ["", new js.lib.RegExp("")]; eq("", a[0]); } #end diff --git a/tests/unit/src/unit/issues/Issue4644.hx b/tests/unit/src/unit/issues/Issue4644.hx index f7efa705303..7f707640e75 100644 --- a/tests/unit/src/unit/issues/Issue4644.hx +++ b/tests/unit/src/unit/issues/Issue4644.hx @@ -10,7 +10,7 @@ class Issue4644 extends Test { }} catch (e) {{ {1} = (e instanceof {2}); }}", - throw (new js.Error() : Dynamic), + throw (new js.lib.Error() : Dynamic), isHaxeError, #if js_unflatten __js__("js._Boot.HaxeError")