Commit a282480c8d0e4367d75afb32d965c9ee378de393
1 parent
e87b2ac8
Exists in
master
and in
5 other branches
Melhorando dialogo "save", incluindo código na ação "savecopy"
Showing
3 changed files
with
98 additions
and
33 deletions
Show diff stats
src/gtk/dialog.c
| @@ -34,55 +34,104 @@ | @@ -34,55 +34,104 @@ | ||
| 34 | 34 | ||
| 35 | /*--[ Implement ]------------------------------------------------------------------------------------*/ | 35 | /*--[ Implement ]------------------------------------------------------------------------------------*/ |
| 36 | 36 | ||
| 37 | + static void save_text(GtkWindow *toplevel,const gchar *filename, const gchar *text, const gchar *errmsg) | ||
| 38 | + { | ||
| 39 | + GError *error = NULL; | ||
| 40 | + | ||
| 41 | + if(!g_file_set_contents(filename,text,-1,&error)) | ||
| 42 | + { | ||
| 43 | + GtkWidget *popup = gtk_message_dialog_new_with_markup( | ||
| 44 | + toplevel, | ||
| 45 | + GTK_DIALOG_MODAL|GTK_DIALOG_DESTROY_WITH_PARENT, | ||
| 46 | + GTK_MESSAGE_ERROR,GTK_BUTTONS_CLOSE, | ||
| 47 | + gettext(errmsg),filename); | ||
| 48 | + | ||
| 49 | + gtk_window_set_title(GTK_WINDOW(popup),_("Can´t save file")); | ||
| 50 | + | ||
| 51 | + gtk_message_dialog_format_secondary_markup(GTK_MESSAGE_DIALOG(popup),"%s",error->message); | ||
| 52 | + g_error_free(error); | ||
| 53 | + | ||
| 54 | + gtk_dialog_run(GTK_DIALOG(popup)); | ||
| 55 | + gtk_widget_destroy(popup); | ||
| 56 | + | ||
| 57 | + } | ||
| 58 | + | ||
| 59 | + } | ||
| 60 | + | ||
| 61 | + static GtkFileChooserConfirmation confirm_overwrite(GtkFileChooser *chooser, GtkAction *action) | ||
| 62 | + { | ||
| 63 | + gchar * filename = gtk_file_chooser_get_filename(chooser); | ||
| 64 | + const gchar * attr = g_object_get_data(G_OBJECT(action),"overwrite"); | ||
| 65 | + GtkFileChooserConfirmation ret = GTK_FILE_CHOOSER_CONFIRMATION_ACCEPT_FILENAME; | ||
| 66 | + GtkWidget * dialog; | ||
| 67 | + | ||
| 68 | + if(attr && !g_strcasecmp(attr,"yes")) | ||
| 69 | + return ret; | ||
| 70 | + | ||
| 71 | + dialog = gtk_message_dialog_new_with_markup( GTK_WINDOW(chooser), | ||
| 72 | + GTK_DIALOG_DESTROY_WITH_PARENT, | ||
| 73 | + GTK_MESSAGE_QUESTION,GTK_BUTTONS_OK_CANCEL, | ||
| 74 | + "%s",_("The file already exists. Replace it?")); | ||
| 75 | + | ||
| 76 | + | ||
| 77 | + if(gtk_dialog_run(GTK_DIALOG(dialog)) != GTK_RESPONSE_OK) | ||
| 78 | + ret = GTK_FILE_CHOOSER_CONFIRMATION_SELECT_AGAIN; | ||
| 79 | + | ||
| 80 | + gtk_widget_destroy(dialog); | ||
| 81 | + | ||
| 82 | + return ret; | ||
| 83 | + | ||
| 84 | + } | ||
| 85 | + | ||
| 37 | static int save_dialog(GtkAction *action, GtkWidget *widget, const gchar *title, const gchar *errmsg, const gchar *text) | 86 | static int save_dialog(GtkAction *action, GtkWidget *widget, const gchar *title, const gchar *errmsg, const gchar *text) |
| 38 | { | 87 | { |
| 39 | GtkWindow * toplevel = GTK_WINDOW(gtk_widget_get_toplevel(widget)); | 88 | GtkWindow * toplevel = GTK_WINDOW(gtk_widget_get_toplevel(widget)); |
| 40 | const gchar * user_title = g_object_get_data(G_OBJECT(action),"title"); | 89 | const gchar * user_title = g_object_get_data(G_OBJECT(action),"title"); |
| 41 | - GtkWidget * dialog; | ||
| 42 | - | 90 | + const gchar * filename = g_object_get_data(G_OBJECT(action),"filename"); |
| 43 | 91 | ||
| 44 | if(!text) | 92 | if(!text) |
| 45 | return; | 93 | return; |
| 46 | 94 | ||
| 47 | - dialog = gtk_file_chooser_dialog_new( gettext(user_title ? user_title : title), | ||
| 48 | - toplevel, | ||
| 49 | - GTK_FILE_CHOOSER_ACTION_SAVE, | ||
| 50 | - GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL, | ||
| 51 | - GTK_STOCK_SAVE, GTK_RESPONSE_ACCEPT, | ||
| 52 | - NULL ); | ||
| 53 | - | ||
| 54 | - | ||
| 55 | - if(gtk_dialog_run(GTK_DIALOG(dialog)) == GTK_RESPONSE_ACCEPT) | 95 | + if(filename) |
| 96 | + { | ||
| 97 | + save_text(toplevel,filename,text,errmsg); | ||
| 98 | + } | ||
| 99 | + else | ||
| 56 | { | 100 | { |
| 57 | - GError *error = NULL; | ||
| 58 | - gchar *filename = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(dialog)); | 101 | + GtkWidget * dialog; |
| 102 | + gchar * ptr; | ||
| 59 | 103 | ||
| 60 | - if(!g_file_set_contents(filename,text,-1,&error)) | ||
| 61 | - { | ||
| 62 | - GtkWidget *popup = gtk_message_dialog_new_with_markup( | 104 | + dialog = gtk_file_chooser_dialog_new( gettext(user_title ? user_title : title), |
| 63 | toplevel, | 105 | toplevel, |
| 64 | - GTK_DIALOG_MODAL|GTK_DIALOG_DESTROY_WITH_PARENT, | ||
| 65 | - GTK_MESSAGE_ERROR,GTK_BUTTONS_CLOSE, | ||
| 66 | - gettext(errmsg),filename); | ||
| 67 | - | ||
| 68 | - gtk_window_set_title(GTK_WINDOW(popup),_("Can´t save file")); | 106 | + GTK_FILE_CHOOSER_ACTION_SAVE, |
| 107 | + GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL, | ||
| 108 | + GTK_STOCK_SAVE, GTK_RESPONSE_ACCEPT, | ||
| 109 | + NULL ); | ||
| 69 | 110 | ||
| 70 | - gtk_message_dialog_format_secondary_markup(GTK_MESSAGE_DIALOG(popup),"%s",error->message); | ||
| 71 | - g_error_free(error); | 111 | + gtk_file_chooser_set_do_overwrite_confirmation(GTK_FILE_CHOOSER(dialog), TRUE); |
| 112 | + g_signal_connect(GTK_FILE_CHOOSER(dialog), "confirm-overwrite", G_CALLBACK(confirm_overwrite), action); | ||
| 72 | 113 | ||
| 73 | - gtk_dialog_run(GTK_DIALOG(popup)); | ||
| 74 | - gtk_widget_destroy(popup); | 114 | + ptr = get_string_from_config("save",gtk_action_get_name(action),""); |
| 115 | + if(*ptr) | ||
| 116 | + gtk_file_chooser_set_filename(GTK_FILE_CHOOSER(dialog),ptr); | ||
| 117 | + g_free(ptr); | ||
| 75 | 118 | ||
| 119 | + if(gtk_dialog_run(GTK_DIALOG(dialog)) == GTK_RESPONSE_ACCEPT) | ||
| 120 | + { | ||
| 121 | + ptr = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(dialog)); | ||
| 122 | + if(ptr) | ||
| 123 | + { | ||
| 124 | + trace("Saving \"%s\"",ptr); | ||
| 125 | + set_string_to_config("save",gtk_action_get_name(action),"%s",ptr); | ||
| 126 | + save_text(toplevel,ptr,text,errmsg); | ||
| 127 | + g_free(ptr); | ||
| 128 | + } | ||
| 76 | } | 129 | } |
| 77 | 130 | ||
| 78 | - g_free(filename); | 131 | + gtk_widget_destroy(dialog); |
| 79 | } | 132 | } |
| 80 | - | ||
| 81 | - gtk_widget_destroy(dialog); | ||
| 82 | - return 0; | ||
| 83 | } | 133 | } |
| 84 | 134 | ||
| 85 | - | ||
| 86 | void paste_file_action(GtkAction *action, GtkWidget *widget) | 135 | void paste_file_action(GtkAction *action, GtkWidget *widget) |
| 87 | { | 136 | { |
| 88 | trace("Action %s activated on widget %p",gtk_action_get_name(action),widget); | 137 | trace("Action %s activated on widget %p",gtk_action_get_name(action),widget); |
| @@ -204,7 +253,7 @@ | @@ -204,7 +253,7 @@ | ||
| 204 | save_dialog( action, | 253 | save_dialog( action, |
| 205 | widget, | 254 | widget, |
| 206 | N_( "Save screen to file" ), | 255 | N_( "Save screen to file" ), |
| 207 | - N_( "Can't save screen to file \n%s" ), | 256 | + N_( "Can't save screen to file\n%s" ), |
| 208 | text); | 257 | text); |
| 209 | 258 | ||
| 210 | g_free(text); | 259 | g_free(text); |
| @@ -218,7 +267,7 @@ | @@ -218,7 +267,7 @@ | ||
| 218 | save_dialog( action, | 267 | save_dialog( action, |
| 219 | widget, | 268 | widget, |
| 220 | N_( "Save selection to file" ), | 269 | N_( "Save selection to file" ), |
| 221 | - N_( "Can't save selection to file \n%s" ), | 270 | + N_( "Can't save selection to file\n%s" ), |
| 222 | v3270_get_selected_text(widget)); | 271 | v3270_get_selected_text(widget)); |
| 223 | } | 272 | } |
| 224 | 273 | ||
| @@ -226,4 +275,9 @@ | @@ -226,4 +275,9 @@ | ||
| 226 | { | 275 | { |
| 227 | trace("Action %s activated on widget %p",gtk_action_get_name(action),widget); | 276 | trace("Action %s activated on widget %p",gtk_action_get_name(action),widget); |
| 228 | 277 | ||
| 278 | + save_dialog( action, | ||
| 279 | + widget, | ||
| 280 | + N_( "Save copy to file" ), | ||
| 281 | + N_( "Can't save copy to file\n%s" ), | ||
| 282 | + v3270_get_copy(widget)); | ||
| 229 | } | 283 | } |
src/gtk/v3270/clipboard.c
| @@ -127,6 +127,17 @@ const gchar * v3270_get_selected_text(GtkWidget *widget) | @@ -127,6 +127,17 @@ const gchar * v3270_get_selected_text(GtkWidget *widget) | ||
| 127 | return terminal->clipboard; | 127 | return terminal->clipboard; |
| 128 | } | 128 | } |
| 129 | 129 | ||
| 130 | +const gchar * v3270_get_copy(GtkWidget *widget) | ||
| 131 | +{ | ||
| 132 | + v3270 *terminal; | ||
| 133 | + | ||
| 134 | + g_return_val_if_fail(GTK_IS_V3270(widget),NULL); | ||
| 135 | + | ||
| 136 | + terminal = GTK_V3270(widget); | ||
| 137 | + | ||
| 138 | + return terminal->clipboard; | ||
| 139 | +} | ||
| 140 | + | ||
| 130 | const gchar * v3270_copy_append(GtkWidget *widget) | 141 | const gchar * v3270_copy_append(GtkWidget *widget) |
| 131 | { | 142 | { |
| 132 | v3270 * terminal; | 143 | v3270 * terminal; |
| @@ -161,7 +172,6 @@ const gchar * v3270_copy_append(GtkWidget *widget) | @@ -161,7 +172,6 @@ const gchar * v3270_copy_append(GtkWidget *widget) | ||
| 161 | 172 | ||
| 162 | g_signal_emit(widget,v3270_widget_signal[SIGNAL_CLIPBOARD], 0, TRUE); | 173 | g_signal_emit(widget,v3270_widget_signal[SIGNAL_CLIPBOARD], 0, TRUE); |
| 163 | 174 | ||
| 164 | - | ||
| 165 | return terminal->clipboard; | 175 | return terminal->clipboard; |
| 166 | } | 176 | } |
| 167 | 177 |
src/gtk/v3270/v3270.h
| @@ -202,6 +202,7 @@ | @@ -202,6 +202,7 @@ | ||
| 202 | 202 | ||
| 203 | // Clipboard | 203 | // Clipboard |
| 204 | const gchar * v3270_get_selected_text(GtkWidget *widget); | 204 | const gchar * v3270_get_selected_text(GtkWidget *widget); |
| 205 | + const gchar * v3270_get_copy(GtkWidget *widget); | ||
| 205 | gchar * v3270_get_text(GtkWidget *widget); | 206 | gchar * v3270_get_text(GtkWidget *widget); |
| 206 | const gchar * v3270_copy(GtkWidget *widget); | 207 | const gchar * v3270_copy(GtkWidget *widget); |
| 207 | const gchar * v3270_copy_append(GtkWidget *widget); | 208 | const gchar * v3270_copy_append(GtkWidget *widget); |