Mercurial > pidgin
diff src/dialogs.c @ 1035:80a47e3b1bca
[gaim-migrate @ 1045]
thanks to bmiller for yet another patch ;)
committer: Tailor Script <tailor@pidgin.im>
| author | Eric Warmenhoven <eric@warmenhoven.org> |
|---|---|
| date | Tue, 31 Oct 2000 07:36:11 +0000 |
| parents | 643a4d81c18a |
| children | faa5afc2b89e |
line wrap: on
line diff
--- a/src/dialogs.c Tue Oct 31 07:18:44 2000 +0000 +++ b/src/dialogs.c Tue Oct 31 07:36:11 2000 +0000 @@ -67,6 +67,8 @@ #define DEFAULT_FONT_NAME "-adobe-helvetica-medium-r-normal--12-120-75-75-p-67-iso8859-1" +#define PATHSIZE 1024 + int smiley_array[FACE_TOTAL]; GdkColor bgcolor; GdkColor fgcolor; @@ -1862,11 +1864,19 @@ { struct log_conversation *l; char buf[128]; + char *file; + char path[PATHSIZE]; if (!find_log_info(c->name)) { + file = gtk_file_selection_get_filename(GTK_FILE_SELECTION(c->log_dialog)); + strncpy( path, file, PATHSIZE - 1 ); + if (file_is_dir(path, c->log_dialog)) { + return; + } + l = (struct log_conversation *)g_new0(struct log_conversation, 1); strcpy(l->name, c->name); - strcpy(l->filename, gtk_file_selection_get_filename(GTK_FILE_SELECTION(c->log_dialog))); + strcpy(l->filename, file); log_conversations = g_list_append(log_conversations, l); if (c != NULL) @@ -2623,8 +2633,6 @@ /* The dialog for import/export */ /*------------------------------------------------------------------------*/ -#define PATHSIZE 1024 - /* see if a buddy list cache file for this user exists */ gboolean @@ -2670,6 +2678,10 @@ if ( show_dialog == 1 ) { file = gtk_file_selection_get_filename(GTK_FILE_SELECTION(exportdialog)); strncpy( path, file, PATHSIZE - 1 ); + if (file_is_dir(path, exportdialog)) { + g_free (buf); + return; + } if ((f = fopen(path,"w"))) { toc_build_config(connections->data, buf, 8192 - 1, TRUE); fprintf(f, "%s\n", buf); @@ -2772,6 +2784,11 @@ if ( !gc ) { file = gtk_file_selection_get_filename(GTK_FILE_SELECTION(importdialog)); strncpy( path, file, PATHSIZE - 1 ); + if (file_is_dir(path, importdialog)) { + g_free (buf); + g_free (first); + return; + } } else { for (i = 0; i < strlen(gc->username); i++)
