NativeArray.hx 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. /*
  2. * Copyright (C)2005-2019 Haxe Foundation
  3. *
  4. * Permission is hereby granted, free of charge, to any person obtaining a
  5. * copy of this software and associated documentation files (the "Software"),
  6. * to deal in the Software without restriction, including without limitation
  7. * the rights to use, copy, modify, merge, publish, distribute, sublicense,
  8. * and/or sell copies of the Software, and to permit persons to whom the
  9. * Software is furnished to do so, subject to the following conditions:
  10. *
  11. * The above copyright notice and this permission notice shall be included in
  12. * all copies or substantial portions of the Software.
  13. *
  14. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  15. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  16. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  17. * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  18. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
  19. * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
  20. * DEALINGS IN THE SOFTWARE.
  21. */
  22. package cs;
  23. import haxe.extern.Rest;
  24. /**
  25. Represents a C# fixed-size Array (`T[]`)
  26. **/
  27. extern class NativeArray<T> extends cs.system.Array implements ArrayAccess<T> {
  28. /**
  29. Creates a new array with the specified elements.
  30. Usage:
  31. ```haxe
  32. var elements = NativeArray.make(1,2,3,4,5,6);
  33. ```
  34. **/
  35. static function make<T>(elements:Rest<T>):NativeArray<T>;
  36. /**
  37. Allocates a new array with size `len`
  38. **/
  39. function new(len:Int):Void;
  40. /**
  41. Alias to array's `Length` property. Returns the size of the array
  42. **/
  43. var length(get, never):Int;
  44. extern inline private function get_length():Int
  45. return this.Length;
  46. static function Reverse(arr:cs.system.Array):Void;
  47. /**
  48. Returns an iterator so it's possible to use `for` with C#'s `NativeArray`
  49. **/
  50. extern inline function iterator():NativeArrayIterator<T>
  51. return new NativeArrayIterator(this);
  52. }
  53. @:dce private class NativeArrayIterator<T> {
  54. public var arr(default, null):NativeArray<T>;
  55. public var idx(default, null):UInt;
  56. inline public function new(arr) {
  57. this.arr = arr;
  58. this.idx = 0;
  59. }
  60. inline public function hasNext():Bool
  61. return this.idx < this.arr.Length;
  62. inline public function next():T {
  63. return this.arr[this.idx++];
  64. }
  65. }