odin-http
odin-http copied to clipboard
5 allocations not freed running "client" example
Running this example https://github.com/laytan/odin-http/blob/main/examples/client/main.odin
with
main :: proc() {
track(run)
}
run :: proc() {
// example code
}
track :: proc(code: proc()) {
track: mem.Tracking_Allocator
mem.tracking_allocator_init(&track, context.allocator)
context.allocator = mem.tracking_allocator(&track)
defer {
if len(track.allocation_map) > 0 {
fmt.eprintf("=== %v allocations not freed: ===\n", len(track.allocation_map))
for _, entry in track.allocation_map {
fmt.eprintf("- %v bytes @ %v\n", entry.size, entry.location)
}
}
if len(track.bad_free_array) > 0 {
fmt.eprintf("=== %v incorrect frees: ===\n", len(track.bad_free_array))
for entry in track.bad_free_array {
fmt.eprintf("- %p @ %v\n", entry.memory, entry.location)
}
}
fmt.printf("Peak memory allocated: %v\n", track.peak_memory_allocated)
mem.tracking_allocator_destroy(&track)
}
code()
}
results in
=== 5 allocations not freed: ===
- 108 bytes @ /Users/vitaly/projects/odin-http/http.odin:165:11:
- 11 bytes @ /Users/vitaly/projects/odin-http/headers.odin:100:7:
- 161 bytes @ /Users/vitaly/projects/odin-http/http.odin:165:11:
- 11 bytes @ /Users/vitaly/projects/odin-http/headers.odin:100:7:
- 311 bytes @ /Users/vitaly/projects/odin-http/http.odin:165:11: