1
1

* 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
Этот коммит содержится в:
Andrew V. Samoilov 2000-10-16 18:37:54 +00:00
родитель 6f10b0fdb3
Коммит a1e4132357

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

@ -269,27 +269,25 @@ command (vfs *me, vfs_s_super *super, int wait_reply, char *fmt, ...)
int sock = SUP.sock; int sock = SUP.sock;
va_start (ap, fmt); va_start (ap, fmt);
fmt_str = g_strdup_vprintf (fmt, ap); fmt_str = g_strdup_vprintf (fmt, ap);
va_end (ap); va_end (ap);
str = g_strconcat (fmt_str, "\r\n", NULL); status = strlen (fmt_str);
g_free (fmt_str); str = g_realloc (fmt_str, status + 3);
strcpy (str + status, "\r\n");
if (logfile){ if (logfile){
if (strncmp (str, "PASS ", 5) == 0){ if (strncmp (str, "PASS ", 5) == 0){
char *tmp = "PASS <Password not logged>\r\n"; fputs ("PASS <Password not logged>\r\n", logfile);
fwrite (tmp, strlen (tmp), 1, logfile);
} else } else
fwrite (str, strlen (str), 1, logfile); fwrite (str, status + 2, 1, logfile);
fflush (logfile); fflush (logfile);
} }
got_sigpipe = 0; got_sigpipe = 0;
enable_interrupt_key (); enable_interrupt_key ();
status = write (SUP.sock, str, strlen (str)); status = write (SUP.sock, str, status + 2);
g_free (str); g_free (str);
if (status < 0){ if (status < 0){
@ -962,7 +960,9 @@ open_data_connection (vfs *me, vfs_s_super *super, char *cmd, char *remote,
} }
if (remote) { if (remote) {
char * remote_path = translate_path (me, super, 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); g_free (remote_path);
} else } else
j = command (me, super, WAIT_REPLY, "%s", cmd); 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; data = s;
else { else {
data = accept (s, (struct sockaddr *)&from, &fromlen); data = accept (s, (struct sockaddr *)&from, &fromlen);
close(s);
if (data < 0) { if (data < 0) {
my_errno = errno; my_errno = errno;
close(s);
return -1; return -1;
} }
close(s);
} }
disable_interrupt_key(); disable_interrupt_key();
return data; return data;
@ -1222,7 +1221,7 @@ dir_load(vfs *me, vfs_s_inode *dir, char *remote_path)
enable_interrupt_key (); enable_interrupt_key ();
while (1) { while (1) {
int i, j; int i;
int res = vfs_s_get_line_interruptible (me, buffer, sizeof (buffer), sock); int res = vfs_s_get_line_interruptible (me, buffer, sizeof (buffer), sock);
if (!res) if (!res)
break; 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); ent = vfs_s_generate_entry(me, NULL, dir, 0);
i = ent->ino->st.st_nlink; i = ent->ino->st.st_nlink;
j = vfs_parse_ls_lga (buffer, &ent->ino->st, &ent->name, &ent->ino->linkname); if (!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) {
vfs_s_free_entry (me, ent); vfs_s_free_entry (me, ent);
continue; continue;
} }
ent->ino->st.st_nlink = i; /* Ouch, we need to preserve our counts :-( */
num_entries++; num_entries++;
if ((!strcmp(ent->name, ".")) || (!strcmp (ent->name, ".."))) { if ((!strcmp(ent->name, ".")) || (!strcmp (ent->name, ".."))) {
g_free (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); 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 #ifdef FIXME_LATER_ALIGATOR
static void my_forget (char *file) static void my_forget (char *file)
{ {
@ -1637,7 +1630,7 @@ static struct vfs_s_data ftp_data = {
NULL, NULL,
0, 0,
0, 0,
NULL, NULL, /* logfile */
NULL, /* init_inode */ NULL, /* init_inode */
NULL, /* free_inode */ NULL, /* free_inode */
@ -1663,13 +1656,13 @@ static struct vfs_s_data ftp_data = {
vfs vfs_ftpfs_ops = { vfs vfs_ftpfs_ops = {
NULL, /* This is place of next pointer */ NULL, /* This is place of next pointer */
"File Tranfer Protocol (ftp)", N_("File Tranfer Protocol (ftp)"),
F_NET, /* flags */ F_NET, /* flags */
"ftp:", /* prefix */ "ftp:", /* prefix */
&ftp_data, /* data */ &ftp_data, /* data */
0, /* errno */ 0, /* errno */
NULL, NULL, /* init */
NULL, NULL, /* done */
vfs_s_fill_names, vfs_s_fill_names,
NULL, NULL,
@ -1718,6 +1711,13 @@ vfs vfs_ftpfs_ops = {
MMAPNULL MMAPNULL
}; };
void ftpfs_set_debug (const char *file)
{
logfile = fopen (file, "w+");
if (logfile)
ftp_data.logfile = logfile;
}
#ifdef USE_NETRC #ifdef USE_NETRC
static char buffer[BUF_MEDIUM]; static char buffer[BUF_MEDIUM];
static char *netrc, *netrcp; static char *netrc, *netrcp;