1
1

* xdirentry.h: Cleanup unused or write-only fields. Adjust all

dependencies.
Этот коммит содержится в:
Pavel Roskin 2003-10-16 05:47:23 +00:00
родитель b7efdfa380
Коммит a6754ce841
6 изменённых файлов: 64 добавлений и 83 удалений

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

@ -1,5 +1,8 @@
2003-10-16 Pavel Roskin <proski@gnu.org> 2003-10-16 Pavel Roskin <proski@gnu.org>
* xdirentry.h: Cleanup unused or write-only fields. Adjust all
dependencies.
* xdirentry.h: Remove magic numbers. Move some constants ... * xdirentry.h: Remove magic numbers. Move some constants ...
* ftpfs.c: ... here. * ftpfs.c: ... here.

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

@ -98,10 +98,10 @@ static int cpio_read(void *fh, char *buffer, int count);
#define CPIO_POS(super) cpio_position #define CPIO_POS(super) cpio_position
/* If some time reentrancy should be needed change it to */ /* If some time reentrancy should be needed change it to */
/* #define CPIO_POS(super) (super)->u.cpio.fd */ /* #define CPIO_POS(super) (super)->u.arch.fd */
#define CPIO_SEEK_SET(super, where) mc_lseek((super)->u.cpio.fd, CPIO_POS(super) = (where), SEEK_SET) #define CPIO_SEEK_SET(super, where) mc_lseek((super)->u.arch.fd, CPIO_POS(super) = (where), SEEK_SET)
#define CPIO_SEEK_CUR(super, where) mc_lseek((super)->u.cpio.fd, CPIO_POS(super) += (where), SEEK_SET) #define CPIO_SEEK_CUR(super, where) mc_lseek((super)->u.arch.fd, CPIO_POS(super) += (where), SEEK_SET)
static struct defer_inode * defer_find(struct defer_inode *l, struct defer_inode *i) static struct defer_inode * defer_find(struct defer_inode *l, struct defer_inode *i)
{ {
@ -112,7 +112,7 @@ static struct defer_inode * defer_find(struct defer_inode *l, struct defer_inode
static int cpio_skip_padding(struct vfs_s_super *super) static int cpio_skip_padding(struct vfs_s_super *super)
{ {
switch(super->u.cpio.type) { switch(super->u.arch.type) {
case CPIO_BIN: case CPIO_BIN:
case CPIO_BINRE: case CPIO_BINRE:
return CPIO_SEEK_CUR(super, (2 - (CPIO_POS(super) % 2)) % 2); return CPIO_SEEK_CUR(super, (2 - (CPIO_POS(super) % 2)) % 2);
@ -129,8 +129,8 @@ static int cpio_skip_padding(struct vfs_s_super *super)
static void cpio_free_archive(struct vfs_class *me, struct vfs_s_super *super) static void cpio_free_archive(struct vfs_class *me, struct vfs_s_super *super)
{ {
if(super->u.cpio.fd != -1) if(super->u.arch.fd != -1)
mc_close(super->u.cpio.fd); mc_close(super->u.arch.fd);
} }
static int cpio_open_cpio_file(struct vfs_class *me, struct vfs_s_super *super, char *name) static int cpio_open_cpio_file(struct vfs_class *me, struct vfs_s_super *super, char *name)
@ -145,9 +145,9 @@ static int cpio_open_cpio_file(struct vfs_class *me, struct vfs_s_super *super,
} }
super->name = g_strdup(name); super->name = g_strdup(name);
super->u.cpio.fd = -1; /* for now */ super->u.arch.fd = -1; /* for now */
mc_stat(name, &(super->u.cpio.stat)); mc_stat(name, &(super->u.arch.st));
super->u.cpio.type = CPIO_UNKNOWN; super->u.arch.type = CPIO_UNKNOWN;
type = get_compression_type(fd); type = get_compression_type(fd);
if (type != COMPRESSION_NONE) { if (type != COMPRESSION_NONE) {
@ -163,14 +163,14 @@ static int cpio_open_cpio_file(struct vfs_class *me, struct vfs_s_super *super,
g_free(s); g_free(s);
} }
super->u.cpio.fd = fd; super->u.arch.fd = fd;
mode = super->u.cpio.stat.st_mode & 07777; mode = super->u.arch.st.st_mode & 07777;
mode |= (mode & 0444) >> 2; /* set eXec where Read is */ mode |= (mode & 0444) >> 2; /* set eXec where Read is */
mode |= S_IFDIR; mode |= S_IFDIR;
root = vfs_s_new_inode(me, super, &(super->u.cpio.stat)); root = vfs_s_new_inode(me, super, &(super->u.arch.st));
root->st.st_mode = mode; root->st.st_mode = mode;
root->u.cpio.offset = -1; root->data_offset = -1;
root->st.st_nlink++; root->st.st_nlink++;
root->st.st_dev = MEDATA->rdev++; root->st.st_dev = MEDATA->rdev++;
@ -203,8 +203,8 @@ static int cpio_read_head(struct vfs_class *me, struct vfs_s_super *super)
#define MAGIC_LENGTH (6) /* How many bytes we have to read ahead */ #define MAGIC_LENGTH (6) /* How many bytes we have to read ahead */
#define SEEKBACK CPIO_SEEK_CUR(super, ptr - top) #define SEEKBACK CPIO_SEEK_CUR(super, ptr - top)
#define RETURN(x) return(super->u.cpio.type = (x)) #define RETURN(x) return(super->u.arch.type = (x))
#define TYPEIS(x) ((super->u.cpio.type == CPIO_UNKNOWN) || (super->u.cpio.type == (x))) #define TYPEIS(x) ((super->u.arch.type == CPIO_UNKNOWN) || (super->u.arch.type == (x)))
static int cpio_find_head(struct vfs_class *me, struct vfs_s_super *super) static int cpio_find_head(struct vfs_class *me, struct vfs_s_super *super)
{ {
char buf[256]; char buf[256];
@ -212,7 +212,7 @@ static int cpio_find_head(struct vfs_class *me, struct vfs_s_super *super)
int top = 0; int top = 0;
int tmp; int tmp;
top = mc_read(super->u.cpio.fd, buf, 256); top = mc_read(super->u.arch.fd, buf, 256);
CPIO_POS(super) += top; CPIO_POS(super) += top;
for(;;) { for(;;) {
if(ptr + MAGIC_LENGTH >= top) { if(ptr + MAGIC_LENGTH >= top) {
@ -221,7 +221,7 @@ static int cpio_find_head(struct vfs_class *me, struct vfs_s_super *super)
top = 128; top = 128;
ptr -= top - 128; ptr -= top - 128;
} }
if((tmp = mc_read(super->u.cpio.fd, buf, top)) == 0 || tmp == -1) { if((tmp = mc_read(super->u.arch.fd, buf, top)) == 0 || tmp == -1) {
message_2s(1, MSG_ERROR, _("Premature end of cpio archive\n%s"), super->name); message_2s(1, MSG_ERROR, _("Premature end of cpio archive\n%s"), super->name);
cpio_free_archive(me, super); cpio_free_archive(me, super);
return CPIO_UNKNOWN; return CPIO_UNKNOWN;
@ -253,10 +253,10 @@ static int cpio_read_bin_head(struct vfs_class *me, struct vfs_s_super *super)
char *name; char *name;
struct stat stat; struct stat stat;
if((len = mc_read(super->u.cpio.fd, (char *)&buf, HEAD_LENGTH)) < HEAD_LENGTH) if((len = mc_read(super->u.arch.fd, (char *)&buf, HEAD_LENGTH)) < HEAD_LENGTH)
return STATUS_EOF; return STATUS_EOF;
CPIO_POS(super) += len; CPIO_POS(super) += len;
if(super->u.cpio.type == CPIO_BINRE) { if(super->u.arch.type == CPIO_BINRE) {
int i; int i;
for(i = 0; i < (HEAD_LENGTH >> 1); i++) for(i = 0; i < (HEAD_LENGTH >> 1); i++)
((short *)&buf)[i] = GUINT16_SWAP_LE_BE(((short *)&buf)[i]); ((short *)&buf)[i] = GUINT16_SWAP_LE_BE(((short *)&buf)[i]);
@ -264,7 +264,7 @@ static int cpio_read_bin_head(struct vfs_class *me, struct vfs_s_super *super)
g_assert(buf.c_magic == 070707); g_assert(buf.c_magic == 070707);
name = g_malloc(buf.c_namesize); name = g_malloc(buf.c_namesize);
if((len = mc_read(super->u.cpio.fd, name, buf.c_namesize)) < buf.c_namesize){ if((len = mc_read(super->u.arch.fd, name, buf.c_namesize)) < buf.c_namesize) {
g_free(name); g_free(name);
return STATUS_EOF; return STATUS_EOF;
} }
@ -299,7 +299,7 @@ static int cpio_read_oldc_head(struct vfs_class *me, struct vfs_s_super *super)
int len; int len;
char *name; char *name;
if((len = mc_read(super->u.cpio.fd, buf, HEAD_LENGTH)) < HEAD_LENGTH) if((len = mc_read(super->u.arch.fd, buf, HEAD_LENGTH)) < HEAD_LENGTH)
return STATUS_EOF; return STATUS_EOF;
CPIO_POS(super) += len; CPIO_POS(super) += len;
buf[HEAD_LENGTH] = 0; buf[HEAD_LENGTH] = 0;
@ -313,7 +313,7 @@ static int cpio_read_oldc_head(struct vfs_class *me, struct vfs_s_super *super)
} }
name = g_malloc(hd.c_namesize); name = g_malloc(hd.c_namesize);
if((len = mc_read(super->u.cpio.fd, name, hd.c_namesize)) < hd.c_namesize) { if((len = mc_read(super->u.arch.fd, name, hd.c_namesize)) < hd.c_namesize) {
g_free (name); g_free (name);
return STATUS_EOF; return STATUS_EOF;
} }
@ -348,7 +348,7 @@ static int cpio_read_crc_head(struct vfs_class *me, struct vfs_s_super *super)
int len; int len;
char *name; char *name;
if((len = mc_read(super->u.cpio.fd, buf, HEAD_LENGTH)) < HEAD_LENGTH) if((len = mc_read(super->u.arch.fd, buf, HEAD_LENGTH)) < HEAD_LENGTH)
return STATUS_EOF; return STATUS_EOF;
CPIO_POS(super) += len; CPIO_POS(super) += len;
buf[HEAD_LENGTH] = 0; buf[HEAD_LENGTH] = 0;
@ -363,12 +363,12 @@ static int cpio_read_crc_head(struct vfs_class *me, struct vfs_s_super *super)
return STATUS_FAIL; return STATUS_FAIL;
} }
if((super->u.cpio.type == CPIO_NEWC && hd.c_magic != 070701) || if((super->u.arch.type == CPIO_NEWC && hd.c_magic != 070701) ||
(super->u.cpio.type == CPIO_CRC && hd.c_magic != 070702)) (super->u.arch.type == CPIO_CRC && hd.c_magic != 070702))
return STATUS_FAIL; return STATUS_FAIL;
name = g_malloc(hd.c_namesize); name = g_malloc(hd.c_namesize);
if((len = mc_read(super->u.cpio.fd, name, hd.c_namesize)) < hd.c_namesize){ if((len = mc_read(super->u.arch.fd, name, hd.c_namesize)) < hd.c_namesize) {
g_free (name); g_free (name);
return STATUS_EOF; return STATUS_EOF;
} }
@ -420,13 +420,13 @@ static int cpio_create_entry(struct vfs_class *me, struct vfs_s_super *super, st
} }
if((stat->st_nlink > 1) && if((stat->st_nlink > 1) &&
(super->u.cpio.type == CPIO_NEWC || (super->u.arch.type == CPIO_NEWC ||
super->u.cpio.type == CPIO_CRC)) { /* For case of hardlinked files */ super->u.arch.type == CPIO_CRC)) { /* For case of hardlinked files */
struct defer_inode i, *l; struct defer_inode i, *l;
i.inumber = stat->st_ino; i.inumber = stat->st_ino;
i.device = stat->st_dev; i.device = stat->st_dev;
i.inode = NULL; i.inode = NULL;
if((l = defer_find(super->u.cpio.defered, &i)) != NULL) { if((l = defer_find(super->u.arch.defered, &i)) != NULL) {
inode = l->inode; inode = l->inode;
if(inode->st.st_size && stat->st_size && (inode->st.st_size != stat->st_size)) { if(inode->st.st_size && stat->st_size && (inode->st.st_size != stat->st_size)) {
message_3s(1, MSG_ERROR, _("Inconsistent hardlinks of\n%s\nin cpio archive\n%s"), message_3s(1, MSG_ERROR, _("Inconsistent hardlinks of\n%s\nin cpio archive\n%s"),
@ -467,20 +467,20 @@ static int cpio_create_entry(struct vfs_class *me, struct vfs_s_super *super, st
if(!inode) { if(!inode) {
inode = vfs_s_new_inode(me, super, stat); inode = vfs_s_new_inode(me, super, stat);
if((stat->st_nlink > 0) && if((stat->st_nlink > 0) &&
(super->u.cpio.type == CPIO_NEWC || (super->u.arch.type == CPIO_NEWC ||
super->u.cpio.type == CPIO_CRC)) { /* For case of hardlinked files */ super->u.arch.type == CPIO_CRC)) { /* For case of hardlinked files */
struct defer_inode *i; struct defer_inode *i;
i = g_new(struct defer_inode, 1); i = g_new(struct defer_inode, 1);
i->inumber = stat->st_ino; i->inumber = stat->st_ino;
i->device = stat->st_dev; i->device = stat->st_dev;
i->inode = inode; i->inode = inode;
i->next = super->u.cpio.defered; i->next = super->u.arch.defered;
super->u.cpio.defered = i; super->u.arch.defered = i;
} }
} }
if(stat->st_size) if(stat->st_size)
inode->u.cpio.offset = CPIO_POS(super); inode->data_offset = CPIO_POS(super);
entry = vfs_s_new_entry(me, tn, inode); entry = vfs_s_new_entry(me, tn, inode);
vfs_s_insert_entry(me, root, entry); vfs_s_insert_entry(me, root, entry);
@ -490,7 +490,7 @@ static int cpio_create_entry(struct vfs_class *me, struct vfs_s_super *super, st
if(S_ISLNK(stat->st_mode)) { if(S_ISLNK(stat->st_mode)) {
inode->linkname = g_malloc(stat->st_size + 1); inode->linkname = g_malloc(stat->st_size + 1);
if(mc_read(super->u.cpio.fd, inode->linkname, stat->st_size) < stat->st_size) { if(mc_read(super->u.arch.fd, inode->linkname, stat->st_size) < stat->st_size) {
inode->linkname[0] = 0; inode->linkname[0] = 0;
return STATUS_EOF; return STATUS_EOF;
} }
@ -553,7 +553,7 @@ cpio_super_same (struct vfs_class *me, struct vfs_s_super *parc, char *archive_n
return 0; return 0;
/* Has the cached archive been changed on the disk? */ /* Has the cached archive been changed on the disk? */
if (parc->u.cpio.stat.st_mtime < archive_stat->st_mtime) { if (parc->u.arch.st.st_mtime < archive_stat->st_mtime) {
/* Yes, reload! */ /* Yes, reload! */
(*vfs_cpiofs_ops.free) ((vfsid) parc); (*vfs_cpiofs_ops.free) ((vfsid) parc);
vfs_rmstamp (&vfs_cpiofs_ops, (vfsid) parc, 0); vfs_rmstamp (&vfs_cpiofs_ops, (vfsid) parc, 0);
@ -566,8 +566,8 @@ cpio_super_same (struct vfs_class *me, struct vfs_s_super *parc, char *archive_n
static int cpio_read(void *fh, char *buffer, int count) static int cpio_read(void *fh, char *buffer, int count)
{ {
off_t begin = FH->ino->u.tar.data_offset; off_t begin = FH->ino->data_offset;
int fd = FH_SUPER->u.tar.fd; int fd = FH_SUPER->u.arch.fd;
struct vfs_class *me = FH_SUPER->me; struct vfs_class *me = FH_SUPER->me;
if (mc_lseek (fd, begin + FH->pos, SEEK_SET) != if (mc_lseek (fd, begin + FH->pos, SEEK_SET) !=

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

@ -346,7 +346,7 @@ dir_uptodate(struct vfs_class *me, struct vfs_s_inode *ino)
force_expiration = 0; force_expiration = 0;
return 0; return 0;
} }
if (tim.tv_sec < ino->u.fish.timestamp.tv_sec) if (tim.tv_sec < ino->timestamp.tv_sec)
return 1; return 1;
return 0; return 0;
} }
@ -364,8 +364,8 @@ dir_load(struct vfs_class *me, struct vfs_s_inode *dir, char *remote_path)
print_vfs_message(_("fish: Reading directory %s..."), remote_path); print_vfs_message(_("fish: Reading directory %s..."), remote_path);
gettimeofday(&dir->u.fish.timestamp, NULL); gettimeofday(&dir->timestamp, NULL);
dir->u.fish.timestamp.tv_sec += 10; /* was 360: 10 is good for dir->timestamp.tv_sec += 10; /* was 360: 10 is good for
stressing direntry layer a bit */ stressing direntry layer a bit */
quoted_path = name_quote (remote_path, 0); quoted_path = name_quote (remote_path, 0);
command(me, super, NONE, command(me, super, NONE,
@ -568,7 +568,6 @@ static int linear_start(struct vfs_class *me, struct vfs_s_fh *fh, int offset)
char *quoted_name; char *quoted_name;
if (offset) if (offset)
ERRNOR (E_NOTSUPP, 0); ERRNOR (E_NOTSUPP, 0);
/* fe->local_stat.st_mtime = 0; FIXME: what is this good for? */
name = vfs_s_fullpath (me, fh->ino); name = vfs_s_fullpath (me, fh->ino);
if (!name) if (!name)
return 0; return 0;
@ -642,8 +641,6 @@ linear_close (struct vfs_class *me, struct vfs_s_fh *fh)
{ {
if (fh->u.fish.total != fh->u.fish.got) if (fh->u.fish.total != fh->u.fish.got)
linear_abort(me, fh); linear_abort(me, fh);
else if (stat (fh->ino->localname, &fh->ino->u.fish.local_stat) < 0)
fh->ino->u.fish.local_stat.st_mtime = 0;
} }
static int static int

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

@ -844,7 +844,7 @@ dir_uptodate(struct vfs_class *me, struct vfs_s_inode *ino)
return 0; return 0;
} }
gettimeofday(&tim, NULL); gettimeofday(&tim, NULL);
if (tim.tv_sec < ino->u.ftp.timestamp.tv_sec) if (tim.tv_sec < ino->timestamp.tv_sec)
return 1; return 1;
return 0; return 0;
} }
@ -1254,8 +1254,8 @@ again:
g_free (p); g_free (p);
} }
gettimeofday(&dir->u.ftp.timestamp, NULL); gettimeofday(&dir->timestamp, NULL);
dir->u.ftp.timestamp.tv_sec += ftpfs_directory_timeout; dir->timestamp.tv_sec += ftpfs_directory_timeout;
if (SUP.strict == RFC_STRICT) if (SUP.strict == RFC_STRICT)
sock = open_data_connection (me, super, "LIST", 0, TYPE_ASCII, 0); sock = open_data_connection (me, super, "LIST", 0, TYPE_ASCII, 0);

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

@ -63,8 +63,8 @@ static struct stat hstat; /* Stat struct corresponding */
static void tar_free_archive (struct vfs_class *me, struct vfs_s_super *archive) static void tar_free_archive (struct vfs_class *me, struct vfs_s_super *archive)
{ {
if (archive->u.tar.fd != -1) if (archive->u.arch.fd != -1)
mc_close(archive->u.tar.fd); mc_close(archive->u.arch.fd);
} }
/* As we open one archive at a time, it is safe to have this static */ /* As we open one archive at a time, it is safe to have this static */
@ -84,8 +84,8 @@ static int tar_open_archive (struct vfs_class *me, char *name, struct vfs_s_supe
} }
archive->name = g_strdup (name); archive->name = g_strdup (name);
mc_stat (name, &(archive->u.tar.tarstat)); mc_stat (name, &(archive->u.arch.st));
archive->u.tar.fd = -1; archive->u.arch.fd = -1;
/* Find out the method to handle this tar file */ /* Find out the method to handle this tar file */
type = get_compression_type (result); type = get_compression_type (result);
@ -102,16 +102,16 @@ static int tar_open_archive (struct vfs_class *me, char *name, struct vfs_s_supe
ERRNOR (ENOENT, -1); ERRNOR (ENOENT, -1);
} }
archive->u.tar.fd = result; archive->u.arch.fd = result;
mode = archive->u.tar.tarstat.st_mode & 07777; mode = archive->u.arch.st.st_mode & 07777;
if (mode & 0400) mode |= 0100; if (mode & 0400) mode |= 0100;
if (mode & 0040) mode |= 0010; if (mode & 0040) mode |= 0010;
if (mode & 0004) mode |= 0001; if (mode & 0004) mode |= 0001;
mode |= S_IFDIR; mode |= S_IFDIR;
root = vfs_s_new_inode (me, archive, &archive->u.tar.tarstat); root = vfs_s_new_inode (me, archive, &archive->u.arch.st);
root->st.st_mode = mode; root->st.st_mode = mode;
root->u.tar.data_offset = -1; root->data_offset = -1;
root->st.st_nlink++; root->st.st_nlink++;
root->st.st_dev = MEDATA->rdev++; root->st.st_dev = MEDATA->rdev++;
@ -350,7 +350,7 @@ read_header (struct vfs_class *me, struct vfs_s_super *archive, int tard)
fill_stat_from_header (me, &st, header); fill_stat_from_header (me, &st, header);
inode = vfs_s_new_inode (me, archive, &st); inode = vfs_s_new_inode (me, archive, &st);
inode->u.tar.data_offset = data_position; inode->data_offset = data_position;
if (*current_link_name) { if (*current_link_name) {
inode->linkname = current_link_name; inode->linkname = current_link_name;
} else if (current_link_name != next_long_link) { } else if (current_link_name != next_long_link) {
@ -366,7 +366,7 @@ read_header (struct vfs_class *me, struct vfs_s_super *archive, int tard)
if (header->header.isextended) { if (header->header.isextended) {
while (get_next_record (archive, tard)->ext_hdr.isextended); while (get_next_record (archive, tard)->ext_hdr.isextended);
inode->u.tar.data_offset = current_tar_position; inode->data_offset = current_tar_position;
} }
return STATUS_SUCCESS; return STATUS_SUCCESS;
} }
@ -453,7 +453,7 @@ tar_super_same (struct vfs_class *me, struct vfs_s_super *parc, char *archive_na
return 0; return 0;
/* Has the cached archive been changed on the disk? */ /* Has the cached archive been changed on the disk? */
if (parc->u.tar.tarstat.st_mtime < archive_stat->st_mtime) { if (parc->u.arch.st.st_mtime < archive_stat->st_mtime) {
/* Yes, reload! */ /* Yes, reload! */
(*vfs_tarfs_ops.free) ((vfsid) parc); (*vfs_tarfs_ops.free) ((vfsid) parc);
vfs_rmstamp (&vfs_tarfs_ops, (vfsid) parc, 0); vfs_rmstamp (&vfs_tarfs_ops, (vfsid) parc, 0);
@ -466,8 +466,8 @@ tar_super_same (struct vfs_class *me, struct vfs_s_super *parc, char *archive_na
static int tar_read (void *fh, char *buffer, int count) static int tar_read (void *fh, char *buffer, int count)
{ {
off_t begin = FH->ino->u.tar.data_offset; off_t begin = FH->ino->data_offset;
int fd = FH_SUPER->u.tar.fd; int fd = FH_SUPER->u.arch.fd;
struct vfs_class *me = FH_SUPER->me; struct vfs_class *me = FH_SUPER->me;
if (mc_lseek (fd, begin + FH->pos, SEEK_SET) != if (mc_lseek (fd, begin + FH->pos, SEEK_SET) !=

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

@ -45,25 +45,11 @@ struct vfs_s_inode {
struct stat st; /* Parameters of this inode */ struct stat st; /* Parameters of this inode */
char *linkname; /* Symlink's contents */ char *linkname; /* Symlink's contents */
char *localname; /* Filename of local file, if we have one */ char *localname; /* Filename of local file, if we have one */
int flags;
struct 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 timeval timestamp;
struct { long data_offset;
long data_offset;
} tar;
struct {
long offset;
} cpio;
struct {
struct timeval timestamp;
struct stat local_stat;
} fish;
struct {
struct timeval timestamp;
} ftp;
} u;
}; };
struct vfs_s_super { struct vfs_s_super {
@ -76,10 +62,6 @@ struct vfs_s_super {
int want_stale; /* If set, we do not flush cache properly */ int want_stale; /* If set, we do not flush cache properly */
union { union {
struct {
int fd;
struct stat tarstat;
} tar;
struct { struct {
int sockr, sockw; int sockr, sockw;
char *cwdir; char *cwdir;
@ -109,11 +91,10 @@ struct vfs_s_super {
} ftp; } ftp;
struct { struct {
int fd; int fd;
struct stat stat; struct stat st;
int type; /* Type of the archive */ 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 */ struct defer_inode *defered; /* List of inodes for which another entries may appear */
} cpio; } arch;
} u; } u;
}; };