2011-01-11 23:01:06 +00:00
|
|
|
/* radare - LGPL - Copyright 2011 pancake<nopcode.org> */
|
|
|
|
|
|
|
|
#include <r_fs.h>
|
|
|
|
|
2011-01-14 00:02:20 +00:00
|
|
|
R_API RFSFile *r_fs_file_new (RFSRoot *root, const char *path) {
|
2014-03-26 13:47:30 +00:00
|
|
|
RFSFile *file = R_NEW0 (RFSFile);
|
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;
|
|
|
|
}
|
|
|
|
|
|
|
|
R_API void r_fs_file_free (RFSFile *file) {
|
|
|
|
free (file->name);
|
|
|
|
free (file->data);
|
|
|
|
free (file);
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO: Use RFSRoot and pass it in the stack instead of heap? problematic with bindings
|
|
|
|
R_API RFSRoot *r_fs_root_new (const char *path, ut64 delta) {
|
2011-01-23 20:54:18 +00:00
|
|
|
char *p;
|
2011-01-11 23:01:06 +00:00
|
|
|
RFSRoot *root = R_NEW (RFSRoot);
|
|
|
|
root->path = strdup (path);
|
2011-01-23 20:54:18 +00:00
|
|
|
p = root->path + strlen (path);
|
|
|
|
if (*p == '/') *p = 0; // chop tailing slash
|
2011-01-11 23:01:06 +00:00
|
|
|
root->delta = delta;
|
|
|
|
return root;
|
|
|
|
}
|
|
|
|
|
|
|
|
R_API void r_fs_root_free (RFSRoot *root) {
|
2011-01-14 00:02:20 +00:00
|
|
|
if (root) {
|
|
|
|
if (root->p && root->p->umount)
|
|
|
|
root->p->umount (root);
|
|
|
|
free (root->path);
|
|
|
|
free (root);
|
|
|
|
}
|
2011-01-11 23:01:06 +00:00
|
|
|
}
|
2011-01-14 13:41:56 +00:00
|
|
|
|
|
|
|
R_API RFSPartition *r_fs_partition_new(int num, ut64 start, ut64 length) {
|
2014-03-26 13:47:30 +00:00
|
|
|
RFSPartition *p = R_NEW0 (RFSPartition);
|
2011-01-14 13:41:56 +00:00
|
|
|
p->number = num;
|
|
|
|
p->start = start;
|
|
|
|
p->length = length;
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
|
|
|
R_API void r_fs_partition_free (RFSPartition *p) {
|
|
|
|
free (p);
|
|
|
|
}
|