Gc.hx 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. /*
  2. * Copyright (C)2005-2018 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 one 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. Disable GC locking for multithreads
  34. **/
  35. NoThreads;
  36. /**
  37. Force major GC on each allocation
  38. **/
  39. ForceMajor;
  40. }
  41. class Gc {
  42. public static var flags(get,set) : haxe.EnumFlags<GcFlag>;
  43. public static function stats() {
  44. var tot = 0., count = 0., mem = 0.;
  45. _stats(tot, count, mem);
  46. return { totalAllocated : tot, allocationCount : count, currentMemory : mem };
  47. }
  48. /**
  49. Dump whole memory into target filename for analysis.
  50. **/
  51. public static function dumpMemory( ?fileName : String = "hlmemory.dump" ) {
  52. _dump(@:privateAccess fileName.toUtf8());
  53. }
  54. static function get_flags() : haxe.EnumFlags<GcFlag> {
  55. return haxe.EnumFlags.ofInt(_get_flags());
  56. }
  57. static function set_flags(v : haxe.EnumFlags<GcFlag>) {
  58. _set_flags(v.toInt());
  59. return v;
  60. }
  61. /**
  62. Enter/leave a blocking section: when in a blocking section the thread cannot
  63. allocate any memory but other threads will not wait for it for collecting memory.
  64. **/
  65. @:hlNative("std", "blocking")
  66. public static function blocking( b : Bool ) {
  67. }
  68. @:hlNative("std", "gc_dump_memory") static function _dump( b : hl.Bytes ) : Void {}
  69. @:hlNative("std", "gc_enable") public static function enable( b : Bool ) : Void {}
  70. @:hlNative("std", "gc_major") public static function major() : Void {}
  71. @:hlNative("std", "gc_stats") static function _stats( totalAllocated : hl.Ref<Float>, allocationCount : hl.Ref<Float>, currentMemory : hl.Ref<Float> ) : Void {}
  72. @:hlNative("std", "gc_get_flags") static function _get_flags() : Int { return 0; }
  73. @:hlNative("std", "gc_set_flags") static function _set_flags( v : Int ) {}
  74. }