Gc.hx 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. /*
  2. * Copyright (C)2005-2017 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 hl;
  23. enum GcFlag {
  24. /**
  25. Activate profiling: regularly print on stdout gc allocation stats
  26. **/
  27. Profile;
  28. /**
  29. Allows to dump a hlmemory.dump file when HL runs out of memory to be examined with hl memory inspector tool.
  30. **/
  31. DumpMem;
  32. /**
  33. Enable block tracking (see Gc.track API)
  34. **/
  35. Track;
  36. }
  37. class Gc {
  38. public static var flags(get,set) : haxe.EnumFlags<GcFlag>;
  39. public static function stats() {
  40. var tot = 0., count = 0., mem = 0.;
  41. _stats(tot, count, mem);
  42. return { totalAllocated : tot, allocationCount : count, currentMemory : mem };
  43. }
  44. /**
  45. Start tracking an object field change.
  46. The check will be performed every allocation and the callback function triggered everytime
  47. a change has been performed since last check. The callback parameter is true if the object was collected.
  48. It is necessary to enable the Track flag in Gc.flags
  49. **/
  50. public static function track( obj : Dynamic, field : String, callb : Dynamic -> Bytes -> Void ) {
  51. var oval = if( Reflect.isFunction(obj) ) Api.getClosureValue(obj) else obj;
  52. var fid = if( ~/^[0-9]+$/.match(field) ) Std.parseInt(field) else @:privateAccess field.bytes.hash();
  53. if( !_track(oval, fid, callb) )
  54. throw "Could not track "+obj+"."+field;
  55. }
  56. public static function untrack( obj : Dynamic ) {
  57. var oval = if( Reflect.isFunction(obj) ) Api.getClosureValue(obj) else obj;
  58. return _untrack(oval);
  59. }
  60. @:hlNative("std", "gc_untrack_all") public static function untrackAll() : Void {
  61. }
  62. @:hlNative("std", "gc_track_count") public static function trackCount() : Int {
  63. return 0;
  64. }
  65. /**
  66. Dump whole memory into target filename for analysis.
  67. **/
  68. public static function dumpMemory( ?fileName : String = "hlmemory.dump" ) {
  69. _dump(@:privateAccess fileName.toUtf8());
  70. }
  71. static function get_flags() : haxe.EnumFlags<GcFlag> {
  72. return haxe.EnumFlags.ofInt(_get_flags());
  73. }
  74. static function set_flags(v : haxe.EnumFlags<GcFlag>) {
  75. _set_flags(v.toInt());
  76. return v;
  77. }
  78. @:hlNative("std", "gc_dump_memory") static function _dump( b : hl.Bytes ) : Void {}
  79. @:hlNative("std", "gc_enable") public static function enable( b : Bool ) : Void {}
  80. @:hlNative("std", "gc_major") public static function major() : Void {}
  81. @:hlNative("std", "gc_stats") static function _stats( totalAllocated : hl.Ref<Float>, allocationCount : hl.Ref<Float>, currentMemory : hl.Ref<Float> ) : Void {}
  82. @:hlNative("std", "gc_track") static function _track( obj : Dynamic, fid : Int, callb : Dynamic -> Bytes -> Void ) : Bool { return false; }
  83. @:hlNative("std", "gc_untrack") static function _untrack( obj : Dynamic ) : Bool { return false; }
  84. @:hlNative("std", "gc_get_flags") static function _get_flags() : Int { return 0; }
  85. @:hlNative("std", "gc_set_flags") static function _set_flags( v : Int ) {}
  86. }