1
1

* xdirentry.h: Remove all typedefs, there is no need to hide the

fact that structures are structures.  Fix all dependencies.
Этот коммит содержится в:
Pavel Roskin 2003-10-12 01:00:44 +00:00
родитель ce356e2ce0
Коммит 6cf97f4069
7 изменённых файлов: 225 добавлений и 201 удалений

Просмотреть файл

@ -1,5 +1,8 @@
2003-10-11 Pavel Roskin <proski@gnu.org>
* xdirentry.h: Remove all typedefs, there is no need to hide the
fact that structures are structures. Fix all dependencies.
* vfs.h: Remove typedef vfs, it's too ambiguous. Massive
changes to use struct vfs_class instead.

Просмотреть файл

@ -84,16 +84,16 @@ struct defer_inode {
struct defer_inode *next;
unsigned long inumber;
unsigned short device;
vfs_s_inode *inode;
struct vfs_s_inode *inode;
};
static int cpio_position;
static int cpio_find_head(struct vfs_class *me, vfs_s_super *super);
static int cpio_read_bin_head(struct vfs_class *me, vfs_s_super *super);
static int cpio_read_oldc_head(struct vfs_class *me, vfs_s_super *super);
static int cpio_read_crc_head(struct vfs_class *me, vfs_s_super *super);
static int cpio_create_entry(struct vfs_class *me, vfs_s_super *super, struct stat *stat, char *name);
static int cpio_find_head(struct vfs_class *me, struct vfs_s_super *super);
static int cpio_read_bin_head(struct vfs_class *me, struct vfs_s_super *super);
static int cpio_read_oldc_head(struct vfs_class *me, struct vfs_s_super *super);
static int cpio_read_crc_head(struct vfs_class *me, struct vfs_s_super *super);
static int cpio_create_entry(struct vfs_class *me, struct vfs_s_super *super, struct stat *stat, char *name);
static int cpio_read(void *fh, char *buffer, int count);
#define CPIO_POS(super) cpio_position
@ -110,7 +110,7 @@ static struct defer_inode * defer_find(struct defer_inode *l, struct defer_inode
defer_find(l->next, i);
}
static int cpio_skip_padding(vfs_s_super *super)
static int cpio_skip_padding(struct vfs_s_super *super)
{
switch(super->u.cpio.type) {
case CPIO_BIN:
@ -127,17 +127,17 @@ static int cpio_skip_padding(vfs_s_super *super)
}
}
static void cpio_free_archive(struct vfs_class *me, vfs_s_super *super)
static void cpio_free_archive(struct vfs_class *me, struct vfs_s_super *super)
{
if(super->u.cpio.fd != -1)
mc_close(super->u.cpio.fd);
}
static int cpio_open_cpio_file(struct vfs_class *me, vfs_s_super *super, char *name)
static int cpio_open_cpio_file(struct vfs_class *me, struct vfs_s_super *super, char *name)
{
int fd, type;
mode_t mode;
vfs_s_inode *root;
struct vfs_s_inode *root;
if((fd = mc_open(name, O_RDONLY)) == -1) {
message_2s(1, MSG_ERROR, _("Cannot open cpio archive\n%s"), name);
@ -182,7 +182,7 @@ static int cpio_open_cpio_file(struct vfs_class *me, vfs_s_super *super, char *n
return fd;
}
static int cpio_read_head(struct vfs_class *me, vfs_s_super *super)
static int cpio_read_head(struct vfs_class *me, struct vfs_s_super *super)
{
switch(cpio_find_head(me, super)) {
case CPIO_UNKNOWN:
@ -205,7 +205,7 @@ static int cpio_read_head(struct vfs_class *me, vfs_s_super *super)
#define SEEKBACK CPIO_SEEK_CUR(super, ptr - top)
#define RETURN(x) return(super->u.cpio.type = (x))
#define TYPEIS(x) ((super->u.cpio.type == CPIO_UNKNOWN) || (super->u.cpio.type == (x)))
static int cpio_find_head(struct vfs_class *me, vfs_s_super *super)
static int cpio_find_head(struct vfs_class *me, struct vfs_s_super *super)
{
char buf[256];
int ptr = 0;
@ -246,7 +246,7 @@ static int cpio_find_head(struct vfs_class *me, vfs_s_super *super)
#undef SEEKBACK
#define HEAD_LENGTH (26)
static int cpio_read_bin_head(struct vfs_class *me, vfs_s_super *super)
static int cpio_read_bin_head(struct vfs_class *me, struct vfs_s_super *super)
{
struct old_cpio_header buf;
int len;
@ -291,7 +291,7 @@ static int cpio_read_bin_head(struct vfs_class *me, vfs_s_super *super)
#undef HEAD_LENGTH
#define HEAD_LENGTH (76)
static int cpio_read_oldc_head(struct vfs_class *me, vfs_s_super *super)
static int cpio_read_oldc_head(struct vfs_class *me, struct vfs_s_super *super)
{
struct new_cpio_header hd;
struct stat stat;
@ -340,7 +340,7 @@ static int cpio_read_oldc_head(struct vfs_class *me, vfs_s_super *super)
#undef HEAD_LENGTH
#define HEAD_LENGTH (110)
static int cpio_read_crc_head(struct vfs_class *me, vfs_s_super *super)
static int cpio_read_crc_head(struct vfs_class *me, struct vfs_s_super *super)
{
struct new_cpio_header hd;
struct stat stat;
@ -393,11 +393,11 @@ static int cpio_read_crc_head(struct vfs_class *me, vfs_s_super *super)
return cpio_create_entry(me, super, &stat, name);
}
static int cpio_create_entry(struct vfs_class *me, vfs_s_super *super, struct stat *stat, char *name)
static int cpio_create_entry(struct vfs_class *me, struct vfs_s_super *super, struct stat *stat, char *name)
{
vfs_s_inode *inode = NULL;
vfs_s_inode *root = super->root;
vfs_s_entry *entry = NULL;
struct vfs_s_inode *inode = NULL;
struct vfs_s_inode *root = super->root;
struct vfs_s_entry *entry = NULL;
char *tn;
switch (stat->st_mode & S_IFMT) { /* For case of HP/UX archives */
@ -509,7 +509,7 @@ static int cpio_create_entry(struct vfs_class *me, vfs_s_super *super, struct st
/* Need to CPIO_SEEK_CUR to skip the file at the end of add entry!!!! */
static int cpio_open_archive(struct vfs_class *me, vfs_s_super *super, char *name, char *op)
static int cpio_open_archive(struct vfs_class *me, struct vfs_s_super *super, char *name, char *op)
{
int status = STATUS_START;
@ -588,7 +588,7 @@ static int cpio_ungetlocalcopy(struct vfs_class *me, char *path, char *local, in
return 0;
}
static int cpio_fh_open(struct vfs_class *me, vfs_s_fh *fh, int flags, int mode)
static int cpio_fh_open(struct vfs_class *me, struct vfs_s_fh *fh, int flags, int mode)
{
if ((flags & O_ACCMODE) != O_RDONLY) ERRNOR (EROFS, -1);
return 0;

Просмотреть файл

@ -34,15 +34,15 @@
static volatile int total_inodes = 0, total_entries = 0;
static vfs_s_entry *vfs_s_resolve_symlink (struct vfs_class * me, vfs_s_entry * entry,
static struct vfs_s_entry *vfs_s_resolve_symlink (struct vfs_class * me, struct vfs_s_entry * entry,
char *path, int follow);
vfs_s_inode *
vfs_s_new_inode (struct vfs_class *me, vfs_s_super *super, struct stat *initstat)
struct vfs_s_inode *
vfs_s_new_inode (struct vfs_class *me, struct vfs_s_super *super, struct stat *initstat)
{
vfs_s_inode *ino;
struct vfs_s_inode *ino;
ino = g_new0 (vfs_s_inode, 1);
ino = g_new0 (struct vfs_s_inode, 1);
if (!ino)
return NULL;
@ -61,10 +61,10 @@ vfs_s_new_inode (struct vfs_class *me, vfs_s_super *super, struct stat *initstat
return ino;
}
vfs_s_entry *
vfs_s_new_entry (struct vfs_class *me, char *name, vfs_s_inode *inode)
struct vfs_s_entry *
vfs_s_new_entry (struct vfs_class *me, char *name, struct vfs_s_inode *inode)
{
vfs_s_entry *entry;
struct vfs_s_entry *entry;
entry = g_new0 (struct vfs_s_entry, 1);
total_entries++;
@ -80,7 +80,7 @@ vfs_s_new_entry (struct vfs_class *me, char *name, vfs_s_inode *inode)
}
static void
vfs_s_free_inode (struct vfs_class *me, vfs_s_inode *ino)
vfs_s_free_inode (struct vfs_class *me, struct vfs_s_inode *ino)
{
if (!ino)
vfs_die ("Don't pass NULL to me");
@ -104,7 +104,7 @@ vfs_s_free_inode (struct vfs_class *me, vfs_s_inode *ino)
}
void
vfs_s_free_entry (struct vfs_class *me, vfs_s_entry *ent)
vfs_s_free_entry (struct vfs_class *me, struct vfs_s_entry *ent)
{
int is_dot = 0;
if (ent->prevp){ /* It is possible that we are deleting freshly created entry */
@ -130,9 +130,9 @@ vfs_s_free_entry (struct vfs_class *me, vfs_s_entry *ent)
}
void
vfs_s_insert_entry (struct vfs_class *me, vfs_s_inode *dir, vfs_s_entry *ent)
vfs_s_insert_entry (struct vfs_class *me, struct vfs_s_inode *dir, struct vfs_s_entry *ent)
{
vfs_s_entry **ep;
struct vfs_s_entry **ep;
for (ep = &dir->subdir; *ep != NULL; ep = &((*ep)->next))
;
@ -167,7 +167,7 @@ vfs_s_default_stat (struct vfs_class *me, mode_t mode)
}
void
vfs_s_add_dots (struct vfs_class *me, vfs_s_inode *dir, vfs_s_inode *parent)
vfs_s_add_dots (struct vfs_class *me, struct vfs_s_inode *dir, struct vfs_s_inode *parent)
{
struct vfs_s_entry *dot, *dotdot;
@ -196,8 +196,8 @@ vfs_s_generate_entry (struct vfs_class *me, char *name, struct vfs_s_inode *pare
}
/* We were asked to create entries automagically */
static vfs_s_entry *
vfs_s_automake (struct vfs_class *me, vfs_s_inode *dir, char *path, int flags)
static struct vfs_s_entry *
vfs_s_automake (struct vfs_class *me, struct vfs_s_inode *dir, char *path, int flags)
{
struct vfs_s_entry *res;
char *sep = strchr (path, PATH_SEP);
@ -217,11 +217,11 @@ vfs_s_automake (struct vfs_class *me, vfs_s_inode *dir, char *path, int flags)
* Follow > 0: follow links, serves as loop protect,
* == -1: do not follow links
*/
vfs_s_entry *
vfs_s_find_entry_tree (struct vfs_class *me, vfs_s_inode *root, char *path, int follow, int flags)
struct vfs_s_entry *
vfs_s_find_entry_tree (struct vfs_class *me, struct vfs_s_inode *root, char *path, int follow, int flags)
{
unsigned int pseg;
vfs_s_entry *ent = NULL;
struct vfs_s_entry *ent = NULL;
char p[MC_MAXPATHLEN] = "";
while (root){
@ -275,10 +275,10 @@ split_dir_name (struct vfs_class *me, char *path, char **dir, char **name, char
}
}
vfs_s_entry *
vfs_s_find_entry_linear (struct vfs_class *me, vfs_s_inode *root, char *path, int follow, int flags)
struct vfs_s_entry *
vfs_s_find_entry_linear (struct vfs_class *me, struct vfs_s_inode *root, char *path, int follow, int flags)
{
vfs_s_entry* ent = NULL;
struct vfs_s_entry* ent = NULL;
if (root->super->root != root)
vfs_die ("We have to use _real_ root. Always. Sorry." );
@ -287,7 +287,7 @@ vfs_s_find_entry_linear (struct vfs_class *me, vfs_s_inode *root, char *path, in
if (!(flags & FL_DIR)){
char *dirname, *name, *save;
vfs_s_inode *ino;
struct vfs_s_inode *ino;
split_dir_name (me, path, &dirname, &name, &save);
ino = vfs_s_find_inode (me, root, dirname, follow, flags | FL_DIR);
if (save)
@ -308,7 +308,7 @@ vfs_s_find_entry_linear (struct vfs_class *me, vfs_s_inode *root, char *path, in
}
if (!ent){
vfs_s_inode *ino;
struct vfs_s_inode *ino;
ino = vfs_s_new_inode (me, root->super, vfs_s_default_stat (me, S_IFDIR | 0755));
ent = vfs_s_new_entry (me, path, ino);
@ -331,10 +331,10 @@ vfs_s_find_entry_linear (struct vfs_class *me, vfs_s_inode *root, char *path, in
return ent;
}
vfs_s_inode *
vfs_s_find_inode (struct vfs_class *me, vfs_s_inode *root, char *path, int follow, int flags)
struct vfs_s_inode *
vfs_s_find_inode (struct vfs_class *me, struct vfs_s_inode *root, char *path, int follow, int flags)
{
vfs_s_entry *ent;
struct vfs_s_entry *ent;
if ((MEDATA->find_entry == vfs_s_find_entry_tree) && (!*path))
return root;
ent = (MEDATA->find_entry)(me, root, path, follow, flags);
@ -343,8 +343,8 @@ vfs_s_find_inode (struct vfs_class *me, vfs_s_inode *root, char *path, int follo
return ent->ino;
}
static vfs_s_entry *
vfs_s_resolve_symlink (struct vfs_class *me, vfs_s_entry *entry, char *path, int follow)
static struct vfs_s_entry *
vfs_s_resolve_symlink (struct vfs_class *me, struct vfs_s_entry *entry, char *path, int follow)
{
char buf[MC_MAXPATHLEN], *linkname;
@ -401,10 +401,10 @@ vfs_s_resolve_symlink (struct vfs_class *me, vfs_s_entry *entry, char *path, int
/* Ook, these were functions around directory entries / inodes */
/* -------------------------------- superblock games -------------------------- */
static vfs_s_super *
static struct vfs_s_super *
vfs_s_new_super (struct vfs_class *me)
{
vfs_s_super *super;
struct vfs_s_super *super;
super = g_new0 (struct vfs_s_super, 1);
super->me = me;
@ -412,7 +412,7 @@ vfs_s_new_super (struct vfs_class *me)
}
static void
vfs_s_insert_super (struct vfs_class *me, vfs_s_super *super)
vfs_s_insert_super (struct vfs_class *me, struct vfs_s_super *super)
{
super->next = MEDATA->supers;
super->prevp = &MEDATA->supers;
@ -423,7 +423,7 @@ vfs_s_insert_super (struct vfs_class *me, vfs_s_super *super)
}
static void
vfs_s_free_super (struct vfs_class *me, vfs_s_super *super)
vfs_s_free_super (struct vfs_class *me, struct vfs_s_super *super)
{
if (super->root){
vfs_s_free_inode (me, super->root);
@ -532,7 +532,7 @@ vfs_s_get_path (struct vfs_class *me, const char *inname, struct vfs_s_super **a
}
void
vfs_s_invalidate (struct vfs_class *me, vfs_s_super *super)
vfs_s_invalidate (struct vfs_class *me, struct vfs_s_super *super)
{
if (!super->want_stale){
vfs_s_free_inode (me, super->root);
@ -541,7 +541,7 @@ vfs_s_invalidate (struct vfs_class *me, vfs_s_super *super)
}
char *
vfs_s_fullpath (struct vfs_class *me, vfs_s_inode *ino)
vfs_s_fullpath (struct vfs_class *me, struct vfs_s_inode *ino)
{
/* For now, usable only on filesystems with _linear structure */
if (MEDATA->find_entry != vfs_s_find_entry_linear)
@ -559,7 +559,7 @@ vfs_s_fullpath (struct vfs_class *me, vfs_s_inode *ino)
/* Support of archives */
/* ------------------------ readdir & friends ----------------------------- */
static vfs_s_inode *
static struct vfs_s_inode *
vfs_s_inode_from_path (struct vfs_class *me, char *name, int flags)
{
struct vfs_s_super *super;
@ -577,8 +577,8 @@ vfs_s_inode_from_path (struct vfs_class *me, char *name, int flags)
}
struct dirhandle {
vfs_s_entry *cur;
vfs_s_inode *dir;
struct vfs_s_entry *cur;
struct vfs_s_inode *dir;
};
static void *
@ -732,7 +732,7 @@ vfs_s_open (struct vfs_class *me, char *file, int flags, int mode)
{
int was_changed = 0;
struct vfs_s_fh *fh;
vfs_s_super *super;
struct vfs_s_super *super;
char *q;
struct vfs_s_inode *ino;
@ -743,8 +743,8 @@ vfs_s_open (struct vfs_class *me, char *file, int flags, int mode)
ERRNOR (EEXIST, NULL);
if (!ino){
char *dirname, *name, *save;
vfs_s_entry *ent;
vfs_s_inode *dir;
struct vfs_s_entry *ent;
struct vfs_s_inode *dir;
int tmp_handle;
/* If the filesystem is read-only, disable file creation */
@ -1021,7 +1021,7 @@ vfs_s_getlocalcopy (struct vfs_class *me, char *path)
static int
vfs_s_setctl (struct vfs_class *me, char *path, int ctlop, char *arg)
{
vfs_s_inode *ino = vfs_s_inode_from_path (me, path, 0);
struct vfs_s_inode *ino = vfs_s_inode_from_path (me, path, 0);
if (!ino)
return 0;
switch (ctlop){
@ -1049,7 +1049,7 @@ vfs_s_setctl (struct vfs_class *me, char *path, int ctlop, char *arg)
static vfsid
vfs_s_getid (struct vfs_class *me, const char *path, struct vfs_stamping **parent)
{
vfs_s_super *archive;
struct vfs_s_super *archive;
struct vfs_class *v;
char *p;
vfsid id;
@ -1081,7 +1081,7 @@ vfs_s_nothingisopen (vfsid id)
static void
vfs_s_free (vfsid id)
{
vfs_s_free_super (((vfs_s_super *)id)->me, (vfs_s_super *)id);
vfs_s_free_super (((struct vfs_s_super *)id)->me, (struct vfs_s_super *)id);
}
void

Просмотреть файл

@ -80,7 +80,7 @@ static char reply_str [80];
static struct vfs_class vfs_fish_ops;
static int
command (struct vfs_class *me, vfs_s_super *super, int wait_reply, const char *fmt, ...)
command (struct vfs_class *me, struct vfs_s_super *super, int wait_reply, const char *fmt, ...)
__attribute__ ((format (printf, 4, 5)));
static int decode_reply (char *s, int was_garbage)
@ -119,7 +119,7 @@ static int get_reply (struct vfs_class *me, int sock, char *string_buf, int stri
#define SUP super->u.fish
static int
command (struct vfs_class *me, vfs_s_super *super, int wait_reply, const char *fmt, ...)
command (struct vfs_class *me, struct vfs_s_super *super, int wait_reply, const char *fmt, ...)
{
va_list ap;
char *str;
@ -151,7 +151,7 @@ command (struct vfs_class *me, vfs_s_super *super, int wait_reply, const char *f
}
static void
free_archive (struct vfs_class *me, vfs_s_super *super)
free_archive (struct vfs_class *me, struct vfs_s_super *super)
{
if ((SUP.sockw != -1) || (SUP.sockr != -1)){
print_vfs_message (_("fish: Disconnecting from %s"), super->name?super->name:"???");
@ -167,7 +167,7 @@ free_archive (struct vfs_class *me, vfs_s_super *super)
}
static void
pipeopen(vfs_s_super *super, char *path, char *argv[])
pipeopen(struct vfs_s_super *super, char *path, char *argv[])
{
int fileset1[2], fileset2[2];
int res;
@ -197,14 +197,14 @@ pipeopen(vfs_s_super *super, char *path, char *argv[])
}
/* The returned directory should always contain a trailing slash */
static char *fish_getcwd(struct vfs_class *me, vfs_s_super *super)
static char *fish_getcwd(struct vfs_class *me, struct vfs_s_super *super)
{
if (command(me, super, WANT_STRING, "#PWD\npwd; echo '### 200'\n") == COMPLETE)
return g_strconcat (reply_str, "/", NULL);
ERRNOR (EIO, NULL);
}
static int
open_archive_int (struct vfs_class *me, vfs_s_super *super)
open_archive_int (struct vfs_class *me, struct vfs_s_super *super)
{
char *argv[100];
char *xsh = (SUP.flags == FISH_FLAG_RSH ? "rsh" : "ssh");
@ -295,7 +295,7 @@ open_archive_int (struct vfs_class *me, vfs_s_super *super)
}
static int
open_archive (struct vfs_class *me, vfs_s_super *super, char *archive_name, char *op)
open_archive (struct vfs_class *me, struct vfs_s_super *super, char *archive_name, char *op)
{
char *host, *user, *password, *p;
int flags;
@ -317,7 +317,7 @@ open_archive (struct vfs_class *me, vfs_s_super *super, char *archive_name, char
}
static int
archive_same(struct vfs_class *me, vfs_s_super *super, char *archive_name, char *op, void *cookie)
archive_same(struct vfs_class *me, struct vfs_s_super *super, char *archive_name, char *op, void *cookie)
{
char *host, *user;
int flags;
@ -337,7 +337,7 @@ archive_same(struct vfs_class *me, vfs_s_super *super, char *archive_name, char
}
static int
dir_uptodate(struct vfs_class *me, vfs_s_inode *ino)
dir_uptodate(struct vfs_class *me, struct vfs_s_inode *ino)
{
struct timeval tim;
@ -352,11 +352,11 @@ dir_uptodate(struct vfs_class *me, vfs_s_inode *ino)
}
static int
dir_load(struct vfs_class *me, vfs_s_inode *dir, char *remote_path)
dir_load(struct vfs_class *me, struct vfs_s_inode *dir, char *remote_path)
{
vfs_s_super *super = dir->super;
struct vfs_s_super *super = dir->super;
char buffer[8192];
vfs_s_entry *ent = NULL;
struct vfs_s_entry *ent = NULL;
FILE *logfile;
char *quoted_path;
@ -475,9 +475,9 @@ error:
}
static int
file_store(struct vfs_class *me, vfs_s_fh *fh, char *name, char *localname)
file_store(struct vfs_class *me, struct vfs_s_fh *fh, char *name, char *localname)
{
vfs_s_super *super = FH_SUPER;
struct vfs_s_super *super = FH_SUPER;
int n, total;
char buffer[8192];
struct stat s;
@ -562,7 +562,7 @@ error_return:
return -1;
}
static int linear_start(struct vfs_class *me, vfs_s_fh *fh, int offset)
static int linear_start(struct vfs_class *me, struct vfs_s_fh *fh, int offset)
{
char *name;
char *quoted_name;
@ -596,9 +596,9 @@ static int linear_start(struct vfs_class *me, vfs_s_fh *fh, int offset)
}
static void
linear_abort (struct vfs_class *me, vfs_s_fh *fh)
linear_abort (struct vfs_class *me, struct vfs_s_fh *fh)
{
vfs_s_super *super = FH_SUPER;
struct vfs_s_super *super = FH_SUPER;
char buffer[8192];
int n;
@ -617,9 +617,9 @@ linear_abort (struct vfs_class *me, vfs_s_fh *fh)
}
static int
linear_read (struct vfs_class *me, vfs_s_fh *fh, void *buf, int len)
linear_read (struct vfs_class *me, struct vfs_s_fh *fh, void *buf, int len)
{
vfs_s_super *super = FH_SUPER;
struct vfs_s_super *super = FH_SUPER;
int n = 0;
len = MIN( fh->u.fish.total - fh->u.fish.got, len );
disable_interrupt_key();
@ -638,7 +638,7 @@ linear_read (struct vfs_class *me, vfs_s_fh *fh, void *buf, int len)
}
static void
linear_close (struct vfs_class *me, vfs_s_fh *fh)
linear_close (struct vfs_class *me, struct vfs_s_fh *fh)
{
if (fh->u.fish.total != fh->u.fish.got)
linear_abort(me, fh);
@ -671,7 +671,7 @@ fish_ctl (void *fh, int ctlop, int arg)
}
static int
send_fish_command(struct vfs_class *me, vfs_s_super *super, char *cmd, int flags)
send_fish_command(struct vfs_class *me, struct vfs_s_super *super, char *cmd, int flags)
{
int r;
@ -686,7 +686,7 @@ send_fish_command(struct vfs_class *me, vfs_s_super *super, char *cmd, int flags
#define PREFIX \
char buf[BUF_LARGE]; \
char *rpath; \
vfs_s_super *super; \
struct vfs_s_super *super; \
if (!(rpath = vfs_s_get_path_mangle(me, path, &super, 0))) \
return -1; \
rpath = name_quote (rpath, 0);
@ -712,7 +712,7 @@ static int fish_##name (struct vfs_class *me, char *path1, char *path2) \
{ \
char buf[BUF_LARGE]; \
char *rpath1, *rpath2; \
vfs_s_super *super1, *super2; \
struct vfs_s_super *super1, *super2; \
if (!(rpath1 = vfs_s_get_path_mangle(me, path1, &super1, 0))) \
return -1; \
if (!(rpath2 = vfs_s_get_path_mangle(me, path2, &super2, 0))) \
@ -813,7 +813,7 @@ static int fish_rmdir (struct vfs_class *me, char *path)
POSTFIX(OPT_FLUSH);
}
static int fish_fh_open (struct vfs_class *me, vfs_s_fh *fh, int flags, int mode)
static int fish_fh_open (struct vfs_class *me, struct vfs_s_fh *fh, int flags, int mode)
{
fh->u.fish.append = 0;
/* File will be written only, so no need to retrieve it */
@ -866,7 +866,7 @@ static struct vfs_s_data fish_data = {
static void
fish_fill_names (struct vfs_class *me, void (*func)(char *))
{
struct vfs_s_super * super = fish_data.supers;
struct vfs_s_super *super = fish_data.supers;
char *flags;
char *name;

Просмотреть файл

@ -156,16 +156,16 @@ static struct vfs_class vfs_ftpfs_ops;
c) strip trailing "/."
*/
static char *ftpfs_get_current_directory (struct vfs_class *me, vfs_s_super *super);
static int ftpfs_chdir_internal (struct vfs_class *me, vfs_s_super *super, char *remote_path);
static int command (struct vfs_class *me, vfs_s_super *super, int wait_reply, const char *fmt, ...)
static char *ftpfs_get_current_directory (struct vfs_class *me, struct vfs_s_super *super);
static int ftpfs_chdir_internal (struct vfs_class *me, struct vfs_s_super *super, char *remote_path);
static int command (struct vfs_class *me, struct vfs_s_super *super, int wait_reply, const char *fmt, ...)
__attribute__ ((format (printf, 4, 5)));
static int ftpfs_open_socket (struct vfs_class *me, vfs_s_super *super);
static int login_server (struct vfs_class *me, vfs_s_super *super, const char *netrcpass);
static int ftpfs_open_socket (struct vfs_class *me, struct vfs_s_super *super);
static int login_server (struct vfs_class *me, struct vfs_s_super *super, const char *netrcpass);
static int lookup_netrc (const char *host, char **login, char **pass);
static char *
translate_path (struct vfs_class *me, vfs_s_super *super, const char *remote_path)
translate_path (struct vfs_class *me, struct vfs_s_super *super, const char *remote_path)
{
if (!SUP.remote_is_amiga)
return g_strdup (remote_path);
@ -297,7 +297,7 @@ get_reply (struct vfs_class *me, int sock, char *string_buf, int string_len)
}
static int
reconnect (struct vfs_class *me, vfs_s_super *super)
reconnect (struct vfs_class *me, struct vfs_s_super *super)
{
int sock = ftpfs_open_socket (me, super);
if (sock != -1){
@ -318,7 +318,7 @@ reconnect (struct vfs_class *me, vfs_s_super *super)
}
static int
command (struct vfs_class *me, vfs_s_super *super, int wait_reply, const char *fmt, ...)
command (struct vfs_class *me, struct vfs_s_super *super, int wait_reply, const char *fmt, ...)
{
va_list ap;
char *cmdstr;
@ -378,7 +378,7 @@ command (struct vfs_class *me, vfs_s_super *super, int wait_reply, const char *f
}
static void
free_archive (struct vfs_class *me, vfs_s_super *super)
free_archive (struct vfs_class *me, struct vfs_s_super *super)
{
if (SUP.sock != -1){
print_vfs_message (_("ftpfs: Disconnecting from %s"), SUP.host);
@ -401,7 +401,7 @@ free_archive (struct vfs_class *me, vfs_s_super *super)
#define TYPE_UNKNOWN -1
static int
changetype (struct vfs_class *me, vfs_s_super *super, int binary)
changetype (struct vfs_class *me, struct vfs_s_super *super, int binary)
{
if (binary != SUP.isbinary) {
if (command (me, super, WAIT_REPLY, "TYPE %c", binary ? 'I' : 'A') != COMPLETE)
@ -413,7 +413,7 @@ changetype (struct vfs_class *me, vfs_s_super *super, int binary)
/* This routine logs the user in */
static int
login_server (struct vfs_class *me, vfs_s_super *super, const char *netrcpass)
login_server (struct vfs_class *me, struct vfs_s_super *super, const char *netrcpass)
{
char *pass;
char *op;
@ -653,7 +653,7 @@ ftpfs_get_proxy_host_and_port (const char *proxy, char **host, int *port)
}
static int
ftpfs_open_socket (struct vfs_class *me, vfs_s_super *super)
ftpfs_open_socket (struct vfs_class *me, struct vfs_s_super *super)
{
struct sockaddr_in server_address;
struct hostent *hp;
@ -730,7 +730,7 @@ ftpfs_open_socket (struct vfs_class *me, vfs_s_super *super)
}
static int
open_archive_int (struct vfs_class *me, vfs_s_super *super)
open_archive_int (struct vfs_class *me, struct vfs_s_super *super)
{
int retry_seconds, count_down;
@ -780,7 +780,7 @@ open_archive_int (struct vfs_class *me, vfs_s_super *super)
}
static int
open_archive (struct vfs_class *me, vfs_s_super *super, char *archive_name, char *op)
open_archive (struct vfs_class *me, struct vfs_s_super *super, char *archive_name, char *op)
{
char *host, *user, *password;
int port;
@ -807,7 +807,7 @@ open_archive (struct vfs_class *me, vfs_s_super *super, char *archive_name, char
}
static int
archive_same(struct vfs_class *me, vfs_s_super *super, char *archive_name, char *op, void *cookie)
archive_same(struct vfs_class *me, struct vfs_s_super *super, char *archive_name, char *op, void *cookie)
{
char *host, *user;
int port;
@ -831,7 +831,7 @@ ftpfs_flushdir (void)
}
static int
dir_uptodate(struct vfs_class *me, vfs_s_inode *ino)
dir_uptodate(struct vfs_class *me, struct vfs_s_inode *ino)
{
struct timeval tim;
@ -847,7 +847,7 @@ dir_uptodate(struct vfs_class *me, vfs_s_inode *ino)
/* The returned directory should always contain a trailing slash */
static char *
ftpfs_get_current_directory (struct vfs_class *me, vfs_s_super *super)
ftpfs_get_current_directory (struct vfs_class *me, struct vfs_s_super *super)
{
char buf[BUF_8K], *bufp, *bufq;
@ -887,7 +887,7 @@ ftpfs_get_current_directory (struct vfs_class *me, vfs_s_super *super)
/* Setup Passive ftp connection, we use it for source routed connections */
static int
setup_passive (struct vfs_class *me, vfs_s_super *super, int my_socket, struct sockaddr_in *sa)
setup_passive (struct vfs_class *me, struct vfs_s_super *super, int my_socket, struct sockaddr_in *sa)
{
int xa, xb, xc, xd, xe, xf;
char n [6];
@ -921,7 +921,7 @@ setup_passive (struct vfs_class *me, vfs_s_super *super, int my_socket, struct s
}
static int
initconn (struct vfs_class *me, vfs_s_super *super)
initconn (struct vfs_class *me, struct vfs_s_super *super)
{
struct sockaddr_in data_addr;
int data;
@ -972,7 +972,7 @@ again:
}
static int
open_data_connection (struct vfs_class *me, vfs_s_super *super, const char *cmd,
open_data_connection (struct vfs_class *me, struct vfs_s_super *super, const char *cmd,
const char *remote, int isbinary, int reget)
{
struct sockaddr_in from;
@ -1015,9 +1015,9 @@ open_data_connection (struct vfs_class *me, vfs_s_super *super, const char *cmd,
#define ABORT_TIMEOUT 5
static void
linear_abort (struct vfs_class *me, vfs_s_fh *fh)
linear_abort (struct vfs_class *me, struct vfs_s_fh *fh)
{
vfs_s_super *super = FH_SUPER;
struct vfs_s_super *super = FH_SUPER;
static unsigned char const ipbuf[3] = { IAC, IP, IAC };
fd_set mask;
char buf[1024];
@ -1065,7 +1065,7 @@ linear_abort (struct vfs_class *me, vfs_s_fh *fh)
#if 0
static void
resolve_symlink_without_ls_options(struct vfs_class *me, vfs_s_super *super, vfs_s_inode *dir)
resolve_symlink_without_ls_options(struct vfs_class *me, struct vfs_s_super *super, struct vfs_s_inode *dir)
{
struct linklist *flist;
struct direntry *fe, *fel;
@ -1126,7 +1126,7 @@ resolve_symlink_without_ls_options(struct vfs_class *me, vfs_s_super *super, vfs
}
static void
resolve_symlink_with_ls_options(struct vfs_class *me, vfs_s_super *super, vfs_s_inode *dir)
resolve_symlink_with_ls_options(struct vfs_class *me, struct vfs_s_super *super, struct vfs_s_inode *dir)
{
char buffer[2048] = "", *filename;
int sock;
@ -1205,7 +1205,7 @@ done:
}
static void
resolve_symlink(struct vfs_class *me, vfs_s_super *super, vfs_s_inode *dir)
resolve_symlink(struct vfs_class *me, struct vfs_s_super *super, struct vfs_s_inode *dir)
{
print_vfs_message(_("Resolving symlink..."));
@ -1217,10 +1217,10 @@ resolve_symlink(struct vfs_class *me, vfs_s_super *super, vfs_s_inode *dir)
#endif
static int
dir_load (struct vfs_class *me, vfs_s_inode *dir, char *remote_path)
dir_load (struct vfs_class *me, struct vfs_s_inode *dir, char *remote_path)
{
vfs_s_entry *ent;
vfs_s_super *super = dir->super;
struct vfs_s_entry *ent;
struct vfs_s_super *super = dir->super;
int sock, num_entries = 0;
#ifdef FIXME_LATER
int has_symlinks = 0;
@ -1279,7 +1279,7 @@ again:
* code below may jump directly into error handling code (without executing
* remaining code). And C doesn't have try {...} finally {}; :-)
*/
vfs_s_inode *parent = dir->ent->dir;
struct vfs_s_inode *parent = dir->ent->dir;
if( parent==NULL )
parent = dir;
@ -1373,7 +1373,7 @@ fallback:
}
static int
file_store(struct vfs_class *me, vfs_s_fh *fh, char *name, char *localname)
file_store(struct vfs_class *me, struct vfs_s_fh *fh, char *name, char *localname)
{
int h, sock, n;
off_t total;
@ -1384,7 +1384,7 @@ file_store(struct vfs_class *me, vfs_s_fh *fh, char *name, char *localname)
#endif
char buffer[8192];
struct stat s;
vfs_s_super *super = FH_SUPER;
struct vfs_s_super *super = FH_SUPER;
h = open(localname, O_RDONLY);
if (h == -1)
@ -1451,7 +1451,7 @@ error_return:
}
static int
linear_start(struct vfs_class *me, vfs_s_fh *fh, int offset)
linear_start(struct vfs_class *me, struct vfs_s_fh *fh, int offset)
{
char *name = vfs_s_fullpath (me, fh->ino);
@ -1468,10 +1468,10 @@ linear_start(struct vfs_class *me, vfs_s_fh *fh, int offset)
}
static int
linear_read (struct vfs_class *me, vfs_s_fh *fh, void *buf, int len)
linear_read (struct vfs_class *me, struct vfs_s_fh *fh, void *buf, int len)
{
int n;
vfs_s_super *super = FH_SUPER;
struct vfs_s_super *super = FH_SUPER;
while ((n = read (FH_SOCK, buf, len))<0) {
if ((errno == EINTR) && !got_interrupt())
@ -1494,7 +1494,7 @@ linear_read (struct vfs_class *me, vfs_s_fh *fh, void *buf, int len)
}
static void
linear_close (struct vfs_class *me, vfs_s_fh *fh)
linear_close (struct vfs_class *me, struct vfs_s_fh *fh)
{
if (FH_SOCK != -1)
linear_abort(me, fh);
@ -1527,7 +1527,7 @@ static int
send_ftp_command(struct vfs_class *me, char *filename, char *cmd, int flags)
{
char *rpath, *p;
vfs_s_super *super;
struct vfs_s_super *super;
int r;
int flush_directory_cache = (flags & OPT_FLUSH);
@ -1592,7 +1592,7 @@ static int ftpfs_unlink (struct vfs_class *me, char *path)
/* Return 1 if path is the same directory as the one we are in now */
static int
is_same_dir (struct vfs_class *me, vfs_s_super *super, const char *path)
is_same_dir (struct vfs_class *me, struct vfs_s_super *super, const char *path)
{
if (!SUP.cwdir)
return 0;
@ -1602,7 +1602,7 @@ is_same_dir (struct vfs_class *me, vfs_s_super *super, const char *path)
}
static int
ftpfs_chdir_internal (struct vfs_class *me, vfs_s_super *super, char *remote_path)
ftpfs_chdir_internal (struct vfs_class *me, struct vfs_s_super *super, char *remote_path)
{
int r;
char *p;
@ -1640,7 +1640,7 @@ static int ftpfs_rmdir (struct vfs_class *me, char *path)
return send_ftp_command(me, path, "RMD /%s", OPT_FLUSH);
}
static int ftpfs_fh_open (struct vfs_class *me, vfs_s_fh *fh, int flags, int mode)
static int ftpfs_fh_open (struct vfs_class *me, struct vfs_s_fh *fh, int flags, int mode)
{
fh->u.ftp.append = 0;
/* File will be written only, so no need to retrieve it from ftp server */
@ -1697,7 +1697,7 @@ static int ftpfs_fh_open (struct vfs_class *me, vfs_s_fh *fh, int flags, int mod
return 0;
}
static int ftpfs_fh_close (struct vfs_class *me, vfs_s_fh *fh)
static int ftpfs_fh_close (struct vfs_class *me, struct vfs_s_fh *fh)
{
if (fh->handle != -1 && !fh->ino->localname){
close (fh->handle);

Просмотреть файл

@ -61,7 +61,7 @@ static long from_oct (int digs, char *where)
static struct stat hstat; /* Stat struct corresponding */
static void tar_free_archive (struct vfs_class *me, vfs_s_super *archive)
static void tar_free_archive (struct vfs_class *me, struct vfs_s_super *archive)
{
if (archive->u.tar.fd != -1)
mc_close(archive->u.tar.fd);
@ -71,7 +71,7 @@ static void tar_free_archive (struct vfs_class *me, vfs_s_super *archive)
static int current_tar_position = 0;
/* Returns fd of the open tar file */
static int tar_open_archive (struct vfs_class *me, char *name, vfs_s_super *archive)
static int tar_open_archive (struct vfs_class *me, char *name, struct vfs_s_super *archive)
{
int result, type;
mode_t mode;
@ -124,7 +124,7 @@ static int tar_open_archive (struct vfs_class *me, char *name, vfs_s_super *arch
static union record rec_buf;
static union record *
get_next_record (vfs_s_super *archive, int tard)
get_next_record (struct vfs_s_super *archive, int tard)
{
int n;
@ -135,7 +135,7 @@ get_next_record (vfs_s_super *archive, int tard)
return &rec_buf;
}
static void skip_n_records (vfs_s_super *archive, int tard, int n)
static void skip_n_records (struct vfs_s_super *archive, int tard, int n)
{
mc_lseek (tard, n * RECORDSIZE, SEEK_CUR);
current_tar_position += n * RECORDSIZE;
@ -198,7 +198,7 @@ typedef enum {
*
*/
static ReadStatus
read_header (struct vfs_class *me, vfs_s_super *archive, int tard)
read_header (struct vfs_class *me, struct vfs_s_super *archive, int tard)
{
register int i;
register long sum, signed_sum, recsum;
@ -376,7 +376,7 @@ read_header (struct vfs_class *me, vfs_s_super *archive, int tard)
* Main loop for reading an archive.
* Returns 0 on success, -1 on error.
*/
static int open_archive (struct vfs_class *me, vfs_s_super *archive, char *name, char *op)
static int open_archive (struct vfs_class *me, struct vfs_s_super *archive, char *name, char *op)
{
ReadStatus status = STATUS_EOFMARK; /* Initial status at start of archive */
ReadStatus prev_status;
@ -489,7 +489,7 @@ static int tar_ungetlocalcopy (struct vfs_class *me, char *path, char *local, in
ERRNOR (EROFS, -has_changed);
}
static int tar_fh_open (struct vfs_class *me, vfs_s_fh *fh, int flags, int mode)
static int tar_fh_open (struct vfs_class *me, struct vfs_s_fh *fh, int flags, int mode)
{
if ((flags & O_ACCMODE) != O_RDONLY) ERRNOR (EROFS, -1);
return 0;

Просмотреть файл

@ -32,16 +32,16 @@
#define FL_FOLLOW 1
#define FL_DIR 4
typedef struct vfs_s_entry {
struct vfs_s_entry {
struct vfs_s_entry **prevp, *next;
struct vfs_s_inode *dir; /* Directory we are in - needed for invalidating directory when file in it changes */
char *name; /* Name of this entry */
struct vfs_s_inode *ino; /* ... and its inode */
/* int magic; */
#define ENTRY_MAGIC 0x014512563
} vfs_s_entry;
};
typedef struct vfs_s_inode {
struct vfs_s_inode {
struct vfs_s_entry *subdir;
struct vfs_s_super *super;
struct stat st; /* Parameters of this inode */
@ -49,7 +49,7 @@ typedef struct vfs_s_inode {
char *localname; /* Filename of local file, if we have one */
int flags;
vfs_s_entry *ent; /* ftp needs this backpointer; don't use if you can avoid it */
struct vfs_s_entry *ent; /* ftp needs this backpointer; don't use if you can avoid it */
union {
struct {
@ -68,16 +68,16 @@ typedef struct vfs_s_inode {
} u;
/* int magic; */
#define INODE_MAGIC 0x93451656
} vfs_s_inode;
};
typedef struct vfs_s_super {
struct vfs_s_super {
struct vfs_s_super **prevp, *next;
struct vfs_class *me;
vfs_s_inode *root;
char *name; /* My name, whatever it means */
int fd_usage; /* Number of open files */
int ino_usage; /* Usage count of this superblock */
int want_stale; /* If set, we do not flush cache properly */
struct vfs_s_inode *root;
char *name; /* My name, whatever it means */
int fd_usage; /* Number of open files */
int ino_usage; /* Usage count of this superblock */
int want_stale; /* If set, we do not flush cache properly */
union {
struct {
@ -102,13 +102,13 @@ typedef struct vfs_s_super {
int failed_on_login; /* used to pass the failure reason to upper levels */
int use_source_route;
int use_passive_connection;
int remote_is_amiga; /* No leading slash allowed for AmiTCP (Amiga) */
int remote_is_amiga; /* No leading slash allowed for AmiTCP (Amiga) */
int isbinary;
int cwd_defered; /* current_directory was changed but CWD command hasn't
been sent yet */
int strict; /* ftp server doesn't understand
"LIST -la <path>"; use "CWD <path>"/
"LIST" instead */
int cwd_defered; /* current_directory was changed but CWD command hasn't
been sent yet */
int strict; /* ftp server doesn't understand
"LIST -la <path>"; use "CWD <path>"/
"LIST" instead */
int control_connection_buzy;
#define RFC_AUTODETECT 0
#define RFC_DARING 1
@ -117,21 +117,21 @@ typedef struct vfs_s_super {
struct {
int fd;
struct stat stat;
int type; /* Type of the archive */
/*int pos; In case reentrancy will be needed */
struct defer_inode *defered; /* List of inodes for which another entries may appear */
int type; /* Type of the archive */
/*int pos; In case reentrancy will be needed */
struct defer_inode *defered; /* List of inodes for which another entries may appear */
} cpio;
} u;
/* int magic; */
#define SUPER_MAGIC 0x915ac312
} vfs_s_super;
};
typedef struct vfs_s_fh {
struct vfs_s_fh {
struct vfs_s_inode *ino;
long pos; /* This is for module's use */
int handle; /* This is for module's use, but if != -1, will be mc_close()d */
int changed; /* Did this file change? */
int linear; /* Is that file open with O_LINEAR? */
int handle; /* This is for module's use, but if != -1, will be mc_close()d */
int changed; /* Did this file change? */
int linear; /* Is that file open with O_LINEAR? */
union {
struct {
int got, total, append;
@ -142,7 +142,7 @@ typedef struct vfs_s_fh {
} u;
/* int magic; */
#define FH_MAGIC 0x91324682
} vfs_s_fh;
};
struct vfs_s_data {
struct vfs_s_super *supers;
@ -150,60 +150,81 @@ struct vfs_s_data {
dev_t rdev;
FILE *logfile;
int (*init_inode) (struct vfs_class *me, vfs_s_inode *ino); /* optional */
void (*free_inode) (struct vfs_class *me, vfs_s_inode *ino); /* optional */
int (*init_entry) (struct vfs_class *me, vfs_s_entry *entry); /* optional */
int (*init_inode) (struct vfs_class *me, struct vfs_s_inode *ino); /* optional */
void (*free_inode) (struct vfs_class *me, struct vfs_s_inode *ino); /* optional */
int (*init_entry) (struct vfs_class *me, struct vfs_s_entry *entry); /* optional */
void* (*archive_check) (struct vfs_class *me, char *name, char *op); /* optional */
int (*archive_same) (struct vfs_class *me, vfs_s_super *psup, char *archive_name, char *op, void *cookie);
int (*open_archive) (struct vfs_class *me, vfs_s_super *psup, char *archive_name, char *op);
void (*free_archive) (struct vfs_class *me, vfs_s_super *psup);
void *(*archive_check) (struct vfs_class *me, char *name, char *op); /* optional */
int (*archive_same) (struct vfs_class *me, struct vfs_s_super *psup,
char *archive_name, char *op, void *cookie);
int (*open_archive) (struct vfs_class *me, struct vfs_s_super *psup,
char *archive_name, char *op);
void (*free_archive) (struct vfs_class *me,
struct vfs_s_super *psup);
int (*fh_open) (struct vfs_class *me, vfs_s_fh *fh, int flags, int mode);
int (*fh_close) (struct vfs_class *me, vfs_s_fh *fh);
int (*fh_open) (struct vfs_class *me, struct vfs_s_fh *fh, int flags,
int mode);
int (*fh_close) (struct vfs_class *me, struct vfs_s_fh *fh);
vfs_s_entry* (*find_entry) (struct vfs_class *me, vfs_s_inode *root, char *path, int follow, int flags);
int (*dir_load) (struct vfs_class *me, vfs_s_inode *ino, char *path);
int (*dir_uptodate) (struct vfs_class *me, vfs_s_inode *ino);
int (*file_store) (struct vfs_class *me, vfs_s_fh *fh, char *path, char *localname);
struct vfs_s_entry *(*find_entry) (struct vfs_class *me,
struct vfs_s_inode *root,
char *path, int follow, int flags);
int (*dir_load) (struct vfs_class *me, struct vfs_s_inode *ino,
char *path);
int (*dir_uptodate) (struct vfs_class *me, struct vfs_s_inode *ino);
int (*file_store) (struct vfs_class *me, struct vfs_s_fh *fh,
char *path, char *localname);
int (*linear_start) (struct vfs_class *me, vfs_s_fh *fh, int from);
int (*linear_read) (struct vfs_class *me, vfs_s_fh *fh, void *buf, int len);
void (*linear_close) (struct vfs_class *me, vfs_s_fh *fh);
int (*linear_start) (struct vfs_class *me, struct vfs_s_fh *fh,
int from);
int (*linear_read) (struct vfs_class *me, struct vfs_s_fh *fh,
void *buf, int len);
void (*linear_close) (struct vfs_class *me, struct vfs_s_fh *fh);
};
/* entries and inodes */
vfs_s_inode *vfs_s_new_inode (struct vfs_class *me, vfs_s_super *super,
struct stat *initstat);
vfs_s_entry *vfs_s_new_entry (struct vfs_class *me, char *name, vfs_s_inode *inode);
void vfs_s_free_entry (struct vfs_class *me, vfs_s_entry *ent);
void vfs_s_insert_entry (struct vfs_class *me, vfs_s_inode *dir,
vfs_s_entry *ent);
struct stat *vfs_s_default_stat (struct vfs_class *me, mode_t mode);
struct vfs_s_inode *vfs_s_new_inode (struct vfs_class *me,
struct vfs_s_super *super,
struct stat *initstat);
struct vfs_s_entry *vfs_s_new_entry (struct vfs_class *me, char *name,
struct vfs_s_inode *inode);
void vfs_s_free_entry (struct vfs_class *me, struct vfs_s_entry *ent);
void vfs_s_insert_entry (struct vfs_class *me, struct vfs_s_inode *dir,
struct vfs_s_entry *ent);
struct stat *vfs_s_default_stat (struct vfs_class *me, mode_t mode);
void vfs_s_add_dots (struct vfs_class *me, vfs_s_inode *dir,
vfs_s_inode *parent);
vfs_s_entry *vfs_s_generate_entry (struct vfs_class *me, char *name,
struct vfs_s_inode *parent, mode_t mode);
vfs_s_entry *vfs_s_find_entry_tree (struct vfs_class *me, vfs_s_inode *root, char *path,
void vfs_s_add_dots (struct vfs_class *me, struct vfs_s_inode *dir,
struct vfs_s_inode *parent);
struct vfs_s_entry *vfs_s_generate_entry (struct vfs_class *me, char *name,
struct vfs_s_inode *parent,
mode_t mode);
struct vfs_s_entry *vfs_s_find_entry_tree (struct vfs_class *me,
struct vfs_s_inode *root,
char *path, int follow,
int flags);
struct vfs_s_entry *vfs_s_find_entry_linear (struct vfs_class *me,
struct vfs_s_inode *root,
char *path, int follow,
int flags);
struct vfs_s_inode *vfs_s_find_inode (struct vfs_class *me,
struct vfs_s_inode *root, char *path,
int follow, int flags);
vfs_s_entry *vfs_s_find_entry_linear (struct vfs_class *me, vfs_s_inode *root, char *path,
int follow, int flags);
vfs_s_inode *vfs_s_find_inode (struct vfs_class *me, vfs_s_inode *root, char *path,
int follow, int flags);
vfs_s_inode *vfs_s_find_root (struct vfs_class *me, vfs_s_entry *entry);
struct vfs_s_inode *vfs_s_find_root (struct vfs_class *me,
struct vfs_s_entry *entry);
/* outside interface */
void vfs_s_init_class (struct vfs_class *vclass);
char *vfs_s_get_path_mangle (struct vfs_class *me, char *inname, vfs_s_super **archive,
int flags);
void vfs_s_invalidate (struct vfs_class *me, vfs_s_super *super);
char *vfs_s_fullpath (struct vfs_class *me, vfs_s_inode *ino);
char *vfs_s_get_path_mangle (struct vfs_class *me, char *inname,
struct vfs_s_super **archive, int flags);
void vfs_s_invalidate (struct vfs_class *me, struct vfs_s_super *super);
char *vfs_s_fullpath (struct vfs_class *me, struct vfs_s_inode *ino);
/* network filesystems support */
int vfs_s_select_on_two (int fd1, int fd2);
int vfs_s_get_line (struct vfs_class *me, int sock, char *buf, int buf_len, char term);
int vfs_s_get_line_interruptible (struct vfs_class *me, char *buffer, int size, int fd);
int vfs_s_get_line (struct vfs_class *me, int sock, char *buf, int buf_len,
char term);
int vfs_s_get_line_interruptible (struct vfs_class *me, char *buffer,
int size, int fd);
/* misc */
int vfs_s_retrieve_file (struct vfs_class *me, struct vfs_s_inode *ino);