aboutsummaryrefslogtreecommitdiff
path: root/base
diff options
context:
space:
mode:
authorgingerBill <gingerBill@users.noreply.github.com>2025-10-07 10:41:52 +0100
committergingerBill <gingerBill@users.noreply.github.com>2025-10-07 10:41:52 +0100
commita4a74442cec9cd8c8956032d0e910862e944f9bf (patch)
tree2f9706fe8117083f6189a9a08d8a98177c039fa2 /base
parent47cfee1f6247abe4eb904cb128d0c907b5958a8b (diff)
Add some basic docs to `Default_Temp_Allocator`
Diffstat (limited to 'base')
-rw-r--r--base/runtime/default_temporary_allocator.odin6
1 files changed, 6 insertions, 0 deletions
diff --git a/base/runtime/default_temporary_allocator.odin b/base/runtime/default_temporary_allocator.odin
index ec3c6ad8c..2017570bb 100644
--- a/base/runtime/default_temporary_allocator.odin
+++ b/base/runtime/default_temporary_allocator.odin
@@ -4,6 +4,7 @@ DEFAULT_TEMP_ALLOCATOR_BACKING_SIZE: int : #config(DEFAULT_TEMP_ALLOCATOR_BACKIN
NO_DEFAULT_TEMP_ALLOCATOR: bool : ODIN_OS == .Freestanding || ODIN_DEFAULT_TO_NIL_ALLOCATOR
when NO_DEFAULT_TEMP_ALLOCATOR {
+ // `Default_Temp_Allocator` is a `nil_allocator` when `NO_DEFAULT_TEMP_ALLOCATOR` is `true`.
Default_Temp_Allocator :: struct {}
default_temp_allocator_init :: proc(s: ^Default_Temp_Allocator, size: int, backing_allocator := context.allocator) {}
@@ -20,6 +21,11 @@ when NO_DEFAULT_TEMP_ALLOCATOR {
default_temp_allocator_temp_end :: proc(temp: Arena_Temp, loc := #caller_location) {
}
} else {
+ // `Default_Temp_Allocator` is an `Arena` based type of allocator. See `runtime.Arena` for its implementation.
+ // The default `context.temp_allocator` is typically called with `free_all(context.temp_allocator)` once per "frame-loop"
+ // to prevent it from "leaking" memory.
+ //
+ // Note: `Default_Temp_Allocator` is a `nil_allocator` when `NO_DEFAULT_TEMP_ALLOCATOR` is `true`.
Default_Temp_Allocator :: struct {
arena: Arena,
}