| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253 | /* * 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 java.internal;import java.internal.Function;private typedef NativeString = String;@:keep @:nativeGen @:native("haxe.lang.StringExt") private class StringExt {	@:functionCode('			if ( index >= me.length() || index < 0 )				return "";			else				return java.lang.Character.toString(me.charAt(index));	')	public static function charAt(me:NativeString, index:Int):NativeString {		return null;	}	@:functionCode('			if ( index >= me.length() || index < 0 )				return null;			else				return (int) me.charAt(index);	')	public static function charCodeAt(me:NativeString, index:Int):Null<Int> {		return null;	}	@:functionCode('			int sIndex = (startIndex != null ) ? (haxe.lang.Runtime.toInt(startIndex)) : 0;			if(str == "") {				int length = me.length();				if(sIndex < 0) {					sIndex = length + sIndex;					if(sIndex < 0) sIndex = 0;				}				return sIndex > length ? length : sIndex;			}			if (sIndex >= me.length() || sIndex < 0)				return -1;			return me.indexOf(str, sIndex);	')	public static function indexOf(me:NativeString, str:NativeString, ?startIndex:Int):Int {		return -1;	}	@:functionCode('			int sIndex = (startIndex != null ) ? (haxe.lang.Runtime.toInt(startIndex)) : (me.length() - 1);			if (sIndex > me.length() || sIndex < 0)				sIndex = me.length() - 1;			else if (sIndex < 0)				return -1;			if (str.length() == 0) {				return startIndex == null || haxe.lang.Runtime.toInt(startIndex) > me.length() ? me.length() : haxe.lang.Runtime.toInt(startIndex);			}			return me.lastIndexOf(str, sIndex);	')	public static function lastIndexOf(me:NativeString, str:NativeString, ?startIndex:Int):Int {		return -1;	}	@:functionCode('			Array<java.lang.String> ret = new Array<java.lang.String>();			int slen = delimiter.length();			if (slen == 0)			{				int len = me.length();				for (int i = 0; i < len; i++)				{					ret.push(me.substring(i, i + 1));				}			} else {				int start = 0;				int pos = me.indexOf(delimiter, start);				while (pos >= 0)				{					ret.push(me.substring(start, pos));					start = pos + slen;					pos = me.indexOf(delimiter, start);				}				ret.push(me.substring(start));			}			return ret;	')	public static function split(me:NativeString, delimiter:NativeString):Array<NativeString> {		return null;	}	@:functionCode('			int meLen = me.length();			int targetLen = meLen;			if (len != null)			{				targetLen = haxe.lang.Runtime.toInt(len);				if (targetLen == 0)					return "";				if( pos != 0 && targetLen < 0 ){					return "";				}			}			if( pos < 0 ){				pos = meLen + pos;				if( pos < 0 ) pos = 0;			} else if( targetLen < 0 ){				targetLen = meLen + targetLen - pos;			}			if( pos + targetLen > meLen ){				targetLen = meLen - pos;			}			if ( pos < 0 || targetLen <= 0 ) return "";			return me.substring(pos, pos + targetLen);	')	public static function substr(me:NativeString, pos:Int, ?len:Int):NativeString {		return null;	}	@:functionCode('		int endIdx;		int len = me.length();		if ( endIndex == null) {			endIdx = len;		} else if ( (endIdx = haxe.lang.Runtime.toInt(endIndex)) < 0 ) {			endIdx = 0;		} else if ( endIdx > len ) {			endIdx = len;		}		if ( startIndex < 0 ) {			startIndex = 0;		} else if ( startIndex > len ) {			startIndex = len;		}		if ( startIndex > endIdx ) {			int tmp = startIndex;			startIndex = endIdx;			endIdx = tmp;		}		return me.substring(startIndex, endIdx);	')	public static function substring(me:NativeString, startIndex:Int, ?endIndex:Int):NativeString {		return null;	}	public static function toString(me:NativeString):NativeString {		return me;	}	@:functionCode('			return me.toLowerCase();	')	public static function toLowerCase(me:NativeString):NativeString {		return null;	}	@:functionCode('			return me.toUpperCase();	')	public static function toUpperCase(me:NativeString):NativeString {		return null;	}	public static function toNativeString(me:NativeString):NativeString {		return me;	}	public static function fromCharCode(code:Int):String {		return new String(java.lang.Character.toChars(code));	}}@:keep @:nativeGen @:native('haxe.lang.StringRefl') private class StringRefl {	public static var fields = [		"length", "toUpperCase", "toLowerCase", "charAt", "charCodeAt", "indexOf", "lastIndexOf", "split", "substr", "substring"	];	public static function handleGetField(str:NativeString, f:NativeString, throwErrors:Bool):Dynamic {		switch (f) {			case "length":				return str.length;			case "toUpperCase", "toLowerCase", "charAt", "charCodeAt", "indexOf", "lastIndexOf", "split", "substr", "substring":				return new Closure(str, f);			default:				if (throwErrors)					throw "Field not found: '" + f + "' in String";				else					return null;		}	}	public static function handleCallField(str:NativeString, f:NativeString, args:java.NativeArray<Dynamic>):Dynamic {		var _args:java.NativeArray<Dynamic>;		if (args == null) {			_args = java.NativeArray.make(str);		} else {			_args = new java.NativeArray(args.length + 1);			_args[0] = str;			for (i in 0...args.length)				_args[i + 1] = args[i];		}		return Runtime.slowCallField(StringExt, f, _args);	}}@:keep @:native('haxe.lang.NativeString') private extern class JavaString {	// name collides with Haxe's	function _charAt(idx:Int):java.StdTypes.Char16;	function codePointAt(idx:Int):Int;	function codePointBefore(idx:Int):Int;	function codePointCount(begin:Int, end:Int):Int;	function offsetByCodePoints(index:Int, codePointOffset:Int):Int;	function getChars(srcBegin:Int, srcEnd:Int, dst:java.NativeArray<java.StdTypes.Char16>, dstBegin:Int):Void;	function startsWith(prefix:String):Bool;	function endsWith(suffix:String):Bool;	function _indexOf(str:String, fromIndex:Int):Int;	function _lastIndexOf(str:String, fromIndex:Int):Int;	function _substring(begin:Int, end:Int):String;	function replace(old:String, nw:String):String;	function _split(regex:String):java.NativeArray<String>;	function trim():String;}
 |