Commit b079db7b57c80140086d9b319e6cb0463f95f8d7
1 parent
a7693b7d
Exists in
master
and in
1 other branch
Moving customized "pack" methods to global methods to avoid code
repetition.
Showing
5 changed files
with
173 additions
and
27 deletions
Show diff stats
@@ -0,0 +1,66 @@ | @@ -0,0 +1,66 @@ | ||
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 <internals.h> | ||
31 | + | ||
32 | +/*--[ Implement ]------------------------------------------------------------------------------------*/ | ||
33 | + | ||
34 | + GtkWidget * v3270_dialog_create_grid(GtkAlign align) | ||
35 | + { | ||
36 | + GtkWidget * grid = gtk_grid_new(); | ||
37 | + | ||
38 | + gtk_grid_set_row_spacing(GTK_GRID(grid),6); | ||
39 | + gtk_grid_set_column_spacing(GTK_GRID(grid),12); | ||
40 | + | ||
41 | + g_object_set(G_OBJECT(grid),"margin-top",6,NULL); | ||
42 | + gtk_widget_set_halign(GTK_WIDGET(grid),align); | ||
43 | + | ||
44 | + return grid; | ||
45 | + } | ||
46 | + | ||
47 | + GtkWidget * v3270_box_pack_frame(GtkWidget *box, GtkWidget *child, const gchar *title, GtkAlign align, gboolean expand, gboolean fill, guint padding) | ||
48 | + { | ||
49 | + GtkFrame * frame = GTK_FRAME(gtk_frame_new("")); | ||
50 | + g_autofree gchar * markup = g_strdup_printf("<b>%s</b>",title); | ||
51 | + GtkWidget * label = gtk_label_new(NULL); | ||
52 | + | ||
53 | + gtk_frame_set_shadow_type(GTK_FRAME(frame),GTK_SHADOW_NONE); | ||
54 | + gtk_label_set_markup(GTK_LABEL(label),markup); | ||
55 | + gtk_frame_set_label_widget(GTK_FRAME(frame),label); | ||
56 | + | ||
57 | + gtk_container_add(GTK_CONTAINER(frame),GTK_WIDGET(child)); | ||
58 | + gtk_widget_set_halign(GTK_WIDGET(frame),align); | ||
59 | + | ||
60 | + g_object_set(G_OBJECT(frame),"margin-top",6,NULL); | ||
61 | + | ||
62 | + gtk_box_pack_start(GTK_BOX(box),GTK_WIDGET(frame),expand,fill,padding); | ||
63 | + | ||
64 | + return child; | ||
65 | + } | ||
66 | + |
@@ -0,0 +1,67 @@ | @@ -0,0 +1,67 @@ | ||
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 | +#ifndef V3270_INTERNALS_H_INCLUDED | ||
31 | + | ||
32 | + #define V3270_INTERNALS_H_INCLUDED 1 | ||
33 | + | ||
34 | + #include <glib.h> | ||
35 | + #include <gtk/gtk.h> | ||
36 | + #include <lib3270.h> | ||
37 | + #include <lib3270/log.h> | ||
38 | + #include <v3270.h> | ||
39 | + | ||
40 | + #if ! GLIB_CHECK_VERSION(2,44,0) | ||
41 | + | ||
42 | + // Reference: https://github.com/ImageMagick/glib/blob/master/glib/glib-autocleanups.h | ||
43 | + static inline void v3270_autoptr_cleanup_generic_gfree(void *p) | ||
44 | + { | ||
45 | + void **pp = (void**)p; | ||
46 | + g_free (*pp); | ||
47 | + } | ||
48 | + | ||
49 | + #define g_autofree __attribute__((cleanup(v3270_autoptr_cleanup_generic_gfree))) | ||
50 | + | ||
51 | + #endif // ! GLIB(2,44,0) | ||
52 | + | ||
53 | + G_BEGIN_DECLS | ||
54 | + | ||
55 | + inline GtkWidget * v3270_box_pack_start(GtkWidget *box, GtkWidget *child, gboolean expand, gboolean fill, guint padding) | ||
56 | + { | ||
57 | + gtk_box_pack_start(GTK_BOX(box),child,expand,fill,padding); | ||
58 | + return child; | ||
59 | + } | ||
60 | + | ||
61 | + G_GNUC_INTERNAL GtkWidget * v3270_box_pack_frame(GtkWidget *box, GtkWidget *child, const gchar *title, GtkAlign align, gboolean expand, gboolean fill, guint padding); | ||
62 | + G_GNUC_INTERNAL GtkWidget * v3270_dialog_create_grid(GtkAlign align); | ||
63 | + | ||
64 | + | ||
65 | + G_END_DECLS | ||
66 | + | ||
67 | +#endif // V3270_INTERNALS_H_INCLUDED |
src/testprogram/testprogram.c
@@ -260,7 +260,7 @@ static void activate(GtkApplication* app, G_GNUC_UNUSED gpointer user_data) { | @@ -260,7 +260,7 @@ static void activate(GtkApplication* app, G_GNUC_UNUSED gpointer user_data) { | ||
260 | GtkWidget * toolbar = gtk_toolbar_new(); | 260 | GtkWidget * toolbar = gtk_toolbar_new(); |
261 | for(f = 0; f < G_N_ELEMENTS(buttons); f++) | 261 | for(f = 0; f < G_N_ELEMENTS(buttons); f++) |
262 | { | 262 | { |
263 | - GtkWidget * button = gtk_tool_button_new_from_stock(buttons[f].icon); | 263 | + GtkWidget * button = GTK_WIDGET(gtk_tool_button_new_from_stock(buttons[f].icon)); |
264 | gtk_widget_set_tooltip_markup(button,buttons[f].tooltip); | 264 | gtk_widget_set_tooltip_markup(button,buttons[f].tooltip); |
265 | g_signal_connect(G_OBJECT(button),"clicked",buttons[f].callback,terminal); | 265 | g_signal_connect(G_OBJECT(button),"clicked",buttons[f].callback,terminal); |
266 | gtk_toolbar_insert(GTK_TOOLBAR(toolbar),GTK_TOOL_ITEM(button),-1); | 266 | gtk_toolbar_insert(GTK_TOOLBAR(toolbar),GTK_TOOL_ITEM(button),-1); |
src/v3270ft/private.h
@@ -43,6 +43,7 @@ | @@ -43,6 +43,7 @@ | ||
43 | #include <v3270/filetransfer.h> | 43 | #include <v3270/filetransfer.h> |
44 | #include <v3270/ftprogress.h> | 44 | #include <v3270/ftprogress.h> |
45 | #include <lib3270.h> | 45 | #include <lib3270.h> |
46 | + #include <lib3270/log.h> | ||
46 | #include <lib3270/filetransfer.h> | 47 | #include <lib3270/filetransfer.h> |
47 | 48 | ||
48 | #define NUM_OPTIONS_WIDGETS 12 | 49 | #define NUM_OPTIONS_WIDGETS 12 |
@@ -179,17 +180,6 @@ | @@ -179,17 +180,6 @@ | ||
179 | 180 | ||
180 | }; | 181 | }; |
181 | 182 | ||
182 | - #ifdef DEBUG | ||
183 | - | ||
184 | - #define debug(fmt, ...) g_message( "%s(%d) " fmt , __FILE__, (int) __LINE__, __VA_ARGS__ ) | ||
185 | - | ||
186 | - #else | ||
187 | - | ||
188 | - #define debug(fmt, ...) /* */ | ||
189 | - | ||
190 | - #endif // DEBUG | ||
191 | - | ||
192 | - | ||
193 | G_GNUC_INTERNAL guint v3270ftprogress_signal[V3270FTPROGRESS_SIGNAL_COUNT]; | 183 | G_GNUC_INTERNAL guint v3270ftprogress_signal[V3270FTPROGRESS_SIGNAL_COUNT]; |
194 | 184 | ||
195 | 185 |
src/v3270ft/settings.c
@@ -28,9 +28,9 @@ | @@ -28,9 +28,9 @@ | ||
28 | */ | 28 | */ |
29 | 29 | ||
30 | #include <string.h> | 30 | #include <string.h> |
31 | - #include <v3270.h> | ||
32 | - #include <v3270/filetransfer.h> | 31 | + #include <internals.h> |
33 | #include "private.h" | 32 | #include "private.h" |
33 | + #include <v3270/filetransfer.h> | ||
34 | 34 | ||
35 | /*--[ Widget definition ]----------------------------------------------------------------------------*/ | 35 | /*--[ Widget definition ]----------------------------------------------------------------------------*/ |
36 | 36 | ||
@@ -83,8 +83,11 @@ | @@ -83,8 +83,11 @@ | ||
83 | return entry; | 83 | return entry; |
84 | } | 84 | } |
85 | 85 | ||
86 | + /* | ||
86 | static GtkWidget * create_frame(GtkWidget *container, const gchar *title, GtkWidget *box, GtkAlign align) | 87 | static GtkWidget * create_frame(GtkWidget *container, const gchar *title, GtkWidget *box, GtkAlign align) |
87 | { | 88 | { |
89 | + gtk_box_pack_start(GTK_BOX(container),v3270_dialog_create_frame(title,box,align),TRUE,TRUE,0); | ||
90 | + | ||
88 | GtkFrame * frame = GTK_FRAME(gtk_frame_new("")); | 91 | GtkFrame * frame = GTK_FRAME(gtk_frame_new("")); |
89 | g_autofree gchar * markup = g_strdup_printf("<b>%s</b>",title); | 92 | g_autofree gchar * markup = g_strdup_printf("<b>%s</b>",title); |
90 | GtkWidget * label = gtk_label_new(NULL); | 93 | GtkWidget * label = gtk_label_new(NULL); |
@@ -102,19 +105,11 @@ | @@ -102,19 +105,11 @@ | ||
102 | 105 | ||
103 | return box; | 106 | return box; |
104 | } | 107 | } |
108 | + */ | ||
105 | 109 | ||
106 | static GtkWidget * create_grid(GtkWidget *container, GtkAlign align) | 110 | static GtkWidget * create_grid(GtkWidget *container, GtkAlign align) |
107 | { | 111 | { |
108 | - GtkWidget * grid = gtk_grid_new(); | ||
109 | - | ||
110 | - gtk_grid_set_row_spacing(GTK_GRID(grid),6); | ||
111 | - gtk_grid_set_column_spacing(GTK_GRID(grid),12); | ||
112 | - | ||
113 | - g_object_set(G_OBJECT(grid),"margin-top",6,NULL); | ||
114 | - gtk_widget_set_halign(GTK_WIDGET(grid),align); | ||
115 | - gtk_box_pack_start(GTK_BOX(container),GTK_WIDGET(grid),TRUE,TRUE,0); | ||
116 | - | ||
117 | - return grid; | 112 | + return v3270_box_pack_start(container,v3270_dialog_create_grid(align),TRUE,TRUE,0); |
118 | } | 113 | } |
119 | 114 | ||
120 | GtkWidget * create_spin_button(V3270FTSettings *widget, GtkWidget *grid, size_t row, LIB3270_FT_VALUE id) | 115 | GtkWidget * create_spin_button(V3270FTSettings *widget, GtkWidget *grid, size_t row, LIB3270_FT_VALUE id) |
@@ -277,7 +272,16 @@ static void open_select_file_dialog(GtkEntry *entry, G_GNUC_UNUSED GtkEntryIconP | @@ -277,7 +272,16 @@ static void open_select_file_dialog(GtkEntry *entry, G_GNUC_UNUSED GtkEntryIconP | ||
277 | 272 | ||
278 | // Transfer options | 273 | // Transfer options |
279 | { | 274 | { |
280 | - GtkWidget * box = create_frame(options, _("Transfer options"), gtk_box_new(GTK_ORIENTATION_VERTICAL,6),GTK_ALIGN_START); | 275 | + GtkWidget * box = |
276 | + v3270_box_pack_frame( | ||
277 | + options, | ||
278 | + gtk_box_new(GTK_ORIENTATION_VERTICAL,6), | ||
279 | + _("Transfer options"), | ||
280 | + GTK_ALIGN_START, | ||
281 | + FALSE, | ||
282 | + FALSE, | ||
283 | + 0 | ||
284 | + ); | ||
281 | 285 | ||
282 | for(ix=0;ix<4;ix++) | 286 | for(ix=0;ix<4;ix++) |
283 | { | 287 | { |
@@ -293,7 +297,17 @@ static void open_select_file_dialog(GtkEntry *entry, G_GNUC_UNUSED GtkEntryIconP | @@ -293,7 +297,17 @@ static void open_select_file_dialog(GtkEntry *entry, G_GNUC_UNUSED GtkEntryIconP | ||
293 | // Record format | 297 | // Record format |
294 | { | 298 | { |
295 | GSList * group = NULL; | 299 | GSList * group = NULL; |
296 | - widget->recordFormatBox = create_frame(options, _("Record format"), gtk_box_new(GTK_ORIENTATION_VERTICAL,6),GTK_ALIGN_CENTER); | 300 | + |
301 | + widget->recordFormatBox = | ||
302 | + v3270_box_pack_frame( | ||
303 | + options, | ||
304 | + gtk_box_new(GTK_ORIENTATION_VERTICAL,6), | ||
305 | + _("Record format"), | ||
306 | + GTK_ALIGN_CENTER, | ||
307 | + FALSE, | ||
308 | + FALSE, | ||
309 | + 0 | ||
310 | + ); | ||
297 | 311 | ||
298 | for(ix=4;ix<8;ix++) | 312 | for(ix=4;ix<8;ix++) |
299 | { | 313 | { |
@@ -309,7 +323,16 @@ static void open_select_file_dialog(GtkEntry *entry, G_GNUC_UNUSED GtkEntryIconP | @@ -309,7 +323,16 @@ static void open_select_file_dialog(GtkEntry *entry, G_GNUC_UNUSED GtkEntryIconP | ||
309 | // Space allocation units | 323 | // Space allocation units |
310 | { | 324 | { |
311 | GSList * group = NULL; | 325 | GSList * group = NULL; |
312 | - widget->spaceAllocationBox = create_frame(options, _("Space allocation units"), gtk_box_new(GTK_ORIENTATION_VERTICAL,6),GTK_ALIGN_END); | 326 | + widget->spaceAllocationBox = |
327 | + v3270_box_pack_frame( | ||
328 | + options, | ||
329 | + gtk_box_new(GTK_ORIENTATION_VERTICAL,6), | ||
330 | + _("Space allocation units"), | ||
331 | + GTK_ALIGN_END, | ||
332 | + FALSE, | ||
333 | + FALSE, | ||
334 | + 0 | ||
335 | + ); | ||
313 | 336 | ||
314 | for(ix=8;ix<12;ix++) | 337 | for(ix=8;ix<12;ix++) |
315 | { | 338 | { |