| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182 | /* * Copyright (C)2005-2012 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 php;class Lib {	/**		Print the specified value on the default output.	**/	public static function print( v : Dynamic ) : Void {		untyped __call__("echo", Std.string(v));	}	/**		Print the specified value on the default output followed by a newline character.	**/	public static function println( v : Dynamic ) : Void {		print(v);		print("\n");	}	public static function dump(v : Dynamic) : Void {		untyped __call__("var_dump", v);	}	/**		Serialize using native PHP serialization. This will return a Binary string that can be		stored for long term usage.	**/	public static function serialize( v : Dynamic ) : String {		return untyped __call__("serialize", v);	}	/**		Unserialize a string using native PHP serialization. See [serialize].	**/	public static function unserialize( s : String ) : Dynamic {		return untyped __call__("unserialize", s);	}	public static function extensionLoaded(name : String) {		return untyped __call__("extension_loaded", name);	}	public static function isCli() : Bool {		return untyped __php__("(0 == strncasecmp(PHP_SAPI, 'cli', 3))");	}	public static function printFile(file : String) {		return untyped __call__("fpassthru", __call__("fopen", file,  "r"));	}	public static function toPhpArray(a : Array<Dynamic>) : NativeArray {		return untyped __field__(a, 'a');	}	public static inline function toHaxeArray(a : NativeArray) : Array<Dynamic> {		return untyped __call__("new _hx_array", a);	}	public static function hashOfAssociativeArray<T>(arr : NativeArray) : haxe.ds.StringMap<T> {		var h = new haxe.ds.StringMap<T>();		untyped h.h = arr;		return h;	}	public static function associativeArrayOfHash(hash : haxe.ds.StringMap<Dynamic>) : NativeArray {		return untyped hash.h;	}	public static function objectOfAssociativeArray(arr : NativeArray) : Dynamic {		untyped __php__("foreach($arr as $key => $value){			if(is_array($value)) $arr[$key] = php_Lib::objectOfAssociativeArray($value);		}");		return untyped __call__("_hx_anonymous", arr);	}	public static function associativeArrayOfObject(ob : Dynamic) : NativeArray {		return untyped __php__("(array) $ob");	}	/**	 * See the documentation for the equivalent PHP function for details on usage:	 * http://php.net/manual/en/function.mail.php	 * @param	to	 * @param	subject	 * @param	message	 * @param	?additionalHeaders	 * @param	?additionalParameters	 */	public static function mail(to : String, subject : String, message : String, ?additionalHeaders : String, ?additionalParameters : String) : Bool	{		if(null != additionalParameters)			return untyped __call__("mail", to, subject, message, additionalHeaders, additionalParameters);		else if(null != additionalHeaders)			return untyped __call__("mail", to, subject, message, additionalHeaders);		else			return untyped __call__("mail", to, subject, message);	}	/**		For neko compatibility only.	**/	public static function rethrow( e : Dynamic ) {		if(Std.is(e, Exception)) {			var __rtex__ = e;			untyped __php__("throw $__rtex__");		}		else throw e;	}	static function appendType(o : Dynamic, path : Array<String>, t : Dynamic) {		var name = path.shift();		if(path.length == 0)			untyped __php__("$o->$name = $t");		else {			var so = untyped __call__("isset", __php__("$o->$name")) ? __php__("$o->$name") : {};			appendType(so, path, t);			untyped __php__("$o->$name = $so");		}	}	public static function getClasses() {		var path : String = null;		var o = {};		untyped __call__('reset', php.Boot.qtypes);		while((path = untyped __call__('key', php.Boot.qtypes)) != null) {			appendType(o, path.split('.'), untyped php.Boot.qtypes[path]);			untyped __call__('next',php.Boot.qtypes);		}		return o;	}	/**	*  Loads types defined in the specified directory. 	*/ 	public static function loadLib(pathToLib : String) : Void 	{		var prefix = untyped __prefix__();		untyped __php__("$_hx_types_array = array(); 		$_hx_cache_content = ''; 		//Calling this function will put all types present in the specified types in the $_hx_types_array 		_hx_build_paths($pathToLib, $_hx_types_array, array(), $prefix); 		for($i=0;$i<count($_hx_types_array);$i++) { 			//For every type that has been found, create its description 			$t = null; 			if($_hx_types_array[$i]['type'] == 0) { 				$t = new _hx_class($_hx_types_array[$i]['phpname'], $_hx_types_array[$i]['qname'], $_hx_types_array[$i]['path']); 			} else if($_hx_types_array[$i]['type'] == 1) { 				$t = new _hx_enum($_hx_types_array[$i]['phpname'], $_hx_types_array[$i]['qname'], $_hx_types_array[$i]['path']); 			} else if($_hx_types_array[$i]['type'] == 2) { 				$t = new _hx_interface($_hx_types_array[$i]['phpname'], $_hx_types_array[$i]['qname'], $_hx_types_array[$i]['path']); 			} else if($_hx_types_array[$i]['type'] == 3) { 				$t = new _hx_class($_hx_types_array[$i]['name'], $_hx_types_array[$i]['qname'], $_hx_types_array[$i]['path']); 			} 			//Register the type 			if(!array_key_exists($t->__qname__, php_Boot::$qtypes)) { 				_hx_register_type($t); 			} 		} "); 	}}
 |