* ftpfs.c (open_data_connection): don't generate //filename, some
ftp servers can't store it; (command): g_strdup_vprintf() and g_strconcat() replaced by g_strdup_vprintf(), g_realloc() and strcpy() to reduce memory usage when trailing "\r\n" added; (ftpfs_set_debug, ftp_data): ftp_data.logfile assigned with logfile value to log servers replies
Этот коммит содержится в:
родитель
6f10b0fdb3
Коммит
a1e4132357
48
vfs/ftpfs.c
48
vfs/ftpfs.c
@ -269,27 +269,25 @@ command (vfs *me, vfs_s_super *super, int wait_reply, char *fmt, ...)
|
||||
int sock = SUP.sock;
|
||||
|
||||
va_start (ap, fmt);
|
||||
|
||||
fmt_str = g_strdup_vprintf (fmt, ap);
|
||||
va_end (ap);
|
||||
|
||||
str = g_strconcat (fmt_str, "\r\n", NULL);
|
||||
g_free (fmt_str);
|
||||
status = strlen (fmt_str);
|
||||
str = g_realloc (fmt_str, status + 3);
|
||||
strcpy (str + status, "\r\n");
|
||||
|
||||
if (logfile){
|
||||
if (strncmp (str, "PASS ", 5) == 0){
|
||||
char *tmp = "PASS <Password not logged>\r\n";
|
||||
|
||||
fwrite (tmp, strlen (tmp), 1, logfile);
|
||||
fputs ("PASS <Password not logged>\r\n", logfile);
|
||||
} else
|
||||
fwrite (str, strlen (str), 1, logfile);
|
||||
fwrite (str, status + 2, 1, logfile);
|
||||
|
||||
fflush (logfile);
|
||||
}
|
||||
|
||||
got_sigpipe = 0;
|
||||
enable_interrupt_key ();
|
||||
status = write (SUP.sock, str, strlen (str));
|
||||
status = write (SUP.sock, str, status + 2);
|
||||
g_free (str);
|
||||
|
||||
if (status < 0){
|
||||
@ -962,7 +960,9 @@ open_data_connection (vfs *me, vfs_s_super *super, char *cmd, char *remote,
|
||||
}
|
||||
if (remote) {
|
||||
char * remote_path = translate_path (me, super, remote);
|
||||
j = command (me, super, WAIT_REPLY, "%s /%s", cmd, remote_path);
|
||||
j = command (me, super, WAIT_REPLY, "%s /%s", cmd,
|
||||
/* WarFtpD can't STORE //filename */
|
||||
(*remote_path == '/') ? remote_path + 1 : remote_path);
|
||||
g_free (remote_path);
|
||||
} else
|
||||
j = command (me, super, WAIT_REPLY, "%s", cmd);
|
||||
@ -973,12 +973,11 @@ open_data_connection (vfs *me, vfs_s_super *super, char *cmd, char *remote,
|
||||
data = s;
|
||||
else {
|
||||
data = accept (s, (struct sockaddr *)&from, &fromlen);
|
||||
close(s);
|
||||
if (data < 0) {
|
||||
my_errno = errno;
|
||||
close(s);
|
||||
return -1;
|
||||
}
|
||||
close(s);
|
||||
}
|
||||
disable_interrupt_key();
|
||||
return data;
|
||||
@ -1222,7 +1221,7 @@ dir_load(vfs *me, vfs_s_inode *dir, char *remote_path)
|
||||
enable_interrupt_key ();
|
||||
|
||||
while (1) {
|
||||
int i, j;
|
||||
int i;
|
||||
int res = vfs_s_get_line_interruptible (me, buffer, sizeof (buffer), sock);
|
||||
if (!res)
|
||||
break;
|
||||
@ -1238,12 +1237,11 @@ dir_load(vfs *me, vfs_s_inode *dir, char *remote_path)
|
||||
|
||||
ent = vfs_s_generate_entry(me, NULL, dir, 0);
|
||||
i = ent->ino->st.st_nlink;
|
||||
j = vfs_parse_ls_lga (buffer, &ent->ino->st, &ent->name, &ent->ino->linkname);
|
||||
ent->ino->st.st_nlink = i; /* Ouch, we need to preserve our counts :-( */
|
||||
if (!j) {
|
||||
if (!vfs_parse_ls_lga (buffer, &ent->ino->st, &ent->name, &ent->ino->linkname)) {
|
||||
vfs_s_free_entry (me, ent);
|
||||
continue;
|
||||
}
|
||||
ent->ino->st.st_nlink = i; /* Ouch, we need to preserve our counts :-( */
|
||||
num_entries++;
|
||||
if ((!strcmp(ent->name, ".")) || (!strcmp (ent->name, ".."))) {
|
||||
g_free (ent->name);
|
||||
@ -1566,11 +1564,6 @@ static int ftpfs_rmdir (vfs *me, char *path)
|
||||
return send_ftp_command(me, path, "RMD /%s", OPT_FLUSH);
|
||||
}
|
||||
|
||||
void ftpfs_set_debug (const char *file)
|
||||
{
|
||||
logfile = fopen (file, "w+");
|
||||
}
|
||||
|
||||
#ifdef FIXME_LATER_ALIGATOR
|
||||
static void my_forget (char *file)
|
||||
{
|
||||
@ -1637,7 +1630,7 @@ static struct vfs_s_data ftp_data = {
|
||||
NULL,
|
||||
0,
|
||||
0,
|
||||
NULL,
|
||||
NULL, /* logfile */
|
||||
|
||||
NULL, /* init_inode */
|
||||
NULL, /* free_inode */
|
||||
@ -1663,13 +1656,13 @@ static struct vfs_s_data ftp_data = {
|
||||
|
||||
vfs vfs_ftpfs_ops = {
|
||||
NULL, /* This is place of next pointer */
|
||||
"File Tranfer Protocol (ftp)",
|
||||
N_("File Tranfer Protocol (ftp)"),
|
||||
F_NET, /* flags */
|
||||
"ftp:", /* prefix */
|
||||
&ftp_data, /* data */
|
||||
0, /* errno */
|
||||
NULL,
|
||||
NULL,
|
||||
NULL, /* init */
|
||||
NULL, /* done */
|
||||
vfs_s_fill_names,
|
||||
NULL,
|
||||
|
||||
@ -1718,6 +1711,13 @@ vfs vfs_ftpfs_ops = {
|
||||
MMAPNULL
|
||||
};
|
||||
|
||||
void ftpfs_set_debug (const char *file)
|
||||
{
|
||||
logfile = fopen (file, "w+");
|
||||
if (logfile)
|
||||
ftp_data.logfile = logfile;
|
||||
}
|
||||
|
||||
#ifdef USE_NETRC
|
||||
static char buffer[BUF_MEDIUM];
|
||||
static char *netrc, *netrcp;
|
||||
|
Загрузка…
Ссылка в новой задаче
Block a user