forked from LeenkxTeam/LNXSDK
		
	
		
			
				
	
	
		
			318 lines
		
	
	
		
			9.1 KiB
		
	
	
	
		
			Haxe
		
	
	
	
	
	
			
		
		
	
	
			318 lines
		
	
	
		
			9.1 KiB
		
	
	
	
		
			Haxe
		
	
	
	
	
	
| /*
 | |
|  * 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 cs.internal;
 | |
| 
 | |
| import cs.system.Type;
 | |
| import haxe.ds.Vector;
 | |
| import cs.internal.FieldLookup;
 | |
| 
 | |
| private typedef StdType = std.Type;
 | |
| 
 | |
| @:keep @:native('haxe.lang.HxObject')
 | |
| class HxObject implements IHxObject {
 | |
| 	public function __hx_deleteField(field:String, hash:Int):Bool {
 | |
| 		return false;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| @:keep @:native('haxe.lang.IHxObject')
 | |
| interface IHxObject {}
 | |
| 
 | |
| #if core_api_serialize
 | |
| @:meta(System.Serializable)
 | |
| #end
 | |
| @:keep @:native('haxe.lang.DynamicObject')
 | |
| class DynamicObject extends HxObject {
 | |
| 	@:skipReflection var __hx_hashes:NativeArray<Int>;
 | |
| 	@:skipReflection var __hx_dynamics:NativeArray<Dynamic>;
 | |
| 
 | |
| 	@:skipReflection var __hx_hashes_f:NativeArray<Int>;
 | |
| 	@:skipReflection var __hx_dynamics_f:NativeArray<Float>;
 | |
| 
 | |
| 	@:skipReflection var __hx_length:Int;
 | |
| 	@:skipReflection var __hx_length_f:Int;
 | |
| 	@:skipReflection var __hx_conflicts:FieldHashConflict;
 | |
| 
 | |
| 	@:skipReflection static var __hx_toString_depth = 0;
 | |
| 
 | |
| 	@:overload public function new() {
 | |
| 		this.__hx_hashes = new NativeArray(0);
 | |
| 		this.__hx_dynamics = new NativeArray(0);
 | |
| 		this.__hx_hashes_f = new NativeArray(0);
 | |
| 		this.__hx_dynamics_f = new NativeArray(0);
 | |
| 		this.__hx_conflicts = null;
 | |
| 	}
 | |
| 
 | |
| 	@:overload public function new(hashes:NativeArray<Int>, dynamics:NativeArray<Dynamic>, hashes_f:NativeArray<Int>, dynamics_f:NativeArray<Float>) {
 | |
| 		this.__hx_hashes = hashes;
 | |
| 		this.__hx_dynamics = dynamics;
 | |
| 		this.__hx_hashes_f = hashes_f;
 | |
| 		this.__hx_dynamics_f = dynamics_f;
 | |
| 		this.__hx_length = hashes.length;
 | |
| 		this.__hx_length_f = hashes_f.length;
 | |
| 		this.__hx_conflicts = null;
 | |
| 	}
 | |
| 
 | |
| 	override public function __hx_deleteField(field:String, hash:Int):Bool {
 | |
| 		if (hash < 0) {
 | |
| 			return FieldLookup.deleteHashConflict(this.__hx_conflicts, hash, field);
 | |
| 		}
 | |
| 
 | |
| 		var res = FieldLookup.findHash(hash, this.__hx_hashes, this.__hx_length);
 | |
| 		if (res >= 0) {
 | |
| 			FieldLookup.removeInt(this.__hx_hashes, this.__hx_length, res);
 | |
| 			FieldLookup.removeDynamic(this.__hx_dynamics, this.__hx_length, res);
 | |
| 			this.__hx_length--;
 | |
| 			return true;
 | |
| 		}
 | |
| 		res = FieldLookup.findHash(hash, this.__hx_hashes_f, this.__hx_length_f);
 | |
| 		if (res >= 0) {
 | |
| 			FieldLookup.removeInt(this.__hx_hashes_f, this.__hx_length_f, res);
 | |
| 			FieldLookup.removeFloat(this.__hx_dynamics_f, this.__hx_length_f, res);
 | |
| 			this.__hx_length_f--;
 | |
| 			return true;
 | |
| 		}
 | |
| 		return false;
 | |
| 	}
 | |
| 
 | |
| 	public function __hx_getField(field:String, hash:Int, throwErrors:Bool, isCheck:Bool, handleProperties:Bool):Dynamic {
 | |
| 		if (hash < 0) {
 | |
| 			var conflict = FieldLookup.getHashConflict(this.__hx_conflicts, hash, field);
 | |
| 			if (conflict != null) {
 | |
| 				return conflict.value;
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		var res = FieldLookup.findHash(hash, this.__hx_hashes, this.__hx_length);
 | |
| 		if (res >= 0) {
 | |
| 			return this.__hx_dynamics[res];
 | |
| 		}
 | |
| 		res = FieldLookup.findHash(hash, this.__hx_hashes_f, this.__hx_length_f);
 | |
| 		if (res >= 0) {
 | |
| 			return this.__hx_dynamics_f[res];
 | |
| 		}
 | |
| 
 | |
| 		return isCheck ? Runtime.undefined : null;
 | |
| 	}
 | |
| 
 | |
| 	public function __hx_setField(field:String, hash:Int, value:Dynamic, handleProperties:Bool):Dynamic {
 | |
| 		if (hash < 0) {
 | |
| 			FieldLookup.setHashConflict(this.__hx_conflicts, hash, field, value);
 | |
| 			return value;
 | |
| 		}
 | |
| 
 | |
| 		var res = FieldLookup.findHash(hash, this.__hx_hashes, this.__hx_length);
 | |
| 		if (res >= 0) {
 | |
| 			return this.__hx_dynamics[res] = value;
 | |
| 		} else {
 | |
| 			var res = FieldLookup.findHash(hash, this.__hx_hashes_f, this.__hx_length_f);
 | |
| 			if (res >= 0) {
 | |
| 				if (Std.isOfType(value, Float)) {
 | |
| 					return this.__hx_dynamics_f[res] = value;
 | |
| 				}
 | |
| 
 | |
| 				FieldLookup.removeInt(this.__hx_hashes_f, this.__hx_length_f, res);
 | |
| 				FieldLookup.removeFloat(this.__hx_dynamics_f, this.__hx_length_f, res);
 | |
| 				this.__hx_length_f--;
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		this.__hx_hashes = FieldLookup.insertInt(this.__hx_hashes, this.__hx_length, ~(res), hash);
 | |
| 		this.__hx_dynamics = FieldLookup.insertDynamic(this.__hx_dynamics, this.__hx_length, ~(res), value);
 | |
| 		this.__hx_length++;
 | |
| 		return value;
 | |
| 	}
 | |
| 
 | |
| 	public function __hx_getField_f(field:String, hash:Int, throwErrors:Bool, handleProperties:Bool):Float {
 | |
| 		if (hash < 0) {
 | |
| 			var conflict = FieldLookup.getHashConflict(this.__hx_conflicts, hash, field);
 | |
| 			if (conflict != null) {
 | |
| 				return conflict.value;
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		var res = FieldLookup.findHash(hash, this.__hx_hashes_f, this.__hx_length_f);
 | |
| 		if (res >= 0) {
 | |
| 			return this.__hx_dynamics_f[res];
 | |
| 		}
 | |
| 		res = FieldLookup.findHash(hash, this.__hx_hashes, this.__hx_length);
 | |
| 		if (res >= 0) {
 | |
| 			return this.__hx_dynamics[res];
 | |
| 		}
 | |
| 
 | |
| 		return 0.0;
 | |
| 	}
 | |
| 
 | |
| 	public function __hx_setField_f(field:String, hash:Int, value:Float, handleProperties:Bool):Float {
 | |
| 		if (hash < 0) {
 | |
| 			FieldLookup.setHashConflict(this.__hx_conflicts, hash, field, value);
 | |
| 			return value;
 | |
| 		}
 | |
| 
 | |
| 		var res = FieldLookup.findHash(hash, this.__hx_hashes_f, this.__hx_length_f);
 | |
| 		if (res >= 0) {
 | |
| 			return this.__hx_dynamics_f[res] = value;
 | |
| 		} else {
 | |
| 			var res = FieldLookup.findHash(hash, this.__hx_hashes, this.__hx_length);
 | |
| 			if (res >= 0) {
 | |
| 				// return this.__hx_dynamics[res] = value;
 | |
| 				FieldLookup.removeInt(this.__hx_hashes, this.__hx_length, res);
 | |
| 				FieldLookup.removeDynamic(this.__hx_dynamics, this.__hx_length, res);
 | |
| 				this.__hx_length--;
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		this.__hx_hashes_f = FieldLookup.insertInt(this.__hx_hashes_f, this.__hx_length_f, ~(res), hash);
 | |
| 		this.__hx_dynamics_f = FieldLookup.insertFloat(this.__hx_dynamics_f, this.__hx_length_f, ~(res), value);
 | |
| 		this.__hx_length_f++;
 | |
| 		return value;
 | |
| 	}
 | |
| 
 | |
| 	public function __hx_getFields(baseArr:Array<String>):Void {
 | |
| 		for (i in 0...this.__hx_length) {
 | |
| 			baseArr.push(FieldLookup.lookupHash(this.__hx_hashes[i]));
 | |
| 		}
 | |
| 		for (i in 0...this.__hx_length_f) {
 | |
| 			baseArr.push(FieldLookup.lookupHash(this.__hx_hashes_f[i]));
 | |
| 		}
 | |
| 		FieldLookup.addHashConflictNames(this.__hx_conflicts, baseArr);
 | |
| 	}
 | |
| 
 | |
| 	public function __hx_invokeField(field:String, hash:Int, dynargs:NativeArray<Dynamic>):Dynamic {
 | |
| 		if (field == "toString") {
 | |
| 			return this.toString();
 | |
| 		}
 | |
| 		var fn:Function = this.__hx_getField(field, hash, false, false, false);
 | |
| 		if (fn == null) {
 | |
| 			throw 'Cannot invoke field $field: It does not exist';
 | |
| 		}
 | |
| 
 | |
| 		return untyped fn.__hx_invokeDynamic(dynargs);
 | |
| 	}
 | |
| 
 | |
| 	@:skipReflection public function toString() {
 | |
| 		if (__hx_toString_depth >= 5) {
 | |
| 			return "...";
 | |
| 		}
 | |
| 		++__hx_toString_depth;
 | |
| 		try {
 | |
| 			var s = __hx_toString();
 | |
| 			--__hx_toString_depth;
 | |
| 			return s;
 | |
| 		} catch (e:Dynamic) {
 | |
| 			--__hx_toString_depth;
 | |
| 			throw(e);
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	@:skipReflection public function __hx_toString():String {
 | |
| 		var ts = Reflect.field(this, "toString");
 | |
| 		if (ts != null)
 | |
| 			return ts();
 | |
| 		var ret = new StringBuf();
 | |
| 		ret.add("{");
 | |
| 		var first = true;
 | |
| 		for (f in Reflect.fields(this)) {
 | |
| 			if (first)
 | |
| 				first = false;
 | |
| 			else
 | |
| 				ret.add(",");
 | |
| 			ret.add(" ");
 | |
| 			ret.add(f);
 | |
| 			ret.add(" : ");
 | |
| 			ret.add(Reflect.field(this, f));
 | |
| 		}
 | |
| 		if (!first)
 | |
| 			ret.add(" ");
 | |
| 		ret.add("}");
 | |
| 		return ret.toString();
 | |
| 	}
 | |
| }
 | |
| 
 | |
| #if !erase_generics
 | |
| @:keep @:native('haxe.lang.IGenericObject') interface IGenericObject {}
 | |
| 
 | |
| @:nativeGen @:keep @:native('haxe.lang.GenericInterface') class GenericInterface extends cs.system.Attribute {
 | |
| 	@:readOnly public var generic(default, never):cs.system.Type;
 | |
| 
 | |
| 	public function new(generic) {
 | |
| 		super();
 | |
| 		untyped this.generic = generic;
 | |
| 	}
 | |
| }
 | |
| #end
 | |
| 
 | |
| @:keep
 | |
| @:native('haxe.lang.Enum')
 | |
| @:nativeGen
 | |
| #if core_api_serialize
 | |
| @:meta(System.Serializable)
 | |
| #end
 | |
| class HxEnum {
 | |
| 	@:readOnly var _hx_index(default, never):Int;
 | |
| 
 | |
| 	@:protected function new(index:Int) {
 | |
| 		untyped this._hx_index = index;
 | |
| 	}
 | |
| 
 | |
| 	public function getTag():String {
 | |
| 		return throw new haxe.exceptions.NotImplementedException();
 | |
| 	}
 | |
| 
 | |
| 	public function getParams():Array<{}> {
 | |
| 		return [];
 | |
| 	}
 | |
| 
 | |
| 	public function toString():String {
 | |
| 		return getTag();
 | |
| 	}
 | |
| 
 | |
| 	@:protected static function paramsToString(tag:String, params:Vector<Dynamic>):String {
 | |
| 		var ret = new StringBuf();
 | |
| 		ret.add(tag);
 | |
| 		ret.add("(");
 | |
| 		var first = true;
 | |
| 		for (p in params) {
 | |
| 			if (first)
 | |
| 				first = false;
 | |
| 			else
 | |
| 				ret.add(",");
 | |
| 			ret.add(p);
 | |
| 		}
 | |
| 		ret.add(")");
 | |
| 		return ret.toString();
 | |
| 	}
 | |
| 
 | |
| 	@:protected static function paramsGetHashCode(index:Int, params:Vector<Dynamic>):Int {
 | |
| 		var h:Int = 19;
 | |
| 		if (params != null)
 | |
| 			for (p in params) {
 | |
| 				h = h * 31;
 | |
| 				if (p != null)
 | |
| 					untyped h += p.GetHashCode();
 | |
| 			}
 | |
| 		h += index;
 | |
| 		return h;
 | |
| 	}
 | |
| }
 |