| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243 | /* * Copyright (c) 2005, The haXe Project Contributors * All rights reserved. * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * *   - Redistributions of source code must retain the above copyright *     notice, this list of conditions and the following disclaimer. *   - Redistributions in binary form must reproduce the above copyright *     notice, this list of conditions and the following disclaimer in the *     documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE HAXE PROJECT CONTRIBUTORS "AS IS" AND ANY * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL THE HAXE PROJECT CONTRIBUTORS BE LIABLE FOR * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH * DAMAGE. */import java.Boot;import java.Lib;import haxe.lang.Exceptions; @:core_api @:nativegen class Std {	public static function is( v : Dynamic, t : Dynamic ) : Bool 	{		if (v == null) 			return v == t;		var clt:Class<Dynamic> = cast t;		if (clt == null)			return false;		var name = untyped __java__("clt.getName()");				switch(name)		{			case "double", "java.lang.Double":				return untyped __java__('haxe.lang.Runtime.isDouble(v)');			case "int", "java.lang.Integer":				return untyped __java__('haxe.lang.Runtime.isInt(v)');			case "boolean", "java.lang.Boolean":				return untyped __java__('v instanceof java.lang.Boolean');		}				var clv:Class<Dynamic> = untyped __java__('v.getClass()');				return untyped clt.isAssignableFrom(clv);	}	public static inline function string( s : Dynamic ) : String {		return cast s;	}	public static inline function int( x : Float ) : Int {		return cast x;	}		@:functionBody('		if (x == null) return null;				int ret = 0;		int base = 10;				if (x.startsWith("0x"))		{			x = x.substring(2);			base = 16;		}				int len = x.length();		boolean foundAny = false;		boolean isNeg = false;		for (int i = 0; i < len; i++)		{			char c = x.charAt(i);			if (!foundAny) 			{				switch(c)				{					case \'-\':						isNeg = true;						continue;					case \'\\n\': 					case \'\\t\': 					case \'\\r\': 					case \' \': 						if (isNeg) return null;						continue;				}			}						if (c >= \'0\' && c <= \'9\')			{				if (!foundAny && c == \'0\')				{					foundAny = true;					continue;				}				ret *= base; foundAny = true;								ret += ((int) (c - \'0\'));			} else if (base == 16) {				if (c >= \'a\' && c <= \'f\') {					ret *= base; foundAny = true;					ret += ((int) (c - \'a\')) + 10;				} else if (c >= \'A\' && c <= \'F\') {					ret *= base; foundAny = true;					ret += ((int) (c - \'A\')) + 10;				} else {					break;				}			} else {				break;			}		}				if (foundAny)			return isNeg ? -ret : ret;		else			return null;	')	public static function parseInt( x : String ) : Null<Int> {		return null;	}		@:functionBody('		if (x == null) return java.lang.Double.NaN;				x = x.trim();		double ret = 0.0;		double div = 0.0;		double e = 0.0;				int len = x.length();		boolean foundAny = false;		boolean isNeg = false;		for (int i = 0; i < len; i++)		{			char c = x.charAt(i);			if (!foundAny) 			{				switch(c)				{					case \'-\':						isNeg = true;						continue;					case \'\\n\': 					case \'\\t\': 					case \'\\r\': 					case \' \': 					if (isNeg) return java.lang.Double.NaN;						continue;				}			}						if (c == \'.\') {				if (div != 0.0) 					break;				div = 1.0;								continue;			}						if (c >= \'0\' && c <= \'9\')			{				if (!foundAny && c == \'0\')				{					foundAny = true;					continue;				}				ret *= 10.0; foundAny = true; div *= 10.0;								ret += ((int) (c - \'0\'));			} else if (foundAny && c == \'E\' || c == \'e\') {				boolean eNeg = false;				boolean eFoundAny = false;								char next = x.charAt(i + 1);				if (i + 1 < len)				{					if (next == \'-\')					{						eNeg = true;						i++;					} else if (next == \'+\') {						i++;					}				}								while (++i < len)				{					c = x.charAt(i);					if (c >= \'0\' && c <= \'9\')					{						if (!eFoundAny && c == \'0\')							continue;						eFoundAny = true;						e *= 10.0;						e += ((int) (c - \'0\'));					} else {						break;					}				}								if (eNeg) e = -e;			} else {				break;			}		}				if (div == 0.0) div = 1.0;				if (foundAny)		{			ret = isNeg ? -(ret / div) : (ret / div);			if (e != 0.0)			{				return ret * Math.pow(10.0, e);			} else {				return ret;			}		} else {			return java.lang.Double.NaN;		}	')	public static function parseFloat( x : String ) : Float {		return 0.0;	}	public static function random( x : Int ) : Int {		return Std.int(Math.random() * x);	}	@:macro public static function format( fmt : haxe.macro.Expr.ExprRequire<String> ) : haxe.macro.Expr.ExprRequire<String> {		return haxe.macro.Format.format(fmt);	}}	
 |