aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorgingerBill <gingerBill@users.noreply.github.com>2025-10-28 10:57:53 +0000
committergingerBill <gingerBill@users.noreply.github.com>2025-10-28 10:57:53 +0000
commit4c8f99cd36ec05dca1b03a5935b92685549b5717 (patch)
tree1f6c52655d41d5a7c580bba403500b853d3239b0
parent5a23f52fb6343598307decd77c117b9917dfc639 (diff)
Add `#caller_location` to `os2.read_entire_file`
-rw-r--r--core/os/os2/file_util.odin17
1 files changed, 7 insertions, 10 deletions
diff --git a/core/os/os2/file_util.odin b/core/os/os2/file_util.odin
index 13d6db661..5934f02f5 100644
--- a/core/os/os2/file_util.odin
+++ b/core/os/os2/file_util.odin
@@ -107,17 +107,14 @@ read_entire_file :: proc{
}
@(require_results)
-read_entire_file_from_path :: proc(name: string, allocator: runtime.Allocator) -> (data: []byte, err: Error) {
- f, ferr := open(name)
- if ferr != nil {
- return nil, ferr
- }
+read_entire_file_from_path :: proc(name: string, allocator: runtime.Allocator, loc := #caller_location) -> (data: []byte, err: Error) {
+ f := open(name) or_return
defer close(f)
- return read_entire_file_from_file(f, allocator)
+ return read_entire_file_from_file(f, allocator, loc)
}
@(require_results)
-read_entire_file_from_file :: proc(f: ^File, allocator: runtime.Allocator) -> (data: []byte, err: Error) {
+read_entire_file_from_file :: proc(f: ^File, allocator: runtime.Allocator, loc := #caller_location) -> (data: []byte, err: Error) {
size: int
has_size := false
if size64, serr := file_size(f); serr == nil {
@@ -129,7 +126,7 @@ read_entire_file_from_file :: proc(f: ^File, allocator: runtime.Allocator) -> (d
if has_size && size > 0 {
total: int
- data = make([]byte, size, allocator) or_return
+ data = make([]byte, size, allocator, loc) or_return
for total < len(data) {
n: int
n, err = read(f, data[total:])
@@ -145,13 +142,13 @@ read_entire_file_from_file :: proc(f: ^File, allocator: runtime.Allocator) -> (d
return
} else {
buffer: [1024]u8
- out_buffer := make([dynamic]u8, 0, 0, allocator)
+ out_buffer := make([dynamic]u8, 0, 0, allocator, loc)
total := 0
for {
n: int
n, err = read(f, buffer[:])
total += n
- append_elems(&out_buffer, ..buffer[:n]) or_return
+ append_elems(&out_buffer, ..buffer[:n], loc=loc) or_return
if err != nil {
if err == .EOF || err == .Broken_Pipe {
err = nil