* xdirentry.h: Cleanup unused or write-only fields. Adjust all
dependencies.
Этот коммит содержится в:
родитель
b7efdfa380
Коммит
a6754ce841
@ -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.
|
||||||
|
|
||||||
|
76
vfs/cpio.c
76
vfs/cpio.c
@ -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);
|
||||||
|
26
vfs/tar.c
26
vfs/tar.c
@ -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;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Загрузка…
x
Ссылка в новой задаче
Block a user