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>
* xdirentry.h: Cleanup unused or write-only fields. Adjust all
dependencies.
* xdirentry.h: Remove magic numbers. Move some constants ...
* ftpfs.c: ... here.

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

@ -98,10 +98,10 @@ static int cpio_read(void *fh, char *buffer, int count);
#define CPIO_POS(super) cpio_position
/* 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_CUR(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.arch.fd, CPIO_POS(super) += (where), SEEK_SET)
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)
{
switch(super->u.cpio.type) {
switch(super->u.arch.type) {
case CPIO_BIN:
case CPIO_BINRE:
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)
{
if(super->u.cpio.fd != -1)
mc_close(super->u.cpio.fd);
if(super->u.arch.fd != -1)
mc_close(super->u.arch.fd);
}
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->u.cpio.fd = -1; /* for now */
mc_stat(name, &(super->u.cpio.stat));
super->u.cpio.type = CPIO_UNKNOWN;
super->u.arch.fd = -1; /* for now */
mc_stat(name, &(super->u.arch.st));
super->u.arch.type = CPIO_UNKNOWN;
type = get_compression_type(fd);
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);
}
super->u.cpio.fd = fd;
mode = super->u.cpio.stat.st_mode & 07777;
super->u.arch.fd = fd;
mode = super->u.arch.st.st_mode & 07777;
mode |= (mode & 0444) >> 2; /* set eXec where Read is */
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->u.cpio.offset = -1;
root->data_offset = -1;
root->st.st_nlink++;
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 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)))
#define RETURN(x) return(super->u.arch.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)
{
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 tmp;
top = mc_read(super->u.cpio.fd, buf, 256);
top = mc_read(super->u.arch.fd, buf, 256);
CPIO_POS(super) += top;
for(;;) {
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;
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);
cpio_free_archive(me, super);
return CPIO_UNKNOWN;
@ -253,10 +253,10 @@ static int cpio_read_bin_head(struct vfs_class *me, struct vfs_s_super *super)
char *name;
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;
CPIO_POS(super) += len;
if(super->u.cpio.type == CPIO_BINRE) {
if(super->u.arch.type == CPIO_BINRE) {
int i;
for(i = 0; i < (HEAD_LENGTH >> 1); 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);
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);
return STATUS_EOF;
}
@ -299,7 +299,7 @@ static int cpio_read_oldc_head(struct vfs_class *me, struct vfs_s_super *super)
int len;
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;
CPIO_POS(super) += len;
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);
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);
return STATUS_EOF;
}
@ -348,7 +348,7 @@ static int cpio_read_crc_head(struct vfs_class *me, struct vfs_s_super *super)
int len;
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;
CPIO_POS(super) += len;
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;
}
if((super->u.cpio.type == CPIO_NEWC && hd.c_magic != 070701) ||
(super->u.cpio.type == CPIO_CRC && hd.c_magic != 070702))
if((super->u.arch.type == CPIO_NEWC && hd.c_magic != 070701) ||
(super->u.arch.type == CPIO_CRC && hd.c_magic != 070702))
return STATUS_FAIL;
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);
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) &&
(super->u.cpio.type == CPIO_NEWC ||
super->u.cpio.type == CPIO_CRC)) { /* For case of hardlinked files */
(super->u.arch.type == CPIO_NEWC ||
super->u.arch.type == CPIO_CRC)) { /* For case of hardlinked files */
struct defer_inode i, *l;
i.inumber = stat->st_ino;
i.device = stat->st_dev;
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;
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"),
@ -467,20 +467,20 @@ static int cpio_create_entry(struct vfs_class *me, struct vfs_s_super *super, st
if(!inode) {
inode = vfs_s_new_inode(me, super, stat);
if((stat->st_nlink > 0) &&
(super->u.cpio.type == CPIO_NEWC ||
super->u.cpio.type == CPIO_CRC)) { /* For case of hardlinked files */
(super->u.arch.type == CPIO_NEWC ||
super->u.arch.type == CPIO_CRC)) { /* For case of hardlinked files */
struct defer_inode *i;
i = g_new(struct defer_inode, 1);
i->inumber = stat->st_ino;
i->device = stat->st_dev;
i->inode = inode;
i->next = super->u.cpio.defered;
super->u.cpio.defered = i;
i->next = super->u.arch.defered;
super->u.arch.defered = i;
}
}
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);
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)) {
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;
return STATUS_EOF;
}
@ -553,7 +553,7 @@ cpio_super_same (struct vfs_class *me, struct vfs_s_super *parc, char *archive_n
return 0;
/* 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! */
(*vfs_cpiofs_ops.free) ((vfsid) parc);
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)
{
off_t begin = FH->ino->u.tar.data_offset;
int fd = FH_SUPER->u.tar.fd;
off_t begin = FH->ino->data_offset;
int fd = FH_SUPER->u.arch.fd;
struct vfs_class *me = FH_SUPER->me;
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;
return 0;
}
if (tim.tv_sec < ino->u.fish.timestamp.tv_sec)
if (tim.tv_sec < ino->timestamp.tv_sec)
return 1;
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);
gettimeofday(&dir->u.fish.timestamp, NULL);
dir->u.fish.timestamp.tv_sec += 10; /* was 360: 10 is good for
gettimeofday(&dir->timestamp, NULL);
dir->timestamp.tv_sec += 10; /* was 360: 10 is good for
stressing direntry layer a bit */
quoted_path = name_quote (remote_path, 0);
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;
if (offset)
ERRNOR (E_NOTSUPP, 0);
/* fe->local_stat.st_mtime = 0; FIXME: what is this good for? */
name = vfs_s_fullpath (me, fh->ino);
if (!name)
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)
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

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

@ -844,7 +844,7 @@ dir_uptodate(struct vfs_class *me, struct vfs_s_inode *ino)
return 0;
}
gettimeofday(&tim, NULL);
if (tim.tv_sec < ino->u.ftp.timestamp.tv_sec)
if (tim.tv_sec < ino->timestamp.tv_sec)
return 1;
return 0;
}
@ -1254,8 +1254,8 @@ again:
g_free (p);
}
gettimeofday(&dir->u.ftp.timestamp, NULL);
dir->u.ftp.timestamp.tv_sec += ftpfs_directory_timeout;
gettimeofday(&dir->timestamp, NULL);
dir->timestamp.tv_sec += ftpfs_directory_timeout;
if (SUP.strict == RFC_STRICT)
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)
{
if (archive->u.tar.fd != -1)
mc_close(archive->u.tar.fd);
if (archive->u.arch.fd != -1)
mc_close(archive->u.arch.fd);
}
/* 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);
mc_stat (name, &(archive->u.tar.tarstat));
archive->u.tar.fd = -1;
mc_stat (name, &(archive->u.arch.st));
archive->u.arch.fd = -1;
/* Find out the method to handle this tar file */
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);
}
archive->u.tar.fd = result;
mode = archive->u.tar.tarstat.st_mode & 07777;
archive->u.arch.fd = result;
mode = archive->u.arch.st.st_mode & 07777;
if (mode & 0400) mode |= 0100;
if (mode & 0040) mode |= 0010;
if (mode & 0004) mode |= 0001;
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->u.tar.data_offset = -1;
root->data_offset = -1;
root->st.st_nlink++;
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);
inode = vfs_s_new_inode (me, archive, &st);
inode->u.tar.data_offset = data_position;
inode->data_offset = data_position;
if (*current_link_name) {
inode->linkname = current_link_name;
} 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) {
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;
}
@ -453,7 +453,7 @@ tar_super_same (struct vfs_class *me, struct vfs_s_super *parc, char *archive_na
return 0;
/* 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! */
(*vfs_tarfs_ops.free) ((vfsid) parc);
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)
{
off_t begin = FH->ino->u.tar.data_offset;
int fd = FH_SUPER->u.tar.fd;
off_t begin = FH->ino->data_offset;
int fd = FH_SUPER->u.arch.fd;
struct vfs_class *me = FH_SUPER->me;
if (mc_lseek (fd, begin + FH->pos, SEEK_SET) !=

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

@ -45,25 +45,11 @@ struct vfs_s_inode {
struct stat st; /* Parameters of this inode */
char *linkname; /* Symlink's contents */
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 */
union {
struct {
long data_offset;
} tar;
struct {
long offset;
} cpio;
struct {
struct timeval timestamp;
struct stat local_stat;
} fish;
struct {
struct timeval timestamp;
} ftp;
} u;
struct timeval timestamp;
long data_offset;
};
struct vfs_s_super {
@ -76,10 +62,6 @@ struct vfs_s_super {
int want_stale; /* If set, we do not flush cache properly */
union {
struct {
int fd;
struct stat tarstat;
} tar;
struct {
int sockr, sockw;
char *cwdir;
@ -109,11 +91,10 @@ struct vfs_s_super {
} ftp;
struct {
int fd;
struct stat stat;
struct stat st;
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;
} arch;
} u;
};