mirror of
https://github.com/MidnightCommander/mc
synced 2025-01-26 05:02:03 +03:00
Changed interface of functions mc_getlocalcopy() and mc_ungetlocalcopy()
...to handle vfs_path_t object as parameter. Signed-off-by: Slava Zanko <slavazanko@gmail.com>
This commit is contained in:
parent
893ed22259
commit
490af62655
@ -742,11 +742,11 @@ vfs_s_ferrno (struct vfs_class *me)
|
|||||||
* for remote filesystems. Archives use standard VFS facilities.
|
* for remote filesystems. Archives use standard VFS facilities.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static char *
|
static vfs_path_t *
|
||||||
vfs_s_getlocalcopy (const vfs_path_t * vpath)
|
vfs_s_getlocalcopy (const vfs_path_t * vpath)
|
||||||
{
|
{
|
||||||
vfs_file_handler_t *fh;
|
vfs_file_handler_t *fh;
|
||||||
char *local = NULL;
|
vfs_path_t *local = NULL;
|
||||||
|
|
||||||
if (vpath == NULL)
|
if (vpath == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
@ -759,7 +759,7 @@ vfs_s_getlocalcopy (const vfs_path_t * vpath)
|
|||||||
|
|
||||||
me = vfs_path_get_by_index (vpath, -1)->class;
|
me = vfs_path_get_by_index (vpath, -1)->class;
|
||||||
if ((MEDATA->flags & VFS_S_USETMP) != 0 && (fh->ino != NULL))
|
if ((MEDATA->flags & VFS_S_USETMP) != 0 && (fh->ino != NULL))
|
||||||
local = g_strdup (fh->ino->localname);
|
local = vfs_path_from_str_flags (fh->ino->localname, VPF_NO_CANON);
|
||||||
|
|
||||||
vfs_s_close (fh);
|
vfs_s_close (fh);
|
||||||
}
|
}
|
||||||
@ -774,7 +774,7 @@ vfs_s_getlocalcopy (const vfs_path_t * vpath)
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
static int
|
static int
|
||||||
vfs_s_ungetlocalcopy (const vfs_path_t * vpath, const char *local, int has_changed)
|
vfs_s_ungetlocalcopy (const vfs_path_t * vpath, const vfs_path_t * local, gboolean has_changed)
|
||||||
{
|
{
|
||||||
(void) vpath;
|
(void) vpath;
|
||||||
(void) local;
|
(void) local;
|
||||||
|
@ -75,23 +75,20 @@ struct dirent *mc_readdir_result = NULL;
|
|||||||
/*** file scope functions ************************************************************************/
|
/*** file scope functions ************************************************************************/
|
||||||
/* --------------------------------------------------------------------------------------------- */
|
/* --------------------------------------------------------------------------------------------- */
|
||||||
|
|
||||||
static char *
|
static vfs_path_t *
|
||||||
mc_def_getlocalcopy (const char *filename)
|
mc_def_getlocalcopy (const vfs_path_t * filename_vpath)
|
||||||
{
|
{
|
||||||
char *tmp = NULL;
|
|
||||||
vfs_path_t *tmp_vpath = NULL;
|
vfs_path_t *tmp_vpath = NULL;
|
||||||
int fdin = -1, fdout = -1;
|
int fdin = -1, fdout = -1;
|
||||||
ssize_t i;
|
ssize_t i;
|
||||||
char buffer[BUF_1K * 8];
|
char buffer[BUF_1K * 8];
|
||||||
struct stat mystat;
|
struct stat mystat;
|
||||||
vfs_path_t *vpath;
|
|
||||||
|
|
||||||
vpath = vfs_path_from_str (filename);
|
fdin = mc_open (filename_vpath, O_RDONLY | O_LINEAR);
|
||||||
fdin = mc_open (vpath, O_RDONLY | O_LINEAR);
|
|
||||||
if (fdin == -1)
|
if (fdin == -1)
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
fdout = vfs_mkstemps (&tmp_vpath, "vfs", filename);
|
fdout = vfs_mkstemps (&tmp_vpath, "vfs", vfs_path_get_last_path_str (filename_vpath));
|
||||||
if (fdout == -1)
|
if (fdout == -1)
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
@ -114,44 +111,43 @@ mc_def_getlocalcopy (const char *filename)
|
|||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mc_stat (vpath, &mystat) != -1)
|
if (mc_stat (filename_vpath, &mystat) != -1)
|
||||||
mc_chmod (tmp_vpath, mystat.st_mode);
|
mc_chmod (tmp_vpath, mystat.st_mode);
|
||||||
|
|
||||||
tmp = vfs_path_to_str (tmp_vpath);
|
return tmp_vpath;
|
||||||
|
|
||||||
fail:
|
fail:
|
||||||
vfs_path_free (vpath);
|
|
||||||
vfs_path_free (tmp_vpath);
|
vfs_path_free (tmp_vpath);
|
||||||
if (fdout != -1)
|
if (fdout != -1)
|
||||||
close (fdout);
|
close (fdout);
|
||||||
if (fdin != -1)
|
if (fdin != -1)
|
||||||
mc_close (fdin);
|
mc_close (fdin);
|
||||||
return tmp;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------- */
|
/* --------------------------------------------------------------------------------------------- */
|
||||||
|
|
||||||
static int
|
static int
|
||||||
mc_def_ungetlocalcopy (struct vfs_class *vfs, const char *filename,
|
mc_def_ungetlocalcopy (const vfs_path_t * filename_vpath,
|
||||||
const char *local, int has_changed)
|
const vfs_path_t * local_vpath, gboolean has_changed)
|
||||||
{
|
{
|
||||||
vfs_path_t *vpath;
|
|
||||||
int fdin = -1, fdout = -1;
|
int fdin = -1, fdout = -1;
|
||||||
|
char *local;
|
||||||
|
|
||||||
vpath = vfs_path_from_str (filename);
|
local = vfs_path_get_last_path_str (local_vpath);
|
||||||
|
|
||||||
if (has_changed)
|
if (has_changed)
|
||||||
{
|
{
|
||||||
char buffer[BUF_1K * 8];
|
char buffer[BUF_1K * 8];
|
||||||
ssize_t i;
|
ssize_t i;
|
||||||
|
|
||||||
if (!vfs->write)
|
if (vfs_path_get_last_path_vfs (filename_vpath)->write == NULL)
|
||||||
goto failed;
|
goto failed;
|
||||||
|
|
||||||
fdin = open (local, O_RDONLY);
|
fdin = open (local, O_RDONLY);
|
||||||
if (fdin == -1)
|
if (fdin == -1)
|
||||||
goto failed;
|
goto failed;
|
||||||
fdout = mc_open (vpath, O_WRONLY | O_TRUNC);
|
fdout = mc_open (filename_vpath, O_WRONLY | O_TRUNC);
|
||||||
if (fdout == -1)
|
if (fdout == -1)
|
||||||
goto failed;
|
goto failed;
|
||||||
while ((i = read (fdin, buffer, sizeof (buffer))) > 0)
|
while ((i = read (fdin, buffer, sizeof (buffer))) > 0)
|
||||||
@ -173,17 +169,15 @@ mc_def_ungetlocalcopy (struct vfs_class *vfs, const char *filename,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
unlink (local);
|
unlink (local);
|
||||||
vfs_path_free (vpath);
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
failed:
|
failed:
|
||||||
message (D_ERROR, _("Changes to file lost"), "%s", filename);
|
message (D_ERROR, _("Changes to file lost"), "%s", vfs_path_get_last_path_str (filename_vpath));
|
||||||
if (fdout != -1)
|
if (fdout != -1)
|
||||||
mc_close (fdout);
|
mc_close (fdout);
|
||||||
if (fdin != -1)
|
if (fdin != -1)
|
||||||
close (fdin);
|
close (fdin);
|
||||||
unlink (local);
|
unlink (local);
|
||||||
vfs_path_free (vpath);
|
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -622,53 +616,47 @@ mc_get_current_wd (char *buffer, size_t size)
|
|||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------- */
|
/* --------------------------------------------------------------------------------------------- */
|
||||||
|
|
||||||
char *
|
vfs_path_t *
|
||||||
mc_getlocalcopy (const char *pathname)
|
mc_getlocalcopy (const vfs_path_t * pathname_vpath)
|
||||||
{
|
{
|
||||||
char *result = NULL;
|
vfs_path_t *result = NULL;
|
||||||
vfs_path_t *vpath;
|
|
||||||
vfs_path_element_t *path_element;
|
vfs_path_element_t *path_element;
|
||||||
|
|
||||||
vpath = vfs_path_from_str (pathname);
|
if (pathname_vpath == NULL)
|
||||||
if (vpath == NULL)
|
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
path_element = vfs_path_get_by_index (vpath, -1);
|
path_element = vfs_path_get_by_index (pathname_vpath, -1);
|
||||||
|
|
||||||
if (vfs_path_element_valid (path_element))
|
if (vfs_path_element_valid (path_element))
|
||||||
{
|
{
|
||||||
result = path_element->class->getlocalcopy != NULL ?
|
result = path_element->class->getlocalcopy != NULL ?
|
||||||
path_element->class->getlocalcopy (vpath) : mc_def_getlocalcopy (pathname);
|
path_element->class-> getlocalcopy (pathname_vpath) :
|
||||||
|
mc_def_getlocalcopy (pathname_vpath);
|
||||||
if (result == NULL)
|
if (result == NULL)
|
||||||
errno = vfs_ferrno (path_element->class);
|
errno = vfs_ferrno (path_element->class);
|
||||||
}
|
}
|
||||||
vfs_path_free (vpath);
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------- */
|
/* --------------------------------------------------------------------------------------------- */
|
||||||
|
|
||||||
int
|
int
|
||||||
mc_ungetlocalcopy (const char *pathname, const char *local, int has_changed)
|
mc_ungetlocalcopy (const vfs_path_t * pathname_vpath, const vfs_path_t * local_vpath,
|
||||||
|
gboolean has_changed)
|
||||||
{
|
{
|
||||||
int return_value = -1;
|
int return_value = -1;
|
||||||
vfs_path_t *vpath;
|
|
||||||
vfs_path_element_t *path_element;
|
vfs_path_element_t *path_element;
|
||||||
|
|
||||||
vpath = vfs_path_from_str (pathname);
|
if (pathname_vpath == NULL)
|
||||||
if (vpath == NULL)
|
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
path_element = vfs_path_get_by_index (vpath, -1);
|
path_element = vfs_path_get_by_index (pathname_vpath, -1);
|
||||||
|
|
||||||
if (vfs_path_element_valid (path_element))
|
if (vfs_path_element_valid (path_element))
|
||||||
{
|
|
||||||
return_value = path_element->class->ungetlocalcopy != NULL ?
|
return_value = path_element->class->ungetlocalcopy != NULL ?
|
||||||
path_element->class->ungetlocalcopy (vpath, local,
|
path_element->class->ungetlocalcopy (pathname_vpath, local_vpath, has_changed) :
|
||||||
has_changed) :
|
mc_def_ungetlocalcopy (pathname_vpath, local_vpath, has_changed);
|
||||||
mc_def_ungetlocalcopy (path_element->class, path_element->path, local, has_changed);
|
|
||||||
}
|
|
||||||
vfs_path_free (vpath);
|
|
||||||
return return_value;
|
return return_value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -184,8 +184,9 @@ typedef struct vfs_class
|
|||||||
int (*nothingisopen) (vfsid id);
|
int (*nothingisopen) (vfsid id);
|
||||||
void (*free) (vfsid id);
|
void (*free) (vfsid id);
|
||||||
|
|
||||||
char *(*getlocalcopy) (const vfs_path_t * vpath);
|
vfs_path_t *(*getlocalcopy) (const vfs_path_t * vpath);
|
||||||
int (*ungetlocalcopy) (const vfs_path_t * vpath, const char *local, int has_changed);
|
int (*ungetlocalcopy) (const vfs_path_t * vpath, const vfs_path_t * local_vpath,
|
||||||
|
gboolean has_changed);
|
||||||
|
|
||||||
int (*mkdir) (const vfs_path_t * vpath, mode_t mode);
|
int (*mkdir) (const vfs_path_t * vpath, mode_t mode);
|
||||||
int (*rmdir) (const vfs_path_t * vpath);
|
int (*rmdir) (const vfs_path_t * vpath);
|
||||||
@ -301,8 +302,9 @@ int mc_ctl (int fd, int ctlop, void *arg);
|
|||||||
int mc_setctl (const vfs_path_t * vpath, int ctlop, void *arg);
|
int mc_setctl (const vfs_path_t * vpath, int ctlop, void *arg);
|
||||||
int mc_open (const vfs_path_t * vpath, int flags, ...);
|
int mc_open (const vfs_path_t * vpath, int flags, ...);
|
||||||
char *mc_get_current_wd (char *buffer, size_t bufsize);
|
char *mc_get_current_wd (char *buffer, size_t bufsize);
|
||||||
char *mc_getlocalcopy (const char *pathname);
|
vfs_path_t *mc_getlocalcopy (const vfs_path_t * pathname_vpath);
|
||||||
int mc_ungetlocalcopy (const char *pathname, const char *local, int has_changed);
|
int mc_ungetlocalcopy (const vfs_path_t * pathname_vpath, const vfs_path_t * local_vpath,
|
||||||
|
gboolean has_changed);
|
||||||
int mc_mkstemps (vfs_path_t ** pname_vpath, const char *prefix, const char *suffix);
|
int mc_mkstemps (vfs_path_t ** pname_vpath, const char *prefix, const char *suffix);
|
||||||
|
|
||||||
/* Creating temporary files safely */
|
/* Creating temporary files safely */
|
||||||
|
@ -3331,22 +3331,18 @@ diff_view (const char *file1, const char *file2, const char *label1, const char
|
|||||||
#define GET_FILE_AND_STAMP(n) \
|
#define GET_FILE_AND_STAMP(n) \
|
||||||
do \
|
do \
|
||||||
{ \
|
{ \
|
||||||
vfs_path_t *vpath = vfs_path_from_str(file##n); \
|
|
||||||
use_copy##n = 0; \
|
use_copy##n = 0; \
|
||||||
real_file##n = file##n; \
|
real_file##n = file##n; \
|
||||||
if (!vfs_file_is_local (vpath)) \
|
if (!vfs_file_is_local (file##n)) \
|
||||||
{ \
|
{ \
|
||||||
real_file##n = mc_getlocalcopy (file##n); \
|
real_file##n = mc_getlocalcopy (file##n); \
|
||||||
if (real_file##n != NULL) \
|
if (real_file##n != NULL) \
|
||||||
{ \
|
{ \
|
||||||
vfs_path_t *tmp_vpath = vfs_path_from_str (real_file##n); \
|
|
||||||
use_copy##n = 1; \
|
use_copy##n = 1; \
|
||||||
if (mc_stat (tmp_vpath, &st##n) != 0) \
|
if (mc_stat (real_file##n, &st##n) != 0) \
|
||||||
use_copy##n = -1; \
|
use_copy##n = -1; \
|
||||||
vfs_path_free (tmp_vpath); \
|
|
||||||
} \
|
} \
|
||||||
} \
|
} \
|
||||||
vfs_path_free(vpath); \
|
|
||||||
} \
|
} \
|
||||||
while (0)
|
while (0)
|
||||||
|
|
||||||
@ -3359,14 +3355,12 @@ do \
|
|||||||
if (use_copy##n > 0) \
|
if (use_copy##n > 0) \
|
||||||
{ \
|
{ \
|
||||||
time_t mtime; \
|
time_t mtime; \
|
||||||
vfs_path_t *tmp_vpath = vfs_path_from_str (real_file##n); \
|
|
||||||
mtime = st##n.st_mtime; \
|
mtime = st##n.st_mtime; \
|
||||||
if (mc_stat (tmp_vpath, &st##n) == 0) \
|
if (mc_stat (real_file##n, &st##n) == 0) \
|
||||||
changed = (mtime != st##n.st_mtime); \
|
changed = (mtime != st##n.st_mtime); \
|
||||||
vfs_path_free (tmp_vpath); \
|
|
||||||
} \
|
} \
|
||||||
mc_ungetlocalcopy (file##n, real_file##n, changed); \
|
mc_ungetlocalcopy (file##n, real_file##n, changed); \
|
||||||
g_free (real_file##n); \
|
vfs_path_free (real_file##n); \
|
||||||
} \
|
} \
|
||||||
} \
|
} \
|
||||||
while (0)
|
while (0)
|
||||||
@ -3375,8 +3369,8 @@ void
|
|||||||
dview_diff_cmd (void)
|
dview_diff_cmd (void)
|
||||||
{
|
{
|
||||||
int rv = 0;
|
int rv = 0;
|
||||||
char *file0 = NULL;
|
vfs_path_t *file0 = NULL;
|
||||||
char *file1 = NULL;
|
vfs_path_t *file1 = NULL;
|
||||||
int is_dir0 = 0;
|
int is_dir0 = 0;
|
||||||
int is_dir1 = 0;
|
int is_dir1 = 0;
|
||||||
|
|
||||||
@ -3389,8 +3383,8 @@ dview_diff_cmd (void)
|
|||||||
panel0 = other_panel;
|
panel0 = other_panel;
|
||||||
panel1 = current_panel;
|
panel1 = current_panel;
|
||||||
}
|
}
|
||||||
file0 = concat_dir_and_file (panel0->cwd, selection (panel0)->fname);
|
file0 = vfs_path_build_filename (panel0->cwd, selection (panel0)->fname, NULL);
|
||||||
file1 = concat_dir_and_file (panel1->cwd, selection (panel1)->fname);
|
file1 = vfs_path_build_filename (panel1->cwd, selection (panel1)->fname, NULL);
|
||||||
is_dir0 = S_ISDIR (selection (panel0)->st.st_mode);
|
is_dir0 = S_ISDIR (selection (panel0)->st.st_mode);
|
||||||
is_dir1 = S_ISDIR (selection (panel1)->st.st_mode);
|
is_dir1 = S_ISDIR (selection (panel1)->st.st_mode);
|
||||||
}
|
}
|
||||||
@ -3404,21 +3398,33 @@ dview_diff_cmd (void)
|
|||||||
int use_copy1;
|
int use_copy1;
|
||||||
struct stat st0;
|
struct stat st0;
|
||||||
struct stat st1;
|
struct stat st1;
|
||||||
char *real_file0;
|
vfs_path_t *real_file0;
|
||||||
char *real_file1;
|
vfs_path_t *real_file1;
|
||||||
|
|
||||||
GET_FILE_AND_STAMP (0);
|
GET_FILE_AND_STAMP (0);
|
||||||
GET_FILE_AND_STAMP (1);
|
GET_FILE_AND_STAMP (1);
|
||||||
if (real_file0 != NULL && real_file1 != NULL)
|
if (real_file0 != NULL && real_file1 != NULL)
|
||||||
{
|
{
|
||||||
rv = diff_view (real_file0, real_file1, file0, file1);
|
char *real_file0_str, *real_file1_str;
|
||||||
|
char *file0_str, *file1_str;
|
||||||
|
|
||||||
|
real_file0_str = vfs_path_to_str (real_file0);
|
||||||
|
real_file1_str = vfs_path_to_str (real_file1);
|
||||||
|
file0_str = vfs_path_to_str (file0);
|
||||||
|
file1_str = vfs_path_to_str (file1);
|
||||||
|
rv = diff_view (real_file0_str, real_file1_str, file0_str, file1_str);
|
||||||
|
g_free (real_file0_str);
|
||||||
|
g_free (real_file1_str);
|
||||||
|
g_free (file0_str);
|
||||||
|
g_free (file1_str);
|
||||||
}
|
}
|
||||||
UNGET_FILE (1);
|
UNGET_FILE (1);
|
||||||
UNGET_FILE (0);
|
UNGET_FILE (0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
g_free (file1);
|
vfs_path_free (file1);
|
||||||
g_free (file0);
|
vfs_path_free (file0);
|
||||||
|
|
||||||
if (rv == 0)
|
if (rv == 0)
|
||||||
message (D_ERROR, MSG_ERROR, _("Two files are needed to compare"));
|
message (D_ERROR, MSG_ERROR, _("Two files are needed to compare"));
|
||||||
|
@ -438,8 +438,6 @@ execute_suspend (const gchar * event_group_name, const gchar * event_name,
|
|||||||
void
|
void
|
||||||
execute_with_vfs_arg (const char *command, const char *filename)
|
execute_with_vfs_arg (const char *command, const char *filename)
|
||||||
{
|
{
|
||||||
char *localcopy;
|
|
||||||
char *fn;
|
|
||||||
struct stat st;
|
struct stat st;
|
||||||
time_t mtime;
|
time_t mtime;
|
||||||
vfs_path_t *vpath = vfs_path_from_str (filename);
|
vfs_path_t *vpath = vfs_path_from_str (filename);
|
||||||
@ -448,40 +446,38 @@ execute_with_vfs_arg (const char *command, const char *filename)
|
|||||||
/* Simplest case, this file is local */
|
/* Simplest case, this file is local */
|
||||||
if (!filename || vfs_file_is_local (vpath))
|
if (!filename || vfs_file_is_local (vpath))
|
||||||
{
|
{
|
||||||
fn = vfs_path_to_str (vpath);
|
do_execute (command, vfs_path_get_last_path_str (vpath), EXECUTE_INTERNAL);
|
||||||
do_execute (command, fn, EXECUTE_INTERNAL);
|
|
||||||
g_free (fn);
|
|
||||||
vfs_path_free (vpath);
|
vfs_path_free (vpath);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
vfs_path_free (vpath);
|
|
||||||
|
|
||||||
/* FIXME: Creation of new files on VFS is not supported */
|
/* FIXME: Creation of new files on VFS is not supported */
|
||||||
if (!*filename)
|
if (!*filename)
|
||||||
return;
|
|
||||||
|
|
||||||
localcopy = mc_getlocalcopy (filename);
|
|
||||||
if (localcopy == NULL)
|
|
||||||
{
|
{
|
||||||
message (D_ERROR, MSG_ERROR, _("Cannot fetch a local copy of %s"), filename);
|
vfs_path_free (vpath);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
localcopy_vpath = mc_getlocalcopy (vpath);
|
||||||
|
if (localcopy_vpath == NULL)
|
||||||
|
{
|
||||||
|
message (D_ERROR, MSG_ERROR, _("Cannot fetch a local copy of %s"), filename);
|
||||||
|
vfs_path_free (vpath);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
localcopy_vpath = vfs_path_from_str (localcopy);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* filename can be an entry on panel, it can be changed by executing
|
* filename can be an entry on panel, it can be changed by executing
|
||||||
* the command, so make a copy. Smarter VFS code would make the code
|
* the command, so make a copy. Smarter VFS code would make the code
|
||||||
* below unnecessary.
|
* below unnecessary.
|
||||||
*/
|
*/
|
||||||
fn = g_strdup (filename);
|
|
||||||
mc_stat (localcopy_vpath, &st);
|
mc_stat (localcopy_vpath, &st);
|
||||||
mtime = st.st_mtime;
|
mtime = st.st_mtime;
|
||||||
do_execute (command, localcopy, EXECUTE_INTERNAL);
|
do_execute (command, vfs_path_get_last_path_str (localcopy_vpath), EXECUTE_INTERNAL);
|
||||||
mc_stat (localcopy_vpath, &st);
|
mc_stat (localcopy_vpath, &st);
|
||||||
mc_ungetlocalcopy (fn, localcopy, mtime != st.st_mtime);
|
mc_ungetlocalcopy (vpath, localcopy_vpath, mtime != st.st_mtime);
|
||||||
g_free (localcopy);
|
|
||||||
vfs_path_free (localcopy_vpath);
|
vfs_path_free (localcopy_vpath);
|
||||||
g_free (fn);
|
vfs_path_free (vpath);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------- */
|
/* --------------------------------------------------------------------------------------------- */
|
||||||
|
@ -106,7 +106,7 @@ exec_extension (const char *filename, const char *lc_data, int *move_dir, int st
|
|||||||
int is_cd = 0;
|
int is_cd = 0;
|
||||||
char buffer[1024];
|
char buffer[1024];
|
||||||
char *p = 0;
|
char *p = 0;
|
||||||
char *localcopy = NULL;
|
vfs_path_t *localcopy_vpath = NULL;
|
||||||
int do_local_copy;
|
int do_local_copy;
|
||||||
time_t localmtime = 0;
|
time_t localmtime = 0;
|
||||||
struct stat mystat;
|
struct stat mystat;
|
||||||
@ -155,10 +155,10 @@ exec_extension (const char *filename, const char *lc_data, int *move_dir, int st
|
|||||||
/* User canceled */
|
/* User canceled */
|
||||||
fclose (cmd_file);
|
fclose (cmd_file);
|
||||||
mc_unlink (file_name_vpath);
|
mc_unlink (file_name_vpath);
|
||||||
if (localcopy)
|
if (localcopy_vpath != NULL)
|
||||||
{
|
{
|
||||||
mc_ungetlocalcopy (filename, localcopy, 0);
|
mc_ungetlocalcopy (vpath, localcopy_vpath, FALSE);
|
||||||
g_free (localcopy);
|
vfs_path_free (localcopy_vpath);
|
||||||
}
|
}
|
||||||
goto ret;
|
goto ret;
|
||||||
}
|
}
|
||||||
@ -223,20 +223,18 @@ exec_extension (const char *filename, const char *lc_data, int *move_dir, int st
|
|||||||
{
|
{
|
||||||
if (do_local_copy)
|
if (do_local_copy)
|
||||||
{
|
{
|
||||||
vfs_path_t *vpath_local;
|
localcopy_vpath = mc_getlocalcopy (vpath);
|
||||||
|
if (localcopy_vpath == NULL)
|
||||||
localcopy = mc_getlocalcopy (filename);
|
|
||||||
if (localcopy == NULL)
|
|
||||||
{
|
{
|
||||||
fclose (cmd_file);
|
fclose (cmd_file);
|
||||||
mc_unlink (file_name_vpath);
|
mc_unlink (file_name_vpath);
|
||||||
goto ret;
|
goto ret;
|
||||||
}
|
}
|
||||||
vpath_local = vfs_path_from_str (localcopy);
|
mc_stat (localcopy_vpath, &mystat);
|
||||||
mc_stat (vpath_local, &mystat);
|
|
||||||
localmtime = mystat.st_mtime;
|
localmtime = mystat.st_mtime;
|
||||||
text = quote_func (localcopy, 0);
|
text =
|
||||||
vfs_path_free (vpath_local);
|
quote_func (vfs_path_get_last_path_str (localcopy_vpath),
|
||||||
|
0);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -382,15 +380,11 @@ exec_extension (const char *filename, const char *lc_data, int *move_dir, int st
|
|||||||
|
|
||||||
g_free (cmd);
|
g_free (cmd);
|
||||||
|
|
||||||
if (localcopy)
|
if (localcopy_vpath != NULL)
|
||||||
{
|
{
|
||||||
vfs_path_t *vpath_local;
|
mc_stat (localcopy_vpath, &mystat);
|
||||||
|
mc_ungetlocalcopy (vpath, localcopy_vpath, localmtime != mystat.st_mtime);
|
||||||
vpath_local = vfs_path_from_str (localcopy);
|
vfs_path_free (localcopy_vpath);
|
||||||
mc_stat (vpath_local, &mystat);
|
|
||||||
mc_ungetlocalcopy (filename, localcopy, localmtime != mystat.st_mtime);
|
|
||||||
vfs_path_free (vpath_local);
|
|
||||||
g_free (localcopy);
|
|
||||||
}
|
}
|
||||||
ret:
|
ret:
|
||||||
vfs_path_free (file_name_vpath);
|
vfs_path_free (file_name_vpath);
|
||||||
@ -512,8 +506,9 @@ regex_check_type (const char *filename, const char *ptr, int *have_type)
|
|||||||
|
|
||||||
if (*have_type == 0)
|
if (*have_type == 0)
|
||||||
{
|
{
|
||||||
|
vfs_path_t *filename_vpath;
|
||||||
|
vfs_path_t *localfile_vpath;
|
||||||
char *realname; /* name used with "file" */
|
char *realname; /* name used with "file" */
|
||||||
char *localfile;
|
|
||||||
|
|
||||||
#ifdef HAVE_CHARSET
|
#ifdef HAVE_CHARSET
|
||||||
int got_encoding_data;
|
int got_encoding_data;
|
||||||
@ -522,15 +517,20 @@ regex_check_type (const char *filename, const char *ptr, int *have_type)
|
|||||||
/* Don't repeate even unsuccessful checks */
|
/* Don't repeate even unsuccessful checks */
|
||||||
*have_type = 1;
|
*have_type = 1;
|
||||||
|
|
||||||
localfile = mc_getlocalcopy (filename);
|
filename_vpath = vfs_path_from_str (filename);
|
||||||
if (localfile == NULL)
|
localfile_vpath = mc_getlocalcopy (filename_vpath);
|
||||||
|
if (localfile_vpath == NULL)
|
||||||
|
{
|
||||||
|
vfs_path_free (filename_vpath);
|
||||||
return -1;
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
realname = localfile;
|
realname = vfs_path_get_last_path_str (localfile_vpath);
|
||||||
|
|
||||||
#ifdef HAVE_CHARSET
|
#ifdef HAVE_CHARSET
|
||||||
got_encoding_data = is_autodetect_codeset_enabled
|
got_encoding_data = is_autodetect_codeset_enabled
|
||||||
? get_file_encoding_local (localfile, encoding_id, sizeof (encoding_id)) : 0;
|
? get_file_encoding_local (vfs_path_get_last_path_str (localfile_vpath), encoding_id,
|
||||||
|
sizeof (encoding_id)) : 0;
|
||||||
|
|
||||||
if (got_encoding_data > 0)
|
if (got_encoding_data > 0)
|
||||||
{
|
{
|
||||||
@ -549,9 +549,12 @@ regex_check_type (const char *filename, const char *ptr, int *have_type)
|
|||||||
}
|
}
|
||||||
#endif /* HAVE_CHARSET */
|
#endif /* HAVE_CHARSET */
|
||||||
|
|
||||||
mc_ungetlocalcopy (filename, localfile, 0);
|
mc_ungetlocalcopy (filename_vpath, localfile_vpath, FALSE);
|
||||||
|
vfs_path_free (filename_vpath);
|
||||||
|
|
||||||
got_data = get_file_type_local (localfile, content_string, sizeof (content_string));
|
got_data =
|
||||||
|
get_file_type_local (vfs_path_get_last_path_str (localfile_vpath), content_string,
|
||||||
|
sizeof (content_string));
|
||||||
|
|
||||||
if (got_data > 0)
|
if (got_data > 0)
|
||||||
{
|
{
|
||||||
@ -583,7 +586,7 @@ regex_check_type (const char *filename, const char *ptr, int *have_type)
|
|||||||
/* No data */
|
/* No data */
|
||||||
content_string[0] = '\0';
|
content_string[0] = '\0';
|
||||||
}
|
}
|
||||||
g_free (realname);
|
vfs_path_free (localfile_vpath);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (got_data == -1)
|
if (got_data == -1)
|
||||||
|
@ -375,13 +375,15 @@ extfs_free_archive (struct archive *archive)
|
|||||||
if (archive->local_name != NULL)
|
if (archive->local_name != NULL)
|
||||||
{
|
{
|
||||||
struct stat my;
|
struct stat my;
|
||||||
vfs_path_t *tmp_vpath;
|
vfs_path_t *local_name_vpath, *name_vpath;
|
||||||
|
|
||||||
tmp_vpath = vfs_path_from_str (archive->local_name);
|
local_name_vpath = vfs_path_from_str (archive->local_name);
|
||||||
mc_stat (tmp_vpath, &my);
|
name_vpath = vfs_path_from_str (archive->local_name);
|
||||||
vfs_path_free (tmp_vpath);
|
mc_stat (local_name_vpath, &my);
|
||||||
mc_ungetlocalcopy (archive->name, archive->local_name,
|
mc_ungetlocalcopy (name_vpath, local_name_vpath,
|
||||||
archive->local_stat.st_mtime != my.st_mtime);
|
archive->local_stat.st_mtime != my.st_mtime);
|
||||||
|
vfs_path_free (local_name_vpath);
|
||||||
|
vfs_path_free (name_vpath);
|
||||||
g_free (archive->local_name);
|
g_free (archive->local_name);
|
||||||
}
|
}
|
||||||
g_free (archive->name);
|
g_free (archive->name);
|
||||||
@ -401,32 +403,31 @@ extfs_open_archive (int fstype, const char *name, struct archive **pparc)
|
|||||||
struct stat mystat;
|
struct stat mystat;
|
||||||
struct archive *current_archive;
|
struct archive *current_archive;
|
||||||
struct entry *root_entry;
|
struct entry *root_entry;
|
||||||
char *local_name = NULL, *tmp = NULL;
|
char *tmp = NULL;
|
||||||
vfs_path_t *vpath;
|
vfs_path_t *local_name_vpath = NULL;
|
||||||
vfs_path_element_t *path_element = NULL;
|
vfs_path_t *name_vpath;
|
||||||
|
|
||||||
vpath = vfs_path_from_str (name);
|
|
||||||
if (vpath != NULL)
|
|
||||||
path_element = vfs_path_get_by_index (vpath, -1);
|
|
||||||
|
|
||||||
|
name_vpath = vfs_path_from_str (name);
|
||||||
info = &g_array_index (extfs_plugins, extfs_plugin_info_t, fstype);
|
info = &g_array_index (extfs_plugins, extfs_plugin_info_t, fstype);
|
||||||
|
|
||||||
if (info->need_archive)
|
if (info->need_archive)
|
||||||
{
|
{
|
||||||
if (mc_stat (vpath, &mystat) == -1)
|
if (mc_stat (name_vpath, &mystat) == -1)
|
||||||
goto ret;
|
goto ret;
|
||||||
|
|
||||||
if (!vfs_file_is_local (vpath))
|
if (!vfs_file_is_local (name_vpath))
|
||||||
{
|
{
|
||||||
local_name = mc_getlocalcopy (name);
|
local_name_vpath = mc_getlocalcopy (name_vpath);
|
||||||
if (local_name == NULL)
|
if (local_name_vpath == NULL)
|
||||||
goto ret;
|
goto ret;
|
||||||
}
|
}
|
||||||
tmp = name_quote ((vpath != NULL) ? path_element->path : name, 0);
|
|
||||||
|
tmp = name_quote ( vfs_path_get_last_path_str (name_vpath), 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
cmd = g_strconcat (info->path, info->prefix, " list ",
|
cmd = g_strconcat (info->path, info->prefix, " list ",
|
||||||
local_name != NULL ? local_name : tmp, (char *) NULL);
|
vfs_path_get_last_path_str (local_name_vpath) != NULL ?
|
||||||
|
vfs_path_get_last_path_str (local_name_vpath) : tmp, (char *) NULL);
|
||||||
g_free (tmp);
|
g_free (tmp);
|
||||||
|
|
||||||
open_error_pipe ();
|
open_error_pipe ();
|
||||||
@ -435,10 +436,10 @@ extfs_open_archive (int fstype, const char *name, struct archive **pparc)
|
|||||||
if (result == NULL)
|
if (result == NULL)
|
||||||
{
|
{
|
||||||
close_error_pipe (D_ERROR, NULL);
|
close_error_pipe (D_ERROR, NULL);
|
||||||
if (local_name != NULL)
|
if (local_name_vpath != NULL)
|
||||||
{
|
{
|
||||||
mc_ungetlocalcopy (name, local_name, 0);
|
mc_ungetlocalcopy (name_vpath, local_name_vpath, FALSE);
|
||||||
g_free (local_name);
|
vfs_path_free (local_name_vpath);
|
||||||
}
|
}
|
||||||
goto ret;
|
goto ret;
|
||||||
}
|
}
|
||||||
@ -450,13 +451,12 @@ extfs_open_archive (int fstype, const char *name, struct archive **pparc)
|
|||||||
current_archive = g_new (struct archive, 1);
|
current_archive = g_new (struct archive, 1);
|
||||||
current_archive->fstype = fstype;
|
current_archive->fstype = fstype;
|
||||||
current_archive->name = (name != NULL) ? g_strdup (name) : NULL;
|
current_archive->name = (name != NULL) ? g_strdup (name) : NULL;
|
||||||
current_archive->local_name = local_name;
|
current_archive->local_name = g_strdup (vfs_path_get_last_path_str (local_name_vpath));
|
||||||
|
|
||||||
if (local_name != NULL)
|
if (local_name_vpath != NULL)
|
||||||
{
|
{
|
||||||
vfs_path_t *tmp_vpath = vfs_path_from_str (local_name);
|
mc_stat (local_name_vpath, ¤t_archive->local_stat);
|
||||||
mc_stat (tmp_vpath, ¤t_archive->local_stat);
|
vfs_path_free (local_name_vpath);
|
||||||
vfs_path_free (tmp_vpath);
|
|
||||||
}
|
}
|
||||||
current_archive->inode_counter = 0;
|
current_archive->inode_counter = 0;
|
||||||
current_archive->fd_usage = 0;
|
current_archive->fd_usage = 0;
|
||||||
@ -482,7 +482,7 @@ extfs_open_archive (int fstype, const char *name, struct archive **pparc)
|
|||||||
*pparc = current_archive;
|
*pparc = current_archive;
|
||||||
|
|
||||||
ret:
|
ret:
|
||||||
vfs_path_free (vpath);
|
vfs_path_free (name_vpath);
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1503,11 +1503,11 @@ extfs_free (vfsid id)
|
|||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------- */
|
/* --------------------------------------------------------------------------------------------- */
|
||||||
|
|
||||||
static char *
|
static vfs_path_t *
|
||||||
extfs_getlocalcopy (const vfs_path_t * vpath)
|
extfs_getlocalcopy (const vfs_path_t * vpath)
|
||||||
{
|
{
|
||||||
struct pseudofile *fp;
|
struct pseudofile *fp;
|
||||||
char *p;
|
vfs_path_t *p;
|
||||||
|
|
||||||
fp = (struct pseudofile *) extfs_open (vpath, O_RDONLY, 0);
|
fp = (struct pseudofile *) extfs_open (vpath, O_RDONLY, 0);
|
||||||
if (fp == NULL)
|
if (fp == NULL)
|
||||||
@ -1517,7 +1517,7 @@ extfs_getlocalcopy (const vfs_path_t * vpath)
|
|||||||
extfs_close ((void *) fp);
|
extfs_close ((void *) fp);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
p = g_strdup (fp->entry->inode->local_filename);
|
p = vfs_path_from_str (fp->entry->inode->local_filename);
|
||||||
fp->archive->fd_usage++;
|
fp->archive->fd_usage++;
|
||||||
extfs_close ((void *) fp);
|
extfs_close ((void *) fp);
|
||||||
return p;
|
return p;
|
||||||
@ -1526,7 +1526,7 @@ extfs_getlocalcopy (const vfs_path_t * vpath)
|
|||||||
/* --------------------------------------------------------------------------------------------- */
|
/* --------------------------------------------------------------------------------------------- */
|
||||||
|
|
||||||
static int
|
static int
|
||||||
extfs_ungetlocalcopy (const vfs_path_t * vpath, const char *local, int has_changed)
|
extfs_ungetlocalcopy (const vfs_path_t * vpath, const vfs_path_t * local, gboolean has_changed)
|
||||||
{
|
{
|
||||||
struct pseudofile *fp;
|
struct pseudofile *fp;
|
||||||
|
|
||||||
@ -1534,10 +1534,10 @@ extfs_ungetlocalcopy (const vfs_path_t * vpath, const char *local, int has_chang
|
|||||||
if (fp == NULL)
|
if (fp == NULL)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (strcmp (fp->entry->inode->local_filename, local) == 0)
|
if (strcmp (fp->entry->inode->local_filename, vfs_path_get_last_path_str (local)) == 0)
|
||||||
{
|
{
|
||||||
fp->archive->fd_usage--;
|
fp->archive->fd_usage--;
|
||||||
if (has_changed != 0)
|
if (has_changed)
|
||||||
fp->has_changed = TRUE;
|
fp->has_changed = TRUE;
|
||||||
extfs_close ((void *) fp);
|
extfs_close ((void *) fp);
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -294,18 +294,16 @@ local_rmdir (const vfs_path_t * vpath)
|
|||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------- */
|
/* --------------------------------------------------------------------------------------------- */
|
||||||
|
|
||||||
static char *
|
static vfs_path_t *
|
||||||
local_getlocalcopy (const vfs_path_t * vpath)
|
local_getlocalcopy (const vfs_path_t * vpath)
|
||||||
{
|
{
|
||||||
vfs_path_element_t *path_element = vfs_path_get_by_index (vpath, -1);
|
return vfs_path_clone (vpath);
|
||||||
|
|
||||||
return g_strdup (path_element->path);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------- */
|
/* --------------------------------------------------------------------------------------------- */
|
||||||
|
|
||||||
static int
|
static int
|
||||||
local_ungetlocalcopy (const vfs_path_t * vpath, const char *local, int has_changed)
|
local_ungetlocalcopy (const vfs_path_t * vpath, const vfs_path_t * local, gboolean has_changed)
|
||||||
{
|
{
|
||||||
(void) vpath;
|
(void) vpath;
|
||||||
(void) local;
|
(void) local;
|
||||||
|
@ -74,7 +74,7 @@
|
|||||||
return -1; \
|
return -1; \
|
||||||
} \
|
} \
|
||||||
else \
|
else \
|
||||||
*t++ = *s;
|
*t++ = *s_iter;
|
||||||
|
|
||||||
#define COPY_STRING(a) \
|
#define COPY_STRING(a) \
|
||||||
if ((t - pad) + strlen(a) > sizeof(pad)) \
|
if ((t - pad) + strlen(a) > sizeof(pad)) \
|
||||||
@ -124,52 +124,58 @@ sfs_vfmake (const vfs_path_t * vpath, vfs_path_t * cache_vpath)
|
|||||||
{
|
{
|
||||||
int w;
|
int w;
|
||||||
char pad[10240];
|
char pad[10240];
|
||||||
char *s, *t = pad;
|
char *s_iter, *t = pad;
|
||||||
int was_percent = 0;
|
int was_percent = 0;
|
||||||
char *pname; /* name of parent archive */
|
vfs_path_t *pname, *s; /* name of parent archive */
|
||||||
char *pqname; /* name of parent archive, quoted */
|
char *pqname; /* name of parent archive, quoted */
|
||||||
vfs_path_element_t *path_element;
|
vfs_path_element_t *path_element;
|
||||||
|
|
||||||
path_element = vfs_path_get_by_index (vpath, -1);
|
path_element = vfs_path_get_by_index (vpath, -1);
|
||||||
pname = vfs_path_to_str_elements_count (vpath, -1);
|
pname = vfs_path_clone (vpath);
|
||||||
|
vfs_path_remove_element_by_index (pname, -1);
|
||||||
|
|
||||||
w = (*path_element->class->which) (path_element->class, path_element->vfs_prefix);
|
w = (*path_element->class->which) (path_element->class, path_element->vfs_prefix);
|
||||||
if (w == -1)
|
if (w == -1)
|
||||||
vfs_die ("This cannot happen... Hopefully.\n");
|
vfs_die ("This cannot happen... Hopefully.\n");
|
||||||
|
|
||||||
if (!(sfs_flags[w] & F_1) && strcmp (pname, "/"))
|
if ((sfs_flags[w] & F_1) == 0 && strcmp (vfs_path_get_last_path_str (pname), PATH_SEP_STR) != 0)
|
||||||
{
|
{
|
||||||
g_free (pname);
|
vfs_path_free (pname);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* if ((sfs_flags[w] & F_2) || (!inpath) || (!*inpath)); else return -1; */
|
/* if ((sfs_flags[w] & F_2) || (!inpath) || (!*inpath)); else return -1; */
|
||||||
if (!(sfs_flags[w] & F_NOLOCALCOPY))
|
if ((sfs_flags[w] & F_NOLOCALCOPY) == 0)
|
||||||
{
|
{
|
||||||
s = mc_getlocalcopy (pname);
|
s = mc_getlocalcopy (pname);
|
||||||
if (!s)
|
if (s == NULL)
|
||||||
{
|
{
|
||||||
g_free (pname);
|
vfs_path_free (pname);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
pqname = name_quote (s, 0);
|
pqname = name_quote (vfs_path_get_last_path_str (s), 0);
|
||||||
g_free (s);
|
vfs_path_free (s);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
pqname = name_quote (pname, 0);
|
char *pname_str;
|
||||||
|
|
||||||
|
pname_str = vfs_path_to_str (pname);
|
||||||
|
pqname = name_quote (pname_str, 0);
|
||||||
|
g_free (pname_str);
|
||||||
}
|
}
|
||||||
g_free (pname);
|
vfs_path_free (pname);
|
||||||
|
|
||||||
|
|
||||||
for (s = sfs_command[w]; *s; s++)
|
for (s_iter = sfs_command[w]; *s_iter != '\0'; s_iter++)
|
||||||
{
|
{
|
||||||
if (was_percent)
|
if (was_percent)
|
||||||
{
|
{
|
||||||
|
|
||||||
const char *ptr = NULL;
|
const char *ptr = NULL;
|
||||||
|
|
||||||
was_percent = 0;
|
was_percent = 0;
|
||||||
|
|
||||||
switch (*s)
|
switch (*s_iter)
|
||||||
{
|
{
|
||||||
case '1':
|
case '1':
|
||||||
ptr = pqname;
|
ptr = pqname;
|
||||||
@ -193,7 +199,7 @@ sfs_vfmake (const vfs_path_t * vpath, vfs_path_t * cache_vpath)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (*s == '%')
|
if (*s_iter == '%')
|
||||||
was_percent = 1;
|
was_percent = 1;
|
||||||
else
|
else
|
||||||
COPY_CHAR;
|
COPY_CHAR;
|
||||||
@ -392,16 +398,16 @@ sfs_nothingisopen (vfsid id)
|
|||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------- */
|
/* --------------------------------------------------------------------------------------------- */
|
||||||
|
|
||||||
static char *
|
static vfs_path_t *
|
||||||
sfs_getlocalcopy (const vfs_path_t * vpath)
|
sfs_getlocalcopy (const vfs_path_t * vpath)
|
||||||
{
|
{
|
||||||
return g_strdup (sfs_redirect (vpath));
|
return vfs_path_from_str (sfs_redirect (vpath));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* --------------------------------------------------------------------------------------------- */
|
/* --------------------------------------------------------------------------------------------- */
|
||||||
|
|
||||||
static int
|
static int
|
||||||
sfs_ungetlocalcopy (const vfs_path_t * vpath, const char *local, int has_changed)
|
sfs_ungetlocalcopy (const vfs_path_t * vpath, const vfs_path_t * local, gboolean has_changed)
|
||||||
{
|
{
|
||||||
(void) vpath;
|
(void) vpath;
|
||||||
(void) local;
|
(void) local;
|
||||||
|
Loading…
Reference in New Issue
Block a user