| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 | /* * 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. */@:core_api class Math{	public static var PI(default,null) : Float;	public static var NaN(default,null) : Float;	public static var POSITIVE_INFINITY(default,null) : Float;	public static var NEGATIVE_INFINITY(default,null) : Float;	public static function abs(v : Float) : Float      { return untyped __call__("abs", v); }	public static function min(a : Float,b : Float) : Float    { return untyped __call__("min", a, b); }	public static function max(a : Float,b : Float) : Float    { return untyped __call__("max", a, b); }	public static function sin(v : Float) : Float      { return untyped __call__("sin", v); }	public static function cos(v : Float) : Float      { return untyped __call__("cos", v); }	public static function atan2(y : Float,x : Float) : Float  { return untyped __call__("atan2", y, x); }	public static function tan(v : Float) : Float      { return untyped __call__("tan", v); }	public static function exp(v : Float) : Float      { return untyped __call__("exp", v); }	public static function log(v : Float) : Float      { return untyped __call__("log", v); }	public static function sqrt(v : Float) : Float     { return untyped __call__("sqrt", v); }	public static function round(v : Float) : Int      { return untyped __call__("(int) floor", v + 0.5); }	public static function floor(v : Float) : Int      { return untyped __call__("(int) floor", v); }	public static function ceil(v : Float) : Int       { return untyped __call__("(int) ceil", v); }	public static function atan(v : Float) : Float     { return untyped __call__("atan", v); }	public static function asin(v : Float) : Float     { return untyped __call__("asin", v); }	public static function acos(v : Float) : Float     { return untyped __call__("acos", v); }	public static function pow(v : Float,exp : Float) : Float    { return untyped __call__("pow", v, exp); }	public static function random() : Float    { return untyped __call__("mt_rand") / __call__("mt_getrandmax"); }	public static function isNaN(f : Float) : Bool     { return untyped __call__("is_nan", f); }	public static function isFinite(f : Float) : Bool  { return untyped __call__("is_finite", f); }	static function __init__() : Void {	 	PI = untyped __php__("M_PI");	 	NaN = untyped __php__("acos(1.01)");	 	NEGATIVE_INFINITY = untyped __php__("log(0)");	 	POSITIVE_INFINITY = -NEGATIVE_INFINITY;	}}
 |