/* * 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. */ @:coreApi class Array { public var length(default,null) : Int; public function new() : Void { lua.Boot.defArray(this,0); } public function concat( a : Array ) : Array { var ret = this.copy(); for (i in a) ret.push(i); return ret; } public function join( sep : String ) : String { var sb = new StringBuf(); var first = true; for (i in iterator()){ if (first) first = false; else sb.add(sep); sb.add(Std.string(i)); } return sb.toString(); } public function pop() : Null { return this.length == 0 ? null : this[this.length-- -1]; } public function push(x : T) : Int { this[this.length++] = x; return this.length; } public function reverse() : Void { var tmp:T; var i = 0; while(i < Std.int(this.length/2)){ tmp = this[i]; this[i] = this[this.length-i-1]; this[this.length-i-1] = tmp; i++; } } public function shift() : Null { if (this.length == 0) return null; var ret = this[0]; for (i in 0...length){ this[i] = this[i+1]; } this.length-=1; return ret; } public function slice( pos : Int, ?end : Int ) : Array { if (end == null || end > length) end = length; else if (end < 0) end = (length-(-end % length)) % length; // negative pos needs to be wrapped from the end, and mod according to array length if (pos < 0) pos = (length -(-pos % length)) % length; // and here if (pos > end || pos > length) return []; var ret = []; for (i in pos...end){ ret.push(this[i]); } return ret; } public function sort( f : T -> T -> Int ) : Void { return haxe.ds.ArraySort.sort(this,f); } public function splice( pos : Int, len : Int ) : Array { if (pos + len > this.length || len < 0) return []; else if (pos < 0) pos = length -(-pos % length); len = cast Math.min(len,this.length-pos); var ret = []; for (i in pos...(pos+len)){ ret.push(this[i]); this[i] = this[i+len]; } for (i in (pos+len)...length){ this[i] = this[i+len]; } this.length-= len; return ret; } public function toString() : String { var sb = new StringBuf(); sb.add("["); sb.add(join(",")); sb.add("]"); return sb.toString(); } public function unshift( x : T ) : Void { var len = length; for (i in 0...len) this[len - i] = this[len - i - 1]; this[0] = x; } public inline function insert( pos : Int, x : T ) : Void { (untyped this).splice(pos,0,x); } public function remove( x : T ) : Bool { for (i in 0...this.length){ var a = this[i]; if (a == x){ if (i == 0){ if (length == 1){ this[0] = null; } else { this[0] = this[1]; lua.Table.remove(cast this, 1); } } else { lua.Table.remove(cast this, i); } this.length-=1; return true; } } return false; } public function indexOf( x : T, ?fromIndex:Int ) : Int { if (fromIndex == null) fromIndex = 0; for (i in fromIndex...length){ if (x == this[i]) return i; } return -1; } public function lastIndexOf( x : T, ?fromIndex:Int ) : Int { if (fromIndex == null) fromIndex = 0; var i = length; while(i-- > fromIndex){ if (this[i] == x) return i; } return -1; } public inline function copy() : Array { return [for (i in this) i]; } public function map(f:T->S):Array { return [for (i in this) f(i)]; } public function filter(f:T->Bool):Array { return [for (i in this) if (f(i)) i]; } public inline function iterator() : Iterator { var cur_length = 0; return { hasNext : function() return cur_length < length, next : function() return this[cur_length++] } } }