wipeout-rewrite/src/utils.c

69 lines
1.4 KiB
C
Raw Normal View History

2023-08-10 13:34:04 +02:00
#include <stdint.h>
#include <string.h>
#include <stdlib.h>
#include <sys/stat.h>
#include "utils.h"
#include "mem.h"
char temp_path[64];
char *get_path(const char *dir, const char *file) {
strcpy(temp_path, dir);
strcpy(temp_path + strlen(dir), file);
return temp_path;
}
bool file_exists(const char *path) {
2023-08-15 17:48:43 +02:00
struct stat s;
return (stat(path, &s) == 0);
2023-08-10 13:34:04 +02:00
}
uint8_t *file_load(const char *path, uint32_t *bytes_read) {
2023-08-10 13:34:04 +02:00
FILE *f = fopen(path, "rb");
error_if(!f, "Could not open file for reading: %s", path);
fseek(f, 0, SEEK_END);
int32_t size = ftell(f);
if (size <= 0) {
fclose(f);
return NULL;
}
fseek(f, 0, SEEK_SET);
uint8_t *bytes = mem_temp_alloc(size);
if (!bytes) {
fclose(f);
return NULL;
}
*bytes_read = fread(bytes, 1, size, f);
fclose(f);
error_if(*bytes_read != size, "Could not read file: %s", path);
return bytes;
}
uint32_t file_store(const char *path, void *bytes, int32_t len) {
2023-08-10 13:34:04 +02:00
FILE *f = fopen(path, "wb");
error_if(!f, "Could not open file for writing: %s", path);
if (fwrite(bytes, 1, len, f) != len) {
die("Could not write file file %s", path);
}
2023-08-15 17:48:43 +02:00
2023-08-10 13:34:04 +02:00
fclose(f);
return len;
}
bool str_starts_with(const char *haystack, const char *needle) {
return (strncmp(haystack, needle, strlen(needle)) == 0);
}
float rand_float(float min, float max) {
return min + ((float)rand() / (float)RAND_MAX) * (max - min);
}
int32_t rand_int(int32_t min, int32_t max) {
return min + rand() % (max - min);
}