2024-05-31 11:26:52 -04:00
|
|
|
package grime
|
|
|
|
// TODO(Ed): Review when os2 is done.
|
2024-05-21 23:35:36 -04:00
|
|
|
|
2024-01-21 23:38:02 -05:00
|
|
|
import "core:fmt"
|
|
|
|
import "core:os"
|
2024-05-14 11:47:44 -04:00
|
|
|
import "base:runtime"
|
2024-01-21 23:38:02 -05:00
|
|
|
|
2024-06-02 17:29:27 -04:00
|
|
|
// TODO(Ed): Make an async option...
|
2024-05-31 11:26:52 -04:00
|
|
|
file_copy_sync :: proc( path_src, path_dst: string, allocator := context.allocator ) -> b32
|
2024-01-21 23:38:02 -05:00
|
|
|
{
|
2024-01-22 03:47:53 -05:00
|
|
|
file_size : i64
|
2024-01-21 23:38:02 -05:00
|
|
|
{
|
2024-03-07 19:15:54 -05:00
|
|
|
path_info, result := file_status( path_src, allocator )
|
2024-01-21 23:38:02 -05:00
|
|
|
if result != os.ERROR_NONE {
|
2024-12-31 02:07:30 -05:00
|
|
|
log_fmt("Could not get file info: %v", result, LogLevel.Error )
|
2024-01-21 23:38:02 -05:00
|
|
|
return false
|
|
|
|
}
|
|
|
|
file_size = path_info.size
|
|
|
|
}
|
|
|
|
|
2024-03-07 19:15:54 -05:00
|
|
|
src_content, result := os.read_entire_file( path_src, allocator )
|
2024-01-21 23:38:02 -05:00
|
|
|
if ! result {
|
2024-12-31 02:07:30 -05:00
|
|
|
log_fmt( "Failed to read file to copy: %v", path_src, LogLevel.Error )
|
2024-01-21 23:38:02 -05:00
|
|
|
runtime.debug_trap()
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
result = os.write_entire_file( path_dst, src_content, false )
|
|
|
|
if ! result {
|
2024-12-31 02:07:30 -05:00
|
|
|
log_fmt( "Failed to copy file: %v", path_dst, LogLevel.Error )
|
2024-01-21 23:38:02 -05:00
|
|
|
runtime.debug_trap()
|
|
|
|
return false
|
|
|
|
}
|
2024-01-22 03:47:53 -05:00
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
2024-05-31 11:26:52 -04:00
|
|
|
file_exists :: proc( file_path : string, allocator := context.allocator ) -> b32 {
|
|
|
|
path_info, result := file_status( file_path, allocator )
|
2024-02-08 10:50:36 -05:00
|
|
|
if result != os.ERROR_NONE {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2024-02-27 07:50:57 -05:00
|
|
|
file_is_locked :: proc( file_path : string ) -> b32 {
|
|
|
|
handle, err := file_open(file_path, os.O_RDONLY)
|
2024-01-22 03:47:53 -05:00
|
|
|
if err != os.ERROR_NONE {
|
|
|
|
// If the error indicates the file is in use, return true.
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
// If the file opens successfully, close it and return false.
|
2024-02-27 07:50:57 -05:00
|
|
|
file_close(handle)
|
2024-01-22 03:47:53 -05:00
|
|
|
return false
|
2024-01-21 23:38:02 -05:00
|
|
|
}
|
2024-02-08 16:05:15 -05:00
|
|
|
|
2024-02-27 07:50:57 -05:00
|
|
|
file_rewind :: proc( file : os.Handle ) {
|
|
|
|
file_seek( file, 0, 0 )
|
2024-02-08 16:05:15 -05:00
|
|
|
}
|
|
|
|
|
2024-02-27 07:50:57 -05:00
|
|
|
file_read_looped :: proc( file : os.Handle, data : []byte ) {
|
|
|
|
total_read, result_code := file_read( file, data )
|
2024-02-08 16:05:15 -05:00
|
|
|
if result_code == os.ERROR_HANDLE_EOF {
|
2024-02-27 07:50:57 -05:00
|
|
|
file_rewind( file )
|
2024-02-08 16:05:15 -05:00
|
|
|
}
|
|
|
|
}
|