default_temporary_allocator.odin 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. package runtime
  2. DEFAULT_TEMP_ALLOCATOR_BACKING_SIZE: int : #config(DEFAULT_TEMP_ALLOCATOR_BACKING_SIZE, 4 * Megabyte)
  3. when ODIN_OS == .Freestanding || ODIN_OS == .JS || ODIN_DEFAULT_TO_NIL_ALLOCATOR {
  4. Default_Temp_Allocator :: struct {}
  5. default_temp_allocator_init :: proc(s: ^Default_Temp_Allocator, size: int, backing_allocator := context.allocator) {}
  6. default_temp_allocator_destroy :: proc(s: ^Default_Temp_Allocator) {}
  7. default_temp_allocator_proc :: nil_allocator_proc
  8. @(require_results)
  9. default_temp_allocator_temp_begin :: proc(loc := #caller_location) -> (temp: Arena_Temp) {
  10. return
  11. }
  12. default_temp_allocator_temp_end :: proc(temp: Arena_Temp, loc := #caller_location) {
  13. }
  14. } else {
  15. Default_Temp_Allocator :: struct {
  16. arena: Arena,
  17. }
  18. default_temp_allocator_init :: proc(s: ^Default_Temp_Allocator, size: int, backing_allocator := context.allocator) {
  19. _ = arena_init(&s.arena, uint(size), backing_allocator)
  20. }
  21. default_temp_allocator_destroy :: proc(s: ^Default_Temp_Allocator) {
  22. if s != nil {
  23. arena_destroy(&s.arena)
  24. s^ = {}
  25. }
  26. }
  27. default_temp_allocator_proc :: proc(allocator_data: rawptr, mode: Allocator_Mode,
  28. size, alignment: int,
  29. old_memory: rawptr, old_size: int, loc := #caller_location) -> (data: []byte, err: Allocator_Error) {
  30. s := (^Default_Temp_Allocator)(allocator_data)
  31. return arena_allocator_proc(&s.arena, mode, size, alignment, old_memory, old_size, loc)
  32. }
  33. @(require_results)
  34. default_temp_allocator_temp_begin :: proc(loc := #caller_location) -> (temp: Arena_Temp) {
  35. if context.temp_allocator.data == &global_default_temp_allocator_data {
  36. temp = arena_temp_begin(&global_default_temp_allocator_data.arena, loc)
  37. }
  38. return
  39. }
  40. default_temp_allocator_temp_end :: proc(temp: Arena_Temp, loc := #caller_location) {
  41. arena_temp_end(temp, loc)
  42. }
  43. }
  44. @(deferred_out=default_temp_allocator_temp_end)
  45. DEFAULT_TEMP_ALLOCATOR_TEMP_GUARD :: #force_inline proc(ignore := false, loc := #caller_location) -> (Arena_Temp, Source_Code_Location) {
  46. if ignore {
  47. return {}, loc
  48. } else {
  49. return default_temp_allocator_temp_begin(loc), loc
  50. }
  51. }
  52. default_temp_allocator :: proc(allocator: ^Default_Temp_Allocator) -> Allocator {
  53. return Allocator{
  54. procedure = default_temp_allocator_proc,
  55. data = allocator,
  56. }
  57. }
  58. @(fini, private)
  59. _destroy_temp_allocator_fini :: proc() {
  60. default_temp_allocator_destroy(&global_default_temp_allocator_data)
  61. }