diff options
author | Timo Sirainen <cras@irssi.org> | 2004-08-19 20:41:47 +0000 |
---|---|---|
committer | cras <cras@dbcabf3a-b0e7-0310-adc4-f8d773084564> | 2004-08-19 20:41:47 +0000 |
commit | 169086ab51fc5dd0070ee18a52997e2a1b7fadf0 (patch) | |
tree | 1917a35d72d49e8271c380834d25e5fc2b46d487 /src/irc/dcc/dcc-send.c | |
parent | e5148aca0ee36c92f5475001744e0d5ca07a627e (diff) | |
download | irssi-169086ab51fc5dd0070ee18a52997e2a1b7fadf0.zip |
/DCC SEND didn't actually use /SET dcc_upload_path
git-svn-id: http://svn.irssi.org/repos/irssi/trunk@3279 dbcabf3a-b0e7-0310-adc4-f8d773084564
Diffstat (limited to 'src/irc/dcc/dcc-send.c')
-rw-r--r-- | src/irc/dcc/dcc-send.c | 40 |
1 files changed, 21 insertions, 19 deletions
diff --git a/src/irc/dcc/dcc-send.c b/src/irc/dcc/dcc-send.c index cb90fca8..2a0dac26 100644 --- a/src/irc/dcc/dcc-send.c +++ b/src/irc/dcc/dcc-send.c @@ -71,6 +71,24 @@ static void dcc_queue_send_next(int queue) } } +static char *dcc_send_get_file(const char *fname) +{ + char *str, *path; + + str = convert_home(fname); + if (!g_path_is_absolute(str)) { + /* full path not given to file, use dcc_upload_path */ + g_free(str); + + path = convert_home(settings_get_str("dcc_upload_path")); + str = *path == '\0' ? g_strdup(fname) : + g_strconcat(path, G_DIR_SEPARATOR_S, fname, NULL); + g_free(path); + } + + return str; +} + static void dcc_send_add(const char *servertag, CHAT_DCC_REC *chat, const char *nick, char *fileargs, int add_mode, int passive) @@ -101,7 +119,7 @@ static void dcc_send_add(const char *servertag, CHAT_DCC_REC *chat, /* add all globbed files to a proper queue */ for (i = 0; i < globbuf.gl_pathc; i++) { - const char *fname = globbuf.gl_pathv[i]; + char *fname = dcc_send_get_file(globbuf.gl_pathv[i]); ret = stat(fname, &st); if (ret == 0 && S_ISDIR(st.st_mode)) { @@ -113,6 +131,7 @@ static void dcc_send_add(const char *servertag, CHAT_DCC_REC *chat, if (ret < 0) { signal_emit("dcc error file open", 3, nick, fname, errno); + g_free(fname); continue; } @@ -137,6 +156,7 @@ static void dcc_send_add(const char *servertag, CHAT_DCC_REC *chat, dcc_queue_add_passive(queue, add_mode, nick, fname, servertag, chat); files++; + g_free(fname); } if (files > 0 && start_new_transfer) @@ -341,24 +361,6 @@ static void dcc_send_connect(SEND_DCC_REC *dcc) } } -static char *dcc_send_get_file(const char *fname) -{ - char *str, *path; - - str = convert_home(fname); - if (!g_path_is_absolute(str)) { - /* full path not given to file, use dcc_upload_path */ - g_free(str); - - path = convert_home(settings_get_str("dcc_upload_path")); - str = *path == '\0' ? g_strdup(fname) : - g_strconcat(path, G_DIR_SEPARATOR_S, fname, NULL); - g_free(path); - } - - return str; -} - static int dcc_send_one_file(int queue, const char *target, const char *fname, IRC_SERVER_REC *server, CHAT_DCC_REC *chat, int passive) |