Commit a7693b7d076423475add1c080b1bc2c793012b40
1 parent
320424c6
Exists in
master
and in
1 other branch
Reworking file transfer dialog.
Showing
6 changed files
with
184 additions
and
154 deletions
Show diff stats
src/include/v3270/filetransfer.h
| ... | ... | @@ -94,6 +94,20 @@ |
| 94 | 94 | |
| 95 | 95 | LIB3270_EXPORT GtkWidget * v3270_ft_settings_new(); |
| 96 | 96 | |
| 97 | + // FT Dialog widget | |
| 98 | + #define GTK_TYPE_V3270_FT_DIALOG (V3270FTDialog_get_type ()) | |
| 99 | + #define GTK_V3270_FT_DIALOG(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_V3270_FT_DIALOG, V3270FTDialog)) | |
| 100 | + #define GTK_V3270_FT_DIALOG_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_V3270_FT_DIALOG, V3270FTDialogClass)) | |
| 101 | + #define GTK_IS_V3270_FT_DIALOG(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_V3270_FT_DIALOG)) | |
| 102 | + #define GTK_IS_V3270_FT_DIALOG_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_V3270_FT_DIALOG)) | |
| 103 | + #define GTK_V3270_FT_DIALOG_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_V3270_FT_DIALOG, V3270FTDialogClass)) | |
| 104 | + | |
| 105 | + typedef struct _V3270FTDialog V3270FTDialog; | |
| 106 | + typedef struct _V3270FTDialogClass V3270FTDialogClass; | |
| 107 | + | |
| 108 | + LIB3270_EXPORT GtkWidget * v3270_ft_dialog_new(GtkWidget *parent); | |
| 109 | + | |
| 110 | + | |
| 97 | 111 | G_END_DECLS |
| 98 | 112 | |
| 99 | 113 | #endif // V3270FT_H_INCLUDED | ... | ... |
src/testprogram/testprogram.c
| ... | ... | @@ -149,20 +149,7 @@ static void disconnect_clicked(GtkButton G_GNUC_UNUSED(*button), GtkWidget *term |
| 149 | 149 | |
| 150 | 150 | static void ft_clicked(GtkButton G_GNUC_UNUSED(*button), GtkWidget *terminal) |
| 151 | 151 | { |
| 152 | - GtkWidget * dialog = gtk_dialog_new_with_buttons( | |
| 153 | - _("FT Settings"), | |
| 154 | - GTK_WINDOW(gtk_widget_get_toplevel(terminal)), | |
| 155 | - GTK_DIALOG_MODAL|GTK_DIALOG_DESTROY_WITH_PARENT, | |
| 156 | - _( "_Close" ), GTK_RESPONSE_ACCEPT, | |
| 157 | - NULL | |
| 158 | - ); | |
| 159 | - | |
| 160 | - gtk_box_pack_start(GTK_BOX(gtk_dialog_get_content_area(GTK_DIALOG(dialog))),v3270_ft_settings_new(),TRUE,TRUE,2); | |
| 161 | - | |
| 162 | - /* | |
| 163 | - GtkWidget * dialog = v3270ft_new(); | |
| 164 | - gtk_window_set_transient_for(GTK_WINDOW(dialog),GTK_WINDOW(gtk_widget_get_toplevel(terminal))); | |
| 165 | - */ | |
| 152 | + GtkWidget * dialog = v3270_ft_dialog_new(terminal); | |
| 166 | 153 | |
| 167 | 154 | gtk_widget_show_all(dialog); |
| 168 | 155 | gtk_dialog_run(GTK_DIALOG(dialog)); | ... | ... |
| ... | ... | @@ -0,0 +1,152 @@ |
| 1 | +/* | |
| 2 | + * "Software pw3270, desenvolvido com base nos códigos fontes do WC3270 e X3270 | |
| 3 | + * (Paul Mattes Paul.Mattes@usa.net), de emulação de terminal 3270 para acesso a | |
| 4 | + * aplicativos mainframe. Registro no INPI sob o nome G3270. | |
| 5 | + * | |
| 6 | + * Copyright (C) <2008> <Banco do Brasil S.A.> | |
| 7 | + * | |
| 8 | + * Este programa é software livre. Você pode redistribuí-lo e/ou modificá-lo sob | |
| 9 | + * os termos da GPL v.2 - Licença Pública Geral GNU, conforme publicado pela | |
| 10 | + * Free Software Foundation. | |
| 11 | + * | |
| 12 | + * Este programa é distribuído na expectativa de ser útil, mas SEM QUALQUER | |
| 13 | + * GARANTIA; sem mesmo a garantia implícita de COMERCIALIZAÇÃO ou de ADEQUAÇÃO | |
| 14 | + * A QUALQUER PROPÓSITO EM PARTICULAR. Consulte a Licença Pública Geral GNU para | |
| 15 | + * obter mais detalhes. | |
| 16 | + * | |
| 17 | + * Você deve ter recebido uma cópia da Licença Pública Geral GNU junto com este | |
| 18 | + * programa; se não, escreva para a Free Software Foundation, Inc., 51 Franklin | |
| 19 | + * St, Fifth Floor, Boston, MA 02110-1301 USA | |
| 20 | + * | |
| 21 | + * Este programa está nomeado como - e possui - linhas de código. | |
| 22 | + * | |
| 23 | + * Contatos: | |
| 24 | + * | |
| 25 | + * perry.werneck@gmail.com (Alexandre Perry de Souza Werneck) | |
| 26 | + * erico.mendonca@gmail.com (Erico Mascarenhas Mendonça) | |
| 27 | + * | |
| 28 | + */ | |
| 29 | + | |
| 30 | + #include <v3270.h> | |
| 31 | + #include <v3270/filetransfer.h> | |
| 32 | + #include "private.h" | |
| 33 | + | |
| 34 | +/*--[ Widget definition ]----------------------------------------------------------------------------*/ | |
| 35 | + | |
| 36 | + struct _V3270FTDialog | |
| 37 | + { | |
| 38 | + GtkDialog parent; | |
| 39 | + | |
| 40 | + GtkWidget * settings; | |
| 41 | + // GtkWidget * buttons[FT_BUTTON_COUNT]; | |
| 42 | + | |
| 43 | + }; | |
| 44 | + | |
| 45 | + struct _V3270FTDialogClass | |
| 46 | + { | |
| 47 | + GtkDialogClass parent_class; | |
| 48 | + }; | |
| 49 | + | |
| 50 | + G_DEFINE_TYPE(V3270FTDialog, V3270FTDialog, GTK_TYPE_DIALOG); | |
| 51 | + | |
| 52 | +/*--[ Implement ]------------------------------------------------------------------------------------*/ | |
| 53 | + | |
| 54 | +static void V3270FTDialog_class_init(G_GNUC_UNUSED V3270FTDialogClass *klass) | |
| 55 | +{ | |
| 56 | +} | |
| 57 | + | |
| 58 | +/* | |
| 59 | +static void apply_clicked(GtkButton G_GNUC_UNUSED(*button), GtkWidget *dialog) | |
| 60 | +{ | |
| 61 | + gtk_dialog_response(GTK_DIALOG(dialog),GTK_RESPONSE_APPLY); | |
| 62 | +} | |
| 63 | + | |
| 64 | +static void cancel_clicked(GtkButton G_GNUC_UNUSED(*button), GtkWidget *dialog) | |
| 65 | +{ | |
| 66 | + gtk_dialog_response(GTK_DIALOG(dialog),GTK_RESPONSE_CANCEL); | |
| 67 | +} | |
| 68 | +*/ | |
| 69 | + | |
| 70 | +/* | |
| 71 | +static GtkWidget * create_button(V3270FTDialog *widget, FT_BUTTON id, const gchar *icon, const gchar *tooltip, GCallback callback) | |
| 72 | +{ | |
| 73 | + widget->buttons[id] = gtk_button_new_from_icon_name(icon,GTK_ICON_SIZE_BUTTON); | |
| 74 | + gtk_widget_set_tooltip_markup(widget->buttons[id],tooltip); | |
| 75 | + | |
| 76 | + // g_signal_connect(widget->buttons[id],"clicked",callback,widget); | |
| 77 | + | |
| 78 | + return widget->buttons[id]; | |
| 79 | +} | |
| 80 | +*/ | |
| 81 | + | |
| 82 | +static void V3270FTDialog_init(V3270FTDialog *widget) | |
| 83 | +{ | |
| 84 | + widget->settings = v3270_ft_settings_new(); | |
| 85 | + | |
| 86 | + gtk_window_set_title(GTK_WINDOW(widget),_( "3270 File transfer")); | |
| 87 | + | |
| 88 | + // https://developer.gnome.org/hig/stable/visual-layout.html.en | |
| 89 | + gtk_container_set_border_width(GTK_CONTAINER(gtk_dialog_get_content_area(GTK_DIALOG(widget))),18); | |
| 90 | + | |
| 91 | + // Create box | |
| 92 | + GtkWidget * container = gtk_box_new(GTK_ORIENTATION_VERTICAL,6); | |
| 93 | + gtk_box_pack_start(GTK_BOX(gtk_dialog_get_content_area(GTK_DIALOG(widget))),container,TRUE,TRUE,0); | |
| 94 | + | |
| 95 | + // Pack settings widget | |
| 96 | + gtk_widget_set_halign(GTK_WIDGET(widget->settings),GTK_ALIGN_START); | |
| 97 | + gtk_widget_set_hexpand(GTK_WIDGET(widget->settings),FALSE); | |
| 98 | + gtk_widget_set_vexpand(GTK_WIDGET(widget->settings),FALSE); | |
| 99 | + gtk_box_pack_start(GTK_BOX(container),widget->settings,FALSE,FALSE,0); | |
| 100 | + | |
| 101 | + | |
| 102 | + // Create file list view | |
| 103 | + { | |
| 104 | + GtkTreeModel * model = GTK_TREE_MODEL(gtk_tree_store_new(1,G_TYPE_STRING)); | |
| 105 | + GtkWidget * files = gtk_tree_view_new_with_model(model); | |
| 106 | + | |
| 107 | + gtk_widget_set_tooltip_markup(files,_("Files to transfer")); | |
| 108 | + | |
| 109 | + gtk_tree_view_set_headers_visible(GTK_TREE_VIEW(files),TRUE); | |
| 110 | + gtk_tree_view_insert_column_with_attributes( | |
| 111 | + GTK_TREE_VIEW(files), | |
| 112 | + -1, | |
| 113 | + _( "Local file name" ),gtk_cell_renderer_text_new(),"text", | |
| 114 | + 0, NULL | |
| 115 | + ); | |
| 116 | + | |
| 117 | + // Put the view inside a scrolled window. | |
| 118 | + GtkWidget * scrolled = gtk_scrolled_window_new(NULL,NULL); | |
| 119 | + gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolled),GTK_POLICY_AUTOMATIC,GTK_POLICY_AUTOMATIC); | |
| 120 | + gtk_container_add(GTK_CONTAINER(scrolled),files); | |
| 121 | + | |
| 122 | + gtk_widget_set_vexpand(scrolled,TRUE); | |
| 123 | + gtk_widget_set_hexpand(scrolled,TRUE); | |
| 124 | + | |
| 125 | + gtk_box_pack_start(GTK_BOX(container),scrolled,TRUE,TRUE,0); | |
| 126 | + } | |
| 127 | + | |
| 128 | + | |
| 129 | +} | |
| 130 | + | |
| 131 | +LIB3270_EXPORT GtkWidget * v3270_ft_dialog_new(GtkWidget *parent) | |
| 132 | +{ | |
| 133 | + gboolean use_header; | |
| 134 | + g_object_get(gtk_settings_get_default(), "gtk-dialogs-use-header", &use_header, NULL); | |
| 135 | + | |
| 136 | + GtkWidget * dialog = | |
| 137 | + GTK_WIDGET(g_object_new( | |
| 138 | + GTK_TYPE_V3270_FT_DIALOG, | |
| 139 | + "use-header-bar", 0, // (use_header ? 1 : 0), | |
| 140 | + NULL | |
| 141 | + )); | |
| 142 | + | |
| 143 | + if(parent) | |
| 144 | + { | |
| 145 | + gtk_window_set_transient_for(GTK_WINDOW(dialog), GTK_WINDOW(gtk_widget_get_toplevel(parent))); | |
| 146 | + gtk_window_set_modal(GTK_WINDOW(dialog), TRUE); | |
| 147 | + gtk_window_set_destroy_with_parent(GTK_WINDOW(dialog), TRUE); | |
| 148 | + } | |
| 149 | + | |
| 150 | + return dialog; | |
| 151 | +} | |
| 152 | + | ... | ... |
src/v3270ft/ftdialog.cbp
| ... | ... | @@ -1,140 +0,0 @@ |
| 1 | -<?xml version="1.0" encoding="UTF-8" standalone="yes" ?> | |
| 2 | -<CodeBlocks_project_file> | |
| 3 | - <FileVersion major="1" minor="6" /> | |
| 4 | - <Project> | |
| 5 | - <Option title="pw3270 File Transfer Dialog" /> | |
| 6 | - <Option pch_mode="2" /> | |
| 7 | - <Option compiler="gcc" /> | |
| 8 | - <Build> | |
| 9 | - <Target title="Debug"> | |
| 10 | - <Option output=".bin/Debug/v3270ft" prefix_auto="1" extension_auto="1" /> | |
| 11 | - <Option object_output=".obj/Debug/" /> | |
| 12 | - <Option type="1" /> | |
| 13 | - <Option compiler="gcc" /> | |
| 14 | - <Compiler> | |
| 15 | - <Add option="-g" /> | |
| 16 | - <Add option="-DDEBUG=1" /> | |
| 17 | - </Compiler> | |
| 18 | - </Target> | |
| 19 | - <Target title="Release"> | |
| 20 | - <Option output=".bin/Release/v3270ft" prefix_auto="1" extension_auto="1" /> | |
| 21 | - <Option object_output=".obj/Release/" /> | |
| 22 | - <Option type="1" /> | |
| 23 | - <Option compiler="gcc" /> | |
| 24 | - <Compiler> | |
| 25 | - <Add option="-O2" /> | |
| 26 | - <Add option="-DNDEBUG=1" /> | |
| 27 | - </Compiler> | |
| 28 | - <Linker> | |
| 29 | - <Add option="-s" /> | |
| 30 | - </Linker> | |
| 31 | - </Target> | |
| 32 | - </Build> | |
| 33 | - <Compiler> | |
| 34 | - <Add option="-Wall" /> | |
| 35 | - <Add option="`pkg-config --cflags gtk+-3.0 lib3270`" /> | |
| 36 | - <Add directory="../../include" /> | |
| 37 | - <Add directory="../../include/pw3270" /> | |
| 38 | - </Compiler> | |
| 39 | - <Linker> | |
| 40 | - <Add option="`pkg-config --libs gtk+-3.0 lib3270`" /> | |
| 41 | - </Linker> | |
| 42 | - <ExtraCommands> | |
| 43 | - <Add before="glib-genmarshal --prefix=v3270ft --header genmarshal > marshal.h" /> | |
| 44 | - <Add before="glib-genmarshal --prefix=v3270ft --body genmarshal > marshal.c" /> | |
| 45 | - </ExtraCommands> | |
| 46 | - <Unit filename="../include/v3270.h" /> | |
| 47 | - <Unit filename="../include/v3270ft.h" /> | |
| 48 | - <Unit filename="../include/v3270ftprogress.h" /> | |
| 49 | - <Unit filename="../v3270/accessible.c"> | |
| 50 | - <Option compilerVar="CC" /> | |
| 51 | - </Unit> | |
| 52 | - <Unit filename="../v3270/accessible.h" /> | |
| 53 | - <Unit filename="../v3270/draw.c"> | |
| 54 | - <Option compilerVar="CC" /> | |
| 55 | - </Unit> | |
| 56 | - <Unit filename="../v3270/hostselect.c"> | |
| 57 | - <Option compilerVar="CC" /> | |
| 58 | - </Unit> | |
| 59 | - <Unit filename="../v3270/hostselect.h" /> | |
| 60 | - <Unit filename="../v3270/iocallback.c"> | |
| 61 | - <Option compilerVar="CC" /> | |
| 62 | - </Unit> | |
| 63 | - <Unit filename="../v3270/keyboard.c"> | |
| 64 | - <Option compilerVar="CC" /> | |
| 65 | - </Unit> | |
| 66 | - <Unit filename="../v3270/macros.c"> | |
| 67 | - <Option compilerVar="CC" /> | |
| 68 | - </Unit> | |
| 69 | - <Unit filename="../v3270/marshal.c"> | |
| 70 | - <Option compilerVar="CC" /> | |
| 71 | - </Unit> | |
| 72 | - <Unit filename="../v3270/marshal.h" /> | |
| 73 | - <Unit filename="../v3270/mouse.c"> | |
| 74 | - <Option compilerVar="CC" /> | |
| 75 | - </Unit> | |
| 76 | - <Unit filename="../v3270/oia.c"> | |
| 77 | - <Option compilerVar="CC" /> | |
| 78 | - </Unit> | |
| 79 | - <Unit filename="../v3270/private.h" /> | |
| 80 | - <Unit filename="../v3270/properties.c"> | |
| 81 | - <Option compilerVar="CC" /> | |
| 82 | - </Unit> | |
| 83 | - <Unit filename="../v3270/security.c"> | |
| 84 | - <Option compilerVar="CC" /> | |
| 85 | - </Unit> | |
| 86 | - <Unit filename="../v3270/selection.c"> | |
| 87 | - <Option compilerVar="CC" /> | |
| 88 | - </Unit> | |
| 89 | - <Unit filename="../v3270/widget.c"> | |
| 90 | - <Option compilerVar="CC" /> | |
| 91 | - </Unit> | |
| 92 | - <Unit filename="filelist.c"> | |
| 93 | - <Option compilerVar="CC" /> | |
| 94 | - </Unit> | |
| 95 | - <Unit filename="genmarshal" /> | |
| 96 | - <Unit filename="get.c"> | |
| 97 | - <Option compilerVar="CC" /> | |
| 98 | - </Unit> | |
| 99 | - <Unit filename="load.c"> | |
| 100 | - <Option compilerVar="CC" /> | |
| 101 | - </Unit> | |
| 102 | - <Unit filename="marshal.c"> | |
| 103 | - <Option compilerVar="CC" /> | |
| 104 | - </Unit> | |
| 105 | - <Unit filename="misc.c"> | |
| 106 | - <Option compilerVar="CC" /> | |
| 107 | - </Unit> | |
| 108 | - <Unit filename="private.h" /> | |
| 109 | - <Unit filename="save.c"> | |
| 110 | - <Option compilerVar="CC" /> | |
| 111 | - </Unit> | |
| 112 | - <Unit filename="select.c"> | |
| 113 | - <Option compilerVar="CC" /> | |
| 114 | - </Unit> | |
| 115 | - <Unit filename="set.c"> | |
| 116 | - <Option compilerVar="CC" /> | |
| 117 | - </Unit> | |
| 118 | - <Unit filename="tables.c"> | |
| 119 | - <Option compilerVar="CC" /> | |
| 120 | - </Unit> | |
| 121 | - <Unit filename="testprogram.c"> | |
| 122 | - <Option compilerVar="CC" /> | |
| 123 | - </Unit> | |
| 124 | - <Unit filename="transfer.c"> | |
| 125 | - <Option compilerVar="CC" /> | |
| 126 | - </Unit> | |
| 127 | - <Unit filename="v3270ft.c"> | |
| 128 | - <Option compilerVar="CC" /> | |
| 129 | - </Unit> | |
| 130 | - <Unit filename="v3270ftprogress.c"> | |
| 131 | - <Option compilerVar="CC" /> | |
| 132 | - </Unit> | |
| 133 | - <Extensions> | |
| 134 | - <code_completion /> | |
| 135 | - <envvars /> | |
| 136 | - <debugger /> | |
| 137 | - <lib_finder disable_auto="1" /> | |
| 138 | - </Extensions> | |
| 139 | - </Project> | |
| 140 | -</CodeBlocks_project_file> |
src/v3270ft/settings.c
| ... | ... | @@ -180,6 +180,7 @@ static void open_select_file_dialog(GtkEntry *entry, G_GNUC_UNUSED GtkEntryIconP |
| 180 | 180 | } |
| 181 | 181 | else |
| 182 | 182 | { |
| 183 | + | |
| 183 | 184 | debug("%s option selected","LIB3270_FT_OPTION_SEND"); |
| 184 | 185 | |
| 185 | 186 | gtk_widget_set_sensitive(widget->recordFormatBox,TRUE); |
| ... | ... | @@ -199,6 +200,9 @@ static void open_select_file_dialog(GtkEntry *entry, G_GNUC_UNUSED GtkEntryIconP |
| 199 | 200 | gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(widget->options[ix]),(options & ft_option[ix].opt) == ft_option[ix].opt); |
| 200 | 201 | } |
| 201 | 202 | |
| 203 | + gtk_widget_set_sensitive(GTK_WIDGET(widget->file.local),TRUE); | |
| 204 | + gtk_widget_set_sensitive(GTK_WIDGET(widget->file.remote),TRUE); | |
| 205 | + | |
| 202 | 206 | } |
| 203 | 207 | |
| 204 | 208 | static void transfer_type_changed(GtkComboBox *widget, V3270FTSettings *dialog) |
| ... | ... | @@ -208,7 +212,14 @@ static void open_select_file_dialog(GtkEntry *entry, G_GNUC_UNUSED GtkEntryIconP |
| 208 | 212 | debug("Transfer type=%u", (unsigned int) selected); |
| 209 | 213 | |
| 210 | 214 | if(selected >= 0) |
| 215 | + { | |
| 211 | 216 | set_options(dialog,ft_type[selected].opt); |
| 217 | + } | |
| 218 | + else | |
| 219 | + { | |
| 220 | + gtk_widget_set_sensitive(GTK_WIDGET(dialog->file.local),FALSE); | |
| 221 | + gtk_widget_set_sensitive(GTK_WIDGET(dialog->file.remote),FALSE); | |
| 222 | + } | |
| 212 | 223 | |
| 213 | 224 | } |
| 214 | 225 | |
| ... | ... | @@ -343,6 +354,9 @@ static void open_select_file_dialog(GtkEntry *entry, G_GNUC_UNUSED GtkEntryIconP |
| 343 | 354 | |
| 344 | 355 | } |
| 345 | 356 | |
| 357 | + gtk_widget_set_sensitive(GTK_WIDGET(widget->file.local),FALSE); | |
| 358 | + gtk_widget_set_sensitive(GTK_WIDGET(widget->file.remote),FALSE); | |
| 359 | + | |
| 346 | 360 | } |
| 347 | 361 | |
| 348 | 362 | LIB3270_EXPORT GtkWidget * v3270_ft_settings_new() | ... | ... |
v3270.cbp
| ... | ... | @@ -141,6 +141,9 @@ |
| 141 | 141 | <Unit filename="src/v3270/windows/iosource.c"> |
| 142 | 142 | <Option compilerVar="CC" /> |
| 143 | 143 | </Unit> |
| 144 | + <Unit filename="src/v3270ft/dialog.c"> | |
| 145 | + <Option compilerVar="CC" /> | |
| 146 | + </Unit> | |
| 144 | 147 | <Unit filename="src/v3270ft/filelist.c"> |
| 145 | 148 | <Option compilerVar="CC" /> |
| 146 | 149 | </Unit> | ... | ... |