Gc.hx 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  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 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. @:hlNative("std", "gc_dump_memory") static function _dump(b:hl.Bytes):Void {}
  68. @:hlNative("std", "gc_enable") public static function enable(b:Bool):Void {}
  69. @:hlNative("std", "gc_major") public static function major():Void {}
  70. @:hlNative("std", "gc_stats") static function _stats(totalAllocated:hl.Ref<Float>, allocationCount:hl.Ref<Float>, currentMemory:hl.Ref<Float>):Void {}
  71. @:hlNative("std", "gc_get_flags") static function _get_flags():Int {
  72. return 0;
  73. }
  74. @:hlNative("std", "gc_set_flags") static function _set_flags(v:Int) {}
  75. }