mirror of
https://github.com/odin-lang/Odin.git
synced 2026-02-17 08:34:08 +00:00
Add loc := #caller_location to read_entire_file
This commit is contained in:
@@ -14,10 +14,10 @@ Read_Error :: enum {
|
||||
read_from_file :: proc(filename: string, print_error := false, allocator := context.allocator, loc := #caller_location) -> (file: File, err: Read_Error) {
|
||||
context.allocator = allocator
|
||||
|
||||
data, data_err := os.read_entire_file(filename, allocator)
|
||||
data, data_err := os.read_entire_file(filename, allocator, loc)
|
||||
if data_err != nil {
|
||||
err = .Unable_To_Read_File
|
||||
delete(data, allocator, loc)
|
||||
delete(data, allocator)
|
||||
return
|
||||
}
|
||||
file, err = read(data, filename, print_error, allocator)
|
||||
|
||||
@@ -107,17 +107,17 @@ read_entire_file :: proc{
|
||||
}
|
||||
|
||||
@(require_results)
|
||||
read_entire_file_from_path :: proc(name: string, allocator: runtime.Allocator) -> (data: []byte, err: Error) {
|
||||
read_entire_file_from_path :: proc(name: string, allocator: runtime.Allocator, loc := #caller_location) -> (data: []byte, err: Error) {
|
||||
f, ferr := open(name)
|
||||
if ferr != nil {
|
||||
return nil, ferr
|
||||
}
|
||||
defer close(f)
|
||||
return read_entire_file_from_file(f, allocator)
|
||||
return read_entire_file_from_file(f=f, allocator=allocator, loc=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 +129,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,7 +145,7 @@ 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
|
||||
|
||||
Reference in New Issue
Block a user