2011-01-11 23:01:06 +00:00
|
|
|
/* radare - LGPL - Copyright 2011 pancake<nopcode.org> */
|
|
|
|
|
|
|
|
#include <r_fs.h>
|
|
|
|
|
2017-02-12 21:44:13 +00:00
|
|
|
R_API RFSFile* r_fs_file_new(RFSRoot* root, const char* path) {
|
|
|
|
RFSFile* file = R_NEW0 (RFSFile);
|
|
|
|
if (!file) {
|
|
|
|
return NULL;
|
|
|
|
}
|
2011-01-14 00:02:20 +00:00
|
|
|
file->root = root;
|
2011-01-11 23:01:06 +00:00
|
|
|
file->name = strdup (path);
|
2011-01-14 00:02:20 +00:00
|
|
|
// TODO: concat path?
|
2011-01-11 23:01:06 +00:00
|
|
|
return file;
|
|
|
|
}
|
|
|
|
|
2017-02-12 21:44:13 +00:00
|
|
|
R_API void r_fs_file_free(RFSFile* file) {
|
2011-01-11 23:01:06 +00:00
|
|
|
free (file->name);
|
|
|
|
free (file->data);
|
|
|
|
free (file);
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO: Use RFSRoot and pass it in the stack instead of heap? problematic with bindings
|
2017-02-12 21:44:13 +00:00
|
|
|
R_API RFSRoot* r_fs_root_new(const char* path, ut64 delta) {
|
|
|
|
char* p;
|
|
|
|
RFSRoot* root = R_NEW0 (RFSRoot);
|
|
|
|
if (!root) {
|
|
|
|
return NULL;
|
|
|
|
}
|
2011-01-11 23:01:06 +00:00
|
|
|
root->path = strdup (path);
|
2016-05-24 20:22:15 +00:00
|
|
|
if (!root->path) {
|
|
|
|
R_FREE (root);
|
|
|
|
return NULL;
|
|
|
|
}
|
2011-01-23 20:54:18 +00:00
|
|
|
p = root->path + strlen (path);
|
2017-02-12 21:44:13 +00:00
|
|
|
if (*p == '/') {
|
|
|
|
*p = 0; // chop tailing slash
|
|
|
|
}
|
2011-01-11 23:01:06 +00:00
|
|
|
root->delta = delta;
|
|
|
|
return root;
|
|
|
|
}
|
|
|
|
|
2017-02-12 21:44:13 +00:00
|
|
|
R_API void r_fs_root_free(RFSRoot* root) {
|
2011-01-14 00:02:20 +00:00
|
|
|
if (root) {
|
2017-02-12 21:44:13 +00:00
|
|
|
if (root->p && root->p->umount) {
|
2011-01-14 00:02:20 +00:00
|
|
|
root->p->umount (root);
|
2017-02-12 21:44:13 +00:00
|
|
|
}
|
2011-01-14 00:02:20 +00:00
|
|
|
free (root->path);
|
|
|
|
free (root);
|
|
|
|
}
|
2011-01-11 23:01:06 +00:00
|
|
|
}
|
2011-01-14 13:41:56 +00:00
|
|
|
|
2017-02-12 21:44:13 +00:00
|
|
|
R_API RFSPartition* r_fs_partition_new(int num, ut64 start, ut64 length) {
|
|
|
|
RFSPartition* p = R_NEW0 (RFSPartition);
|
|
|
|
if (!p) {
|
|
|
|
return NULL;
|
|
|
|
}
|
2011-01-14 13:41:56 +00:00
|
|
|
p->number = num;
|
2017-11-07 10:45:10 +00:00
|
|
|
p->type = 0; // TODO we need an enum with all the partition types
|
2011-01-14 13:41:56 +00:00
|
|
|
p->start = start;
|
|
|
|
p->length = length;
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
2017-02-12 21:44:13 +00:00
|
|
|
R_API void r_fs_partition_free(RFSPartition* p) {
|
2011-01-14 13:41:56 +00:00
|
|
|
free (p);
|
|
|
|
}
|