mirror of
https://gitlab.com/80486DX2-66/gists
synced 2025-01-25 05:42:03 +05:30
reverse-ramdisk.c: major rewrite, add POSIX code
This commit is contained in:
parent
b5c9a01749
commit
1c61eec1ce
@ -5,11 +5,12 @@ C programming idea: Handling temporary files like memory allocations (allocating
|
|||||||
|
|
||||||
Warning: The current result is quick and dirty. Not for educational or
|
Warning: The current result is quick and dirty. Not for educational or
|
||||||
production purposes.
|
production purposes.
|
||||||
|
Warning: The functions are not thread-safe.
|
||||||
|
|
||||||
GCC/Clang/TCC: Compile with -DTEST to set macro TEST as defined, with -DDEBUG
|
GCC/Clang/TCC: Compile with -DTEST to set macro TEST as defined, with -DDEBUG
|
||||||
to enable debug mode
|
to enable debug mode
|
||||||
|
|
||||||
To-Do: error handling on line 184, function fread()
|
To-Do: Add thread-safe versions of functions (use postfix `_r`)
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
@ -40,11 +41,19 @@ To-Do: error handling on line 184, function fread()
|
|||||||
exit(EXIT_FAILURE); \
|
exit(EXIT_FAILURE); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
#if IS_POSIX
|
||||||
|
typedef struct {
|
||||||
|
int ID;
|
||||||
|
char* file_path;
|
||||||
|
int file;
|
||||||
|
} TempFile;
|
||||||
|
#else
|
||||||
typedef struct {
|
typedef struct {
|
||||||
int ID;
|
int ID;
|
||||||
char* file_path;
|
char* file_path;
|
||||||
FILE* file;
|
FILE* file;
|
||||||
} TempFile;
|
} TempFile;
|
||||||
|
#endif
|
||||||
|
|
||||||
TempFile* temp_files = NULL;
|
TempFile* temp_files = NULL;
|
||||||
size_t num_temp_files = 0;
|
size_t num_temp_files = 0;
|
||||||
@ -74,9 +83,13 @@ int tf_alloc(size_t n, size_t type_size) {
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Open the file
|
#if IS_POSIX
|
||||||
|
int file = open(file_path, O_RDWR | O_CREAT);
|
||||||
|
if (file == -1) {
|
||||||
|
#else
|
||||||
FILE* file = fopen(file_path, "w+b");
|
FILE* file = fopen(file_path, "w+b");
|
||||||
if (file == NULL) {
|
if (file == NULL) {
|
||||||
|
#endif
|
||||||
line_fail(-2);
|
line_fail(-2);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -113,7 +126,11 @@ int tf_alloc(size_t n, size_t type_size) {
|
|||||||
int tf_free(int ID) {
|
int tf_free(int ID) {
|
||||||
size_t index = (size_t) ID;
|
size_t index = (size_t) ID;
|
||||||
|
|
||||||
|
#if IS_POSIX
|
||||||
|
close(temp_files[index].file);
|
||||||
|
#else
|
||||||
fclose(temp_files[index].file);
|
fclose(temp_files[index].file);
|
||||||
|
#endif
|
||||||
|
|
||||||
// Delete the file
|
// Delete the file
|
||||||
if (remove(temp_files[index].file_path) != 0) {
|
if (remove(temp_files[index].file_path) != 0) {
|
||||||
@ -142,53 +159,105 @@ int tf_free(int ID) {
|
|||||||
int tf_write(int ID, size_t offset, void* data, size_t data_size) {
|
int tf_write(int ID, size_t offset, void* data, size_t data_size) {
|
||||||
size_t index = (size_t) ID;
|
size_t index = (size_t) ID;
|
||||||
|
|
||||||
|
#if IS_POSIX
|
||||||
|
// Check file handler for -1
|
||||||
|
int file = temp_files[index].file;
|
||||||
|
if (file == -1)
|
||||||
|
#else
|
||||||
// Check file handler for NULL
|
// Check file handler for NULL
|
||||||
FILE* file = temp_files[index].file;
|
FILE* file = temp_files[index].file;
|
||||||
if (file == NULL)
|
if (file == NULL)
|
||||||
|
#endif
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
// Set the position
|
// Set the position
|
||||||
fseek(file, offset, SEEK_SET);
|
#if IS_POSIX
|
||||||
|
if (lseek(file, offset, SEEK_SET) == -1) {
|
||||||
// Write the data to the file
|
#else
|
||||||
size_t bytes_written = fwrite(data, 1, data_size, file);
|
if (fseek(file, offset, SEEK_SET) == -1) {
|
||||||
|
#endif
|
||||||
if (bytes_written != data_size)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
if (fdatasync(file) == -1) {
|
|
||||||
line_fail(-1);
|
line_fail(-1);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Write the data to the file
|
||||||
|
#if IS_POSIX
|
||||||
|
ssize_t bytes_written = write(file, data, data_size);
|
||||||
|
#else
|
||||||
|
size_t bytes_written = fwrite(data, 1, data_size, file);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (
|
||||||
|
#if IS_POSIX
|
||||||
|
(size_t)
|
||||||
|
#endif
|
||||||
|
bytes_written != data_size) {
|
||||||
|
errno = EIO;
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
#if IS_POSIX
|
||||||
|
if (fsync(file) == -1) {
|
||||||
|
line_fail(-1);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
fflush(file);
|
||||||
|
#endif
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int tf_read(int ID, size_t offset, void* dest, size_t data_size) {
|
int tf_read(int ID, size_t offset, void* dest, size_t data_size) {
|
||||||
size_t index = (size_t) ID;
|
size_t index = (size_t) ID;
|
||||||
|
|
||||||
// Open the file in read mode
|
#if IS_POSIX
|
||||||
|
int file = temp_files[index].file;
|
||||||
|
if (file == -1)
|
||||||
|
#else
|
||||||
FILE* file = temp_files[index].file;
|
FILE* file = temp_files[index].file;
|
||||||
if (file == NULL)
|
if (file == NULL)
|
||||||
|
#endif
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
// Read the data from the file
|
// Read the data from the file
|
||||||
void* data = malloc(data_size);
|
void* data = malloc(data_size);
|
||||||
if (data == NULL) {
|
if (data == NULL) {
|
||||||
|
#if IS_POSIX
|
||||||
|
close(file);
|
||||||
|
#else
|
||||||
fclose(file);
|
fclose(file);
|
||||||
line_fail(-3);
|
#endif
|
||||||
|
line_fail(-7);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Initialize the memory in the data buffer
|
|
||||||
memset(data, 0, data_size); // clear destination
|
memset(data, 0, data_size); // clear destination
|
||||||
fseek(file, offset, SEEK_SET); // set position
|
// Set the position
|
||||||
size_t bytes_read = fread(data, 1, data_size, file); // read bytes
|
#if IS_POSIX
|
||||||
|
if (lseek(file, offset, SEEK_SET) == -1) {
|
||||||
|
#else
|
||||||
|
if (fseek(file, offset, SEEK_SET) == -1) {
|
||||||
|
#endif
|
||||||
|
line_fail(-1);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// read bytes
|
||||||
|
#if IS_POSIX
|
||||||
|
ssize_t bytes_read = read(file, data, data_size);
|
||||||
|
#else
|
||||||
|
size_t bytes_read = fread(data, 1, data_size, file);
|
||||||
|
#endif
|
||||||
memcpy(dest, data, data_size);
|
memcpy(dest, data, data_size);
|
||||||
|
|
||||||
free(data); // Free the allocated memory
|
free(data); // Free the allocated memory
|
||||||
|
|
||||||
if (bytes_read != data_size) {
|
if (
|
||||||
|
#if IS_POSIX
|
||||||
|
(size_t)
|
||||||
|
#endif
|
||||||
|
bytes_read != data_size) {
|
||||||
errno = EIO;
|
errno = EIO;
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user