Hash.hx 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. /*
  2. * Copyright (C)2005-2012 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. @:coreApi class Hash<T> {
  23. private var __Internal : Dynamic;
  24. public function new() : Void {
  25. __Internal = {};
  26. }
  27. public function set( key : String, value : T ) : Void {
  28. untyped __Internal.__SetField(key,value,true);
  29. }
  30. public function get( key : String ) : Null<T> {
  31. return untyped __Internal.__Field(key,true);
  32. }
  33. public function exists( key : String ) : Bool {
  34. return untyped __Internal.__HasField(key);
  35. }
  36. public function remove( key : String ) : Bool {
  37. return untyped __global__.__hxcpp_anon_remove(__Internal,key);
  38. }
  39. /**
  40. Returns an iterator of all keys in the hashtable.
  41. **/
  42. public function keys() : Iterator<String> {
  43. var a:Array<String> = [];
  44. untyped __Internal.__GetFields(a);
  45. return a.iterator();
  46. }
  47. /**
  48. Returns an iterator of all values in the hashtable.
  49. **/
  50. public function iterator() : Iterator<T> {
  51. var a:Array<String> = [];
  52. untyped __Internal.__GetFields(a);
  53. var it = a.iterator();
  54. var me = this;
  55. return untyped {
  56. hasNext : function() { return it.hasNext(); },
  57. next : function() { return me.__Internal.__Field(it.next(),true); }
  58. };
  59. }
  60. /**
  61. Returns an displayable representation of the hashtable content.
  62. **/
  63. public function toString() : String {
  64. var s = new StringBuf();
  65. s.add("{");
  66. var it = keys();
  67. for( i in it ) {
  68. s.add(i);
  69. s.add(" => ");
  70. s.add(Std.string(get(i)));
  71. if( it.hasNext() )
  72. s.add(", ");
  73. }
  74. s.add("}");
  75. return s.toString();
  76. }
  77. }