NativeArray.hx 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  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 jvm;
  23. import haxe.extern.Rest;
  24. /**
  25. Represents a java fixed-size Array (`T[]`)
  26. **/
  27. @:nativeGen extern class NativeArray<T> 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. static inline function ofArray<T>(arr:Array<T>) {
  37. var ret = new NativeArray(arr.length);
  38. for (i in 0...arr.length) {
  39. ret[i] = arr[i];
  40. }
  41. return ret;
  42. }
  43. inline function toArray<T>() {
  44. var a = [];
  45. for (i in 0...length) {
  46. a[i] = this[i];
  47. }
  48. return a;
  49. }
  50. /**
  51. The length of the array
  52. **/
  53. var length(default, null):Int;
  54. /**
  55. Allocates a new array with size `len`
  56. **/
  57. function new(len:Int):Void;
  58. }