mirror of
https://github.com/rkd77/elinks.git
synced 2024-12-04 14:46:47 -05:00
ftp: ftp didn't handle filenames with spaces.
This commit is contained in:
parent
026e56d539
commit
3f4de99f16
@ -63,12 +63,8 @@ init_directory_listing(struct string *page, struct uri *uri)
|
|||||||
&& !add_char_to_string(&dirpath, local ? CHAR_DIR_SEP : '/'))
|
&& !add_char_to_string(&dirpath, local ? CHAR_DIR_SEP : '/'))
|
||||||
goto out_of_memory;
|
goto out_of_memory;
|
||||||
|
|
||||||
if (local || uri->protocol == PROTOCOL_FSP || uri->protocol == PROTOCOL_GOPHER
|
/* Decode uri for displaying. */
|
||||||
|| uri->protocol == PROTOCOL_SMB) {
|
decode_uri_string(&dirpath);
|
||||||
/* A little hack to get readable Gopher names. We should find a
|
|
||||||
* way to do it more general. */
|
|
||||||
decode_uri_string(&dirpath);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!local && !add_char_to_string(&location, '/'))
|
if (!local && !add_char_to_string(&location, '/'))
|
||||||
goto out_of_memory;
|
goto out_of_memory;
|
||||||
|
@ -683,8 +683,15 @@ add_file_cmd_to_str(struct connection *conn)
|
|||||||
|
|
||||||
if (!conn->uri->datalen
|
if (!conn->uri->datalen
|
||||||
|| conn->uri->data[conn->uri->datalen - 1] == '/') {
|
|| conn->uri->data[conn->uri->datalen - 1] == '/') {
|
||||||
|
struct string uri_string;
|
||||||
/* Commands to get directory listing. */
|
/* Commands to get directory listing. */
|
||||||
|
|
||||||
|
if (!init_string(&uri_string)) {
|
||||||
|
done_string(&command);
|
||||||
|
done_string(&ftp_data_command);
|
||||||
|
abort_connection(conn, S_OUT_OF_MEM);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
ftp->dir = 1;
|
ftp->dir = 1;
|
||||||
ftp->pending_commands = 4;
|
ftp->pending_commands = 4;
|
||||||
|
|
||||||
@ -695,17 +702,27 @@ add_file_cmd_to_str(struct connection *conn)
|
|||||||
add_string_to_string(&command, &ftp_data_command);
|
add_string_to_string(&command, &ftp_data_command);
|
||||||
|
|
||||||
add_to_string(&command, "CWD ");
|
add_to_string(&command, "CWD ");
|
||||||
add_uri_to_string(&command, conn->uri, URI_PATH);
|
add_uri_to_string(&uri_string, conn->uri, URI_PATH);
|
||||||
|
decode_uri_string(&uri_string);
|
||||||
|
add_string_to_string(&command, &uri_string);
|
||||||
add_crlf_to_string(&command);
|
add_crlf_to_string(&command);
|
||||||
|
|
||||||
add_to_string(&command, "LIST");
|
add_to_string(&command, "LIST");
|
||||||
add_crlf_to_string(&command);
|
add_crlf_to_string(&command);
|
||||||
|
done_string(&uri_string);
|
||||||
|
|
||||||
conn->from = 0;
|
conn->from = 0;
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
struct string uri_string;
|
||||||
/* Commands to get a file. */
|
/* Commands to get a file. */
|
||||||
|
|
||||||
|
if (!init_string(&uri_string)) {
|
||||||
|
done_string(&command);
|
||||||
|
done_string(&ftp_data_command);
|
||||||
|
abort_connection(conn, S_OUT_OF_MEM);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
ftp->dir = 0;
|
ftp->dir = 0;
|
||||||
ftp->pending_commands = 3;
|
ftp->pending_commands = 3;
|
||||||
|
|
||||||
@ -727,8 +744,11 @@ add_file_cmd_to_str(struct connection *conn)
|
|||||||
}
|
}
|
||||||
|
|
||||||
add_to_string(&command, "RETR ");
|
add_to_string(&command, "RETR ");
|
||||||
add_uri_to_string(&command, conn->uri, URI_PATH);
|
add_uri_to_string(&uri_string, conn->uri, URI_PATH);
|
||||||
|
decode_uri_string(&uri_string);
|
||||||
|
add_string_to_string(&command, &uri_string);
|
||||||
add_crlf_to_string(&command);
|
add_crlf_to_string(&command);
|
||||||
|
done_string(&uri_string);
|
||||||
}
|
}
|
||||||
|
|
||||||
done_string(&ftp_data_command);
|
done_string(&ftp_data_command);
|
||||||
@ -1134,7 +1154,7 @@ display_dir_entry(struct cache_entry *cached, off_t *pos, int *tries,
|
|||||||
}
|
}
|
||||||
|
|
||||||
add_to_string(&string, "<a href=\"");
|
add_to_string(&string, "<a href=\"");
|
||||||
add_html_to_string(&string, ftp_info->name.source, ftp_info->name.length);
|
encode_uri_string(&string, ftp_info->name.source, ftp_info->name.length, 0);
|
||||||
if (ftp_info->type == FTP_FILE_DIRECTORY)
|
if (ftp_info->type == FTP_FILE_DIRECTORY)
|
||||||
add_char_to_string(&string, '/');
|
add_char_to_string(&string, '/');
|
||||||
add_to_string(&string, "\">");
|
add_to_string(&string, "\">");
|
||||||
|
Loading…
Reference in New Issue
Block a user