| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186 | /* * 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 php;import haxe.ds.StringMap;import php.*;import php.reflection.ReflectionClass;/**	Platform-specific PHP Library. Provides some platform-specific functions	for the PHP target, such as conversion from Haxe types to native types	and vice-versa.**/class Lib {	/**		Print the specified value on the default output.	**/	public static inline function print( v : Dynamic ) : Void {		Global.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");	}	/**		Displays structured information about one or more expressions		that includes its type and value. Arrays and objects are		explored recursively with values indented to show structure.	*/	public static inline function dump(v : Dynamic) : Void {		Global.var_dump(v);	}	/**		Serialize using native PHP serialization. This will return a binary		`String` that can be stored for long term usage.	**/	public static inline function serialize( v : Dynamic ) : String {		return Global.serialize(v);	}	/**		Unserialize a `String` using native PHP serialization. See `php.Lib.serialize()`.	**/	public static inline function unserialize( s : String ) : Dynamic {		return Global.unserialize(s);	}	/**		Find out whether an extension is loaded.	*/	public static inline function extensionLoaded(name : String) {		return Global.extension_loaded(name);	}	public static inline function isCli() : Bool {		return 0 == Global.strncasecmp(Const.PHP_SAPI, 'cli', 3);	}	/**		Output file content from the given file name.	*/	public static inline function printFile(file : String) {		return Global.fpassthru(Global.fopen(file,  "r"));	}	public static inline function toPhpArray(a : Array<Dynamic>) : NativeArray {		return @:privateAccess a.arr;	}	public static inline function toHaxeArray(a : NativeArray) : Array<Dynamic> {		return @:privateAccess Array.wrap(a);	}	public static function hashOfAssociativeArray<T>(arr : NativeAssocArray<T>) : Map<String,T> {		var result = new StringMap();		@:privateAccess result.data = arr;		return result;	}	public static inline function associativeArrayOfHash(hash : haxe.ds.StringMap<Dynamic>) : NativeArray {		return @:privateAccess hash.data;	}	public static function objectOfAssociativeArray(arr : NativeArray) : Dynamic {		Syntax.foreach(arr, function(key:Scalar, value:Dynamic) {			if(Global.is_array(value)) {				arr[key] = objectOfAssociativeArray(value);			}		});		return Boot.createAnon(arr);	}	public static inline function associativeArrayOfObject(ob : Dynamic) : NativeArray {		return Syntax.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 inline function mail(to : String, subject : String, message : String, ?additionalHeaders : String, ?additionalParameters : String) : Bool {		return Global.mail(to, subject, message, additionalHeaders, additionalParameters);	}	/**		For neko compatibility only.	**/	public static inline function rethrow( e : Dynamic ) {		throw e;	}	/**		Tries to load all compiled php files and returns list of types.	**/	public static function getClasses():Dynamic {		if(!loaded) {			loaded = true;			var reflection = new ReflectionClass(Boot.getPhpName('php.Boot'));			loadLib(Global.dirname(reflection.getFileName(), 2));		}		var result:Dynamic = {};		Syntax.foreach(Boot.getRegisteredAliases(), function(phpName:String, haxeName:String) {			var parts = haxeName.split('.');			var obj = result;			while(parts.length > 1) {				var pack = parts.shift();				if(Syntax.field(obj, pack) == null) {					Syntax.setField(obj, pack, {});				}				obj = Syntax.field(obj, pack);			}			Syntax.setField(obj, parts[0], Boot.getClass(phpName));		});		return result;	}	static var loaded:Bool = false;	/**		Loads types defined in the specified directory.	**/	public static function loadLib(pathToLib : String) : Void {		var absolutePath = Global.realpath(pathToLib);		if(absolutePath == false) throw 'Failed to read path: $pathToLib';		Syntax.foreach(Global.glob('$absolutePath/*.php'), function(_, fileName) {			if(!Global.is_dir(fileName)) {				Global.require_once(fileName);			}		});		Syntax.foreach(Global.glob('$absolutePath/*', Const.GLOB_ONLYDIR), function(_, dirName) {			loadLib(dirName);		});	}}
 |