Commit 1911bca8165e6a3426ed8af1718ace7e8a4ad850
1 parent
4c113245
Exists in
master
and in
5 other branches
- Fix para o bug 998842 (https://bugzilla.suse.com/show_bug.cgi?id=998842) causo…
…u problemas na compilação gtk2; corrigindo
Showing
2 changed files
with
35 additions
and
29 deletions
Show diff stats
src/pw3270/uiparser/keypad.c
@@ -64,7 +64,32 @@ | @@ -64,7 +64,32 @@ | ||
64 | keypad->col = atoi(tmp); | 64 | keypad->col = atoi(tmp); |
65 | } | 65 | } |
66 | 66 | ||
67 | +#if GTK_CHECK_VERSION(3,0,0) | ||
68 | + | ||
67 | gtk_grid_attach(keypad->grid,keypad->widget,keypad->col,keypad->row,width,height); | 69 | gtk_grid_attach(keypad->grid,keypad->widget,keypad->col,keypad->row,width,height); |
70 | + | ||
71 | +#else | ||
72 | + guint r = 0, c = 0; | ||
73 | + | ||
74 | + gtk_table_get_size(keypad->grid,&r,&c); | ||
75 | + | ||
76 | + if(r < keypad->row || c < (keypad->col+1)) { | ||
77 | + trace("Resize to %u,%u to %u,%u",r,c,keypad->row,keypad->col+1); | ||
78 | + gtk_table_resize(keypad->grid,keypad->row,keypad->col+1); | ||
79 | + } | ||
80 | + | ||
81 | + r = keypad->row-1; | ||
82 | + c = keypad->col; | ||
83 | + | ||
84 | + gtk_table_attach( keypad->grid, | ||
85 | + keypad->widget, | ||
86 | + c,c+width, | ||
87 | + r,r+height, | ||
88 | + GTK_EXPAND|GTK_FILL, | ||
89 | + GTK_EXPAND|GTK_FILL, | ||
90 | + 1,1); | ||
91 | +#endif | ||
92 | + | ||
68 | keypad->widget = NULL; | 93 | keypad->widget = NULL; |
69 | 94 | ||
70 | } | 95 | } |
@@ -167,10 +192,15 @@ | @@ -167,10 +192,15 @@ | ||
167 | keypad->parser = info; | 192 | keypad->parser = info; |
168 | keypad->pos = ui_get_position_attribute(names,values); | 193 | keypad->pos = ui_get_position_attribute(names,values); |
169 | keypad->relief = ui_get_relief(names, values, GTK_RELIEF_NORMAL); | 194 | keypad->relief = ui_get_relief(names, values, GTK_RELIEF_NORMAL); |
170 | - keypad->grid = GTK_GRID(gtk_grid_new()); | ||
171 | 195 | ||
196 | +#if GTK_CHECK_VERSION(3,0,0) | ||
197 | + keypad->grid = GTK_GRID(gtk_grid_new()); | ||
172 | gtk_grid_set_row_homogeneous(keypad->grid,TRUE); | 198 | gtk_grid_set_row_homogeneous(keypad->grid,TRUE); |
173 | gtk_grid_set_column_homogeneous(keypad->grid,TRUE); | 199 | gtk_grid_set_column_homogeneous(keypad->grid,TRUE); |
200 | +#else | ||
201 | + keypad->grid = GTK_TABLE(gtk_table_new(1,1,TRUE)); | ||
202 | +#endif // GTK3 | ||
203 | + | ||
174 | 204 | ||
175 | g_object_set_data(G_OBJECT(keypad->grid),"position",(gpointer) keypad->pos); | 205 | g_object_set_data(G_OBJECT(keypad->grid),"position",(gpointer) keypad->pos); |
176 | 206 |
src/pw3270/uiparser/keypad.h
@@ -37,38 +37,14 @@ | @@ -37,38 +37,14 @@ | ||
37 | struct parser * parser; | 37 | struct parser * parser; |
38 | unsigned short row; | 38 | unsigned short row; |
39 | unsigned short col; | 39 | unsigned short col; |
40 | +#if GTK_CHECK_VERSION(3,0,0) | ||
40 | GtkGrid * grid; | 41 | GtkGrid * grid; |
42 | +#else | ||
43 | + GtkTable * grid; | ||
44 | +#endif // GTK3 | ||
41 | GtkWidget * widget; | 45 | GtkWidget * widget; |
42 | GtkReliefStyle relief; | 46 | GtkReliefStyle relief; |
43 | UI_ATTR_DIRECTION pos; | 47 | UI_ATTR_DIRECTION pos; |
44 | }; | 48 | }; |
45 | 49 | ||
46 | -/* | ||
47 | - struct row | ||
48 | - { | ||
49 | - unsigned short pos; | ||
50 | - unsigned short num_cols; | ||
51 | - GList * cols; | ||
52 | - }; | ||
53 | - | ||
54 | - struct keypad | ||
55 | - { | ||
56 | - struct parser * parser; | ||
57 | - unsigned short num_rows; | ||
58 | - unsigned short num_cols; | ||
59 | - unsigned short col; | ||
60 | - unsigned short button_width; | ||
61 | - struct row * row; | ||
62 | - GtkWidget * box; | ||
63 | - GtkWidget * handle; | ||
64 | - GtkWidget * table; | ||
65 | - GtkReliefStyle relief; | ||
66 | - UI_ATTR_DIRECTION pos; | ||
67 | - GList * rows; | ||
68 | - | ||
69 | - GtkWidget * widget; | ||
70 | - | ||
71 | - }; | ||
72 | -*/ | ||
73 | - | ||
74 | G_GNUC_INTERNAL void keypad_button_start(GMarkupParseContext *context, const gchar **names,const gchar **values, GError **error, struct keypad *keypad); | 50 | G_GNUC_INTERNAL void keypad_button_start(GMarkupParseContext *context, const gchar **names,const gchar **values, GError **error, struct keypad *keypad); |