Commit a3fdfc937e9c1f84d436075d65056c02cefd0934
1 parent
97bf1562
Exists in
master
and in
5 other branches
Finalizando widget para trace
Showing
1 changed file
with
41 additions
and
7 deletions
Show diff stats
src/pw3270/trace.c
... | ... | @@ -55,6 +55,7 @@ |
55 | 55 | GtkWidget * entry; |
56 | 56 | GtkWidget * button; |
57 | 57 | gchar **line; |
58 | + gboolean * enabled; | |
58 | 59 | }; |
59 | 60 | |
60 | 61 | const GtkWindowClass * pw3270_trace_get_parent_class(void); |
... | ... | @@ -73,7 +74,19 @@ |
73 | 74 | |
74 | 75 | static void activate_default(GtkWindow *window) |
75 | 76 | { |
77 | + pw3270_trace * hwnd = PW3270_TRACE(window); | |
78 | + | |
76 | 79 | trace("%s",__FUNCTION__); |
80 | + | |
81 | + if(*hwnd->line) | |
82 | + g_free(*hwnd->line); | |
83 | + | |
84 | + *hwnd->line = g_strdup(gtk_entry_get_text(GTK_ENTRY(hwnd->entry))); | |
85 | + | |
86 | + gtk_widget_set_sensitive(hwnd->entry,FALSE); | |
87 | + gtk_widget_set_sensitive(hwnd->button,FALSE); | |
88 | + | |
89 | + *hwnd->enabled = FALSE; | |
77 | 90 | } |
78 | 91 | |
79 | 92 | #if GTK_CHECK_VERSION(3,0,0) |
... | ... | @@ -84,7 +97,8 @@ static void destroy(GtkObject *widget) |
84 | 97 | { |
85 | 98 | pw3270_trace * hwnd = PW3270_TRACE(widget); |
86 | 99 | |
87 | - hwnd->line = NULL; | |
100 | + hwnd->line = NULL; | |
101 | + *hwnd->enabled = FALSE; | |
88 | 102 | |
89 | 103 | #if GTK_CHECK_VERSION(3,0,0) |
90 | 104 | GTK_WIDGET_CLASS(pw3270_trace_parent_class)->destroy(widget); |
... | ... | @@ -94,17 +108,28 @@ static void destroy(GtkObject *widget) |
94 | 108 | |
95 | 109 | } |
96 | 110 | |
111 | + static gboolean delete_event(GtkWidget *widget, GdkEventAny *event) | |
112 | + { | |
113 | + pw3270_trace * hwnd = PW3270_TRACE(widget); | |
114 | + trace("%s",__FUNCTION__); | |
115 | + hwnd->line = NULL; | |
116 | + *hwnd->enabled = FALSE; | |
117 | + gtk_widget_hide(widget); | |
118 | + return TRUE; | |
119 | + } | |
120 | + | |
97 | 121 | static void pw3270_trace_class_init(pw3270_traceClass *klass) |
98 | 122 | { |
99 | 123 | GtkWindowClass * window_class = GTK_WINDOW_CLASS(klass); |
124 | + GtkWidgetClass * widget_class = GTK_WIDGET_CLASS(klass); | |
100 | 125 | |
101 | 126 | trace("%s",__FUNCTION__); |
102 | 127 | |
103 | 128 | window_class->activate_default = activate_default; |
129 | + widget_class->delete_event = delete_event; | |
104 | 130 | |
105 | 131 | #if GTK_CHECK_VERSION(3,0,0) |
106 | 132 | { |
107 | - GtkWidgetClass * widget_class = GTK_WIDGET_CLASS(klass); | |
108 | 133 | widget_class->destroy = destroy; |
109 | 134 | } |
110 | 135 | #else |
... | ... | @@ -116,6 +141,12 @@ static void destroy(GtkObject *widget) |
116 | 141 | |
117 | 142 | } |
118 | 143 | |
144 | + static void activate(GtkButton *button, GtkWindow *window) | |
145 | + { | |
146 | + trace("%s",__FUNCTION__); | |
147 | + activate_default(window); | |
148 | + } | |
149 | + | |
119 | 150 | static void pw3270_trace_init(pw3270_trace *window) |
120 | 151 | { |
121 | 152 | GtkWidget *widget; |
... | ... | @@ -142,13 +173,14 @@ static void destroy(GtkObject *widget) |
142 | 173 | window->entry = gtk_entry_new(); |
143 | 174 | gtk_box_pack_start(GTK_BOX(widget),window->entry,TRUE,TRUE,4); |
144 | 175 | gtk_widget_set_sensitive(window->entry,FALSE); |
176 | + g_signal_connect(G_OBJECT(window->entry),"activate",G_CALLBACK(activate),window); | |
145 | 177 | |
146 | 178 | window->button = gtk_button_new_from_stock(GTK_STOCK_OK); |
147 | 179 | gtk_box_pack_end(GTK_BOX(widget),window->button,FALSE,FALSE,4); |
148 | 180 | gtk_widget_set_sensitive(window->button,FALSE); |
149 | 181 | gtk_button_set_focus_on_click(GTK_BUTTON(window->button),FALSE); |
150 | 182 | |
151 | - g_signal_connect(G_OBJECT(window->button),"clicked",G_CALLBACK(gtk_window_activate_default),window); | |
183 | + g_signal_connect(G_OBJECT(window->button),"clicked",G_CALLBACK(activate),window); | |
152 | 184 | |
153 | 185 | gtk_box_pack_start(GTK_BOX(vbox),widget,FALSE,TRUE,0); |
154 | 186 | |
... | ... | @@ -194,17 +226,19 @@ static void destroy(GtkObject *widget) |
194 | 226 | |
195 | 227 | LIB3270_EXPORT gchar * pw3270_trace_get_command(GtkWidget *widget) |
196 | 228 | { |
197 | - pw3270_trace * hwnd = PW3270_TRACE(widget); | |
198 | - gchar * line = NULL; | |
229 | + pw3270_trace * hwnd = PW3270_TRACE(widget); | |
230 | + gchar * line = NULL; | |
231 | + gboolean enabled = TRUE; | |
199 | 232 | |
200 | - hwnd->line = &line; | |
233 | + hwnd->line = &line; | |
234 | + hwnd->enabled = &enabled; | |
201 | 235 | |
202 | 236 | gtk_window_present(GTK_WINDOW(widget)); |
203 | 237 | gtk_widget_set_sensitive(hwnd->entry,TRUE); |
204 | 238 | gtk_widget_set_sensitive(hwnd->button,TRUE); |
205 | 239 | gtk_widget_grab_focus(hwnd->entry); |
206 | 240 | |
207 | - while(hwnd->line) | |
241 | + while(enabled) | |
208 | 242 | { |
209 | 243 | gtk_main_iteration(); |
210 | 244 | } | ... | ... |