Mercurial > pidgin
annotate finch/libgnt/gntmain.c @ 17826:ab71a09600ad
Changed a malloc use to g_new0
author | Eric Polino <aluink@pidgin.im> |
---|---|
date | Mon, 04 Jun 2007 03:08:59 +0000 |
parents | cfa84fed6ecd |
children | 8410511f4dbb |
rev | line source |
---|---|
15817 | 1 #define _GNU_SOURCE |
2 #if defined(__APPLE__) | |
3 #define _XOPEN_SOURCE_EXTENDED | |
4 #endif | |
5 | |
6 #include "config.h" | |
7 | |
8 #include <gmodule.h> | |
9 | |
10 #include <sys/types.h> | |
11 #include <sys/wait.h> | |
12 | |
13 #include "gnt.h" | |
14 #include "gntbox.h" | |
16888
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
15 #include "gntbutton.h" |
15817 | 16 #include "gntcolors.h" |
17 #include "gntclipboard.h" | |
18 #include "gntkeys.h" | |
16888
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
19 #include "gntlabel.h" |
15817 | 20 #include "gntmenu.h" |
21 #include "gntstyle.h" | |
22 #include "gnttree.h" | |
23 #include "gntutils.h" | |
16888
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
24 #include "gntwindow.h" |
15817 | 25 #include "gntwm.h" |
26 | |
27 #include <panel.h> | |
28 | |
29 #include <stdio.h> | |
30 #include <stdlib.h> | |
31 #include <locale.h> | |
32 #include <unistd.h> | |
33 #include <signal.h> | |
34 #include <string.h> | |
35 #include <ctype.h> | |
36 #include <errno.h> | |
37 | |
38 /** | |
39 * Notes: Interesting functions to look at: | |
40 * scr_dump, scr_init, scr_restore: for workspaces | |
41 * | |
42 * Need to wattrset for colors to use with PDCurses. | |
43 */ | |
44 | |
45 static GIOChannel *channel = NULL; | |
46 | |
47 static gboolean ascii_only; | |
48 static gboolean mouse_enabled; | |
49 | |
50 static void setup_io(void); | |
51 | |
52 static gboolean refresh_screen(); | |
53 | |
54 GntWM *wm; | |
55 static GntClipboard *clipboard; | |
56 | |
57 #define HOLDING_ESCAPE (escape_stuff.timer != 0) | |
58 | |
59 static struct { | |
60 int timer; | |
61 } escape_stuff; | |
62 | |
63 static gboolean | |
64 escape_timeout(gpointer data) | |
65 { | |
66 gnt_wm_process_input(wm, "\033"); | |
67 escape_stuff.timer = 0; | |
68 return FALSE; | |
69 } | |
70 | |
71 /** | |
72 * Mouse support: | |
73 * - bring a window on top if you click on its taskbar | |
74 * - click on the top-bar of the active window and drag+drop to move a window | |
75 * - click on a window to bring it to focus | |
76 * - allow scrolling in tree/textview on wheel-scroll event | |
77 * - click to activate button or select a row in tree | |
78 * wishlist: | |
79 * - have a little [X] on the windows, and clicking it will close that window. | |
80 */ | |
81 static gboolean | |
82 detect_mouse_action(const char *buffer) | |
83 { | |
84 int x, y; | |
85 static enum { | |
86 MOUSE_NONE, | |
87 MOUSE_LEFT, | |
88 MOUSE_RIGHT, | |
89 MOUSE_MIDDLE | |
90 } button = MOUSE_NONE; | |
91 static GntWidget *remember = NULL; | |
92 static int offset = 0; | |
93 GntMouseEvent event; | |
94 GntWidget *widget = NULL; | |
95 PANEL *p = NULL; | |
96 | |
97 if (!wm->ordered || buffer[0] != 27) | |
98 return FALSE; | |
99 | |
100 buffer++; | |
101 if (strlen(buffer) < 5) | |
102 return FALSE; | |
103 | |
104 x = buffer[3]; | |
105 y = buffer[4]; | |
106 if (x < 0) x += 256; | |
107 if (y < 0) y += 256; | |
108 x -= 33; | |
109 y -= 33; | |
110 | |
111 while ((p = panel_below(p)) != NULL) { | |
112 const GntNode *node = panel_userptr(p); | |
113 GntWidget *wid; | |
114 if (!node) | |
115 continue; | |
116 wid = node->me; | |
117 if (x >= wid->priv.x && x < wid->priv.x + wid->priv.width) { | |
118 if (y >= wid->priv.y && y < wid->priv.y + wid->priv.height) { | |
119 widget = wid; | |
120 break; | |
121 } | |
122 } | |
123 } | |
124 | |
125 if (strncmp(buffer, "[M ", 3) == 0) { | |
126 /* left button down */ | |
127 /* Bring the window you clicked on to front */ | |
128 /* If you click on the topbar, then you can drag to move the window */ | |
129 event = GNT_LEFT_MOUSE_DOWN; | |
130 } else if (strncmp(buffer, "[M\"", 3) == 0) { | |
131 /* right button down */ | |
132 event = GNT_RIGHT_MOUSE_DOWN; | |
133 } else if (strncmp(buffer, "[M!", 3) == 0) { | |
134 /* middle button down */ | |
135 event = GNT_MIDDLE_MOUSE_DOWN; | |
136 } else if (strncmp(buffer, "[M`", 3) == 0) { | |
137 /* wheel up*/ | |
138 event = GNT_MOUSE_SCROLL_UP; | |
139 } else if (strncmp(buffer, "[Ma", 3) == 0) { | |
140 /* wheel down */ | |
141 event = GNT_MOUSE_SCROLL_DOWN; | |
142 } else if (strncmp(buffer, "[M#", 3) == 0) { | |
143 /* button up */ | |
144 event = GNT_MOUSE_UP; | |
145 } else | |
146 return FALSE; | |
17047
a19b8d71f868
Do not process clicks on no widget.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16888
diff
changeset
|
147 |
17053
541c5ed54e90
Fix the commit from earlier today about null-widgets.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
17047
diff
changeset
|
148 if (widget && gnt_wm_process_click(wm, event, x, y, widget)) |
15817 | 149 return TRUE; |
150 | |
151 if (event == GNT_LEFT_MOUSE_DOWN && widget && widget != wm->_list.window && | |
152 !GNT_WIDGET_IS_FLAG_SET(widget, GNT_WIDGET_TRANSIENT)) { | |
153 if (widget != wm->ordered->data) { | |
154 gnt_wm_raise_window(wm, widget); | |
155 } | |
156 if (y == widget->priv.y) { | |
157 offset = x - widget->priv.x; | |
158 remember = widget; | |
159 button = MOUSE_LEFT; | |
160 } | |
161 } else if (event == GNT_MOUSE_UP) { | |
162 if (button == MOUSE_NONE && y == getmaxy(stdscr) - 1) { | |
163 /* Clicked on the taskbar */ | |
164 int n = g_list_length(wm->list); | |
165 if (n) { | |
166 int width = getmaxx(stdscr) / n; | |
167 gnt_bindable_perform_action_named(GNT_BINDABLE(wm), "switch-window-n", x/width, NULL); | |
168 } | |
169 } else if (button == MOUSE_LEFT && remember) { | |
170 x -= offset; | |
171 if (x < 0) x = 0; | |
172 if (y < 0) y = 0; | |
173 gnt_screen_move_widget(remember, x, y); | |
174 } | |
175 button = MOUSE_NONE; | |
176 remember = NULL; | |
177 offset = 0; | |
178 } | |
179 | |
17053
541c5ed54e90
Fix the commit from earlier today about null-widgets.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
17047
diff
changeset
|
180 if (widget) |
541c5ed54e90
Fix the commit from earlier today about null-widgets.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
17047
diff
changeset
|
181 gnt_widget_clicked(widget, event, x, y); |
15817 | 182 return TRUE; |
183 } | |
184 | |
185 static gboolean | |
186 io_invoke_error(GIOChannel *source, GIOCondition cond, gpointer data) | |
187 { | |
188 int id = GPOINTER_TO_INT(data); | |
189 g_source_remove(id); | |
190 g_io_channel_unref(source); | |
191 | |
192 channel = NULL; | |
193 setup_io(); | |
194 return TRUE; | |
195 } | |
196 | |
197 static gboolean | |
198 io_invoke(GIOChannel *source, GIOCondition cond, gpointer null) | |
199 { | |
200 char keys[256]; | |
201 int rd = read(STDIN_FILENO, keys + HOLDING_ESCAPE, sizeof(keys) - 1 - HOLDING_ESCAPE); | |
202 char *k; | |
203 if (rd < 0) | |
204 { | |
205 int ch = getch(); /* This should return ERR, but let's see what it really returns */ | |
206 endwin(); | |
207 printf("ERROR: %s\n", strerror(errno)); | |
208 printf("File descriptor is: %d\n\nGIOChannel is: %p\ngetch() = %d\n", STDIN_FILENO, source, ch); | |
209 raise(SIGABRT); | |
210 } | |
211 else if (rd == 0) | |
212 { | |
213 endwin(); | |
214 printf("EOF\n"); | |
215 raise(SIGABRT); | |
216 } | |
217 | |
16281
82b6fdd899a9
Dialogs opened resulting from a mouse-click should fain focus.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
15817
diff
changeset
|
218 gnt_wm_set_event_stack(wm, TRUE); |
15817 | 219 rd += HOLDING_ESCAPE; |
220 keys[rd] = 0; | |
221 if (mouse_enabled && detect_mouse_action(keys)) | |
16281
82b6fdd899a9
Dialogs opened resulting from a mouse-click should fain focus.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
15817
diff
changeset
|
222 goto end; |
15817 | 223 |
224 if (HOLDING_ESCAPE) | |
225 keys[0] = '\033'; | |
226 k = keys; | |
17822
cfa84fed6ecd
Cleaned up some comment garbage
Eric Polino <aluink@pidgin.im>
parents:
17819
diff
changeset
|
227 if(*k < 0){ /* Alt not sending ESC* */ |
17819
d8b9bea550bc
Added a few lines to gnt_main::io_invoke to deal with ALT not sending ESC.
Eric Polino <aluink@pidgin.im>
parents:
17053
diff
changeset
|
228 *(k + 1) = 128 - *k; |
d8b9bea550bc
Added a few lines to gnt_main::io_invoke to deal with ALT not sending ESC.
Eric Polino <aluink@pidgin.im>
parents:
17053
diff
changeset
|
229 *k = 27; |
d8b9bea550bc
Added a few lines to gnt_main::io_invoke to deal with ALT not sending ESC.
Eric Polino <aluink@pidgin.im>
parents:
17053
diff
changeset
|
230 *(k + 2) = 0; |
d8b9bea550bc
Added a few lines to gnt_main::io_invoke to deal with ALT not sending ESC.
Eric Polino <aluink@pidgin.im>
parents:
17053
diff
changeset
|
231 rd++; |
d8b9bea550bc
Added a few lines to gnt_main::io_invoke to deal with ALT not sending ESC.
Eric Polino <aluink@pidgin.im>
parents:
17053
diff
changeset
|
232 } |
15817 | 233 while (rd) { |
234 char back; | |
235 int p; | |
236 | |
237 if (k[0] == '\033' && rd == 1) { | |
238 if (escape_stuff.timer) { | |
239 gnt_wm_process_input(wm, "\033\033"); | |
240 g_source_remove(escape_stuff.timer); | |
241 escape_stuff.timer = 0; | |
242 break; | |
243 } | |
244 escape_stuff.timer = g_timeout_add(250, escape_timeout, NULL); | |
245 break; | |
246 } | |
247 | |
248 gnt_keys_refine(k); | |
249 p = MAX(1, gnt_keys_find_combination(k)); | |
250 back = k[p]; | |
251 k[p] = '\0'; | |
252 gnt_wm_process_input(wm, k); /* XXX: */ | |
253 k[p] = back; | |
254 rd -= p; | |
255 k += p; | |
256 } | |
16281
82b6fdd899a9
Dialogs opened resulting from a mouse-click should fain focus.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
15817
diff
changeset
|
257 end: |
82b6fdd899a9
Dialogs opened resulting from a mouse-click should fain focus.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
15817
diff
changeset
|
258 gnt_wm_set_event_stack(wm, FALSE); |
15817 | 259 return TRUE; |
260 } | |
261 | |
262 static void | |
263 setup_io() | |
264 { | |
265 int result; | |
266 channel = g_io_channel_unix_new(STDIN_FILENO); | |
267 g_io_channel_set_close_on_unref(channel, TRUE); | |
268 | |
269 #if 0 | |
270 g_io_channel_set_encoding(channel, NULL, NULL); | |
271 g_io_channel_set_buffered(channel, FALSE); | |
272 g_io_channel_set_flags(channel, G_IO_FLAG_NONBLOCK, NULL ); | |
273 #endif | |
274 | |
275 result = g_io_add_watch_full(channel, G_PRIORITY_HIGH, | |
276 (G_IO_IN | G_IO_HUP | G_IO_ERR | G_IO_PRI), | |
277 io_invoke, NULL, NULL); | |
278 | |
279 g_io_add_watch_full(channel, G_PRIORITY_HIGH, | |
280 (G_IO_NVAL), | |
281 io_invoke_error, GINT_TO_POINTER(result), NULL); | |
282 | |
283 g_io_channel_unref(channel); /* Apparently this caused crashes for some people. | |
284 But irssi does this, so I am going to assume the | |
285 crashes were caused by some other stuff. */ | |
286 | |
287 g_printerr("gntmain: setting up IO\n"); | |
288 } | |
289 | |
290 static gboolean | |
291 refresh_screen() | |
292 { | |
293 gnt_bindable_perform_action_named(GNT_BINDABLE(wm), "refresh-screen", NULL); | |
294 return FALSE; | |
295 } | |
296 | |
297 /* Xerox */ | |
298 static void | |
299 clean_pid(void) | |
300 { | |
301 int status; | |
302 pid_t pid; | |
303 | |
304 do { | |
305 pid = waitpid(-1, &status, WNOHANG); | |
306 } while (pid != 0 && pid != (pid_t)-1); | |
307 | |
308 if ((pid == (pid_t) - 1) && (errno != ECHILD)) { | |
309 char errmsg[BUFSIZ]; | |
310 g_snprintf(errmsg, BUFSIZ, "Warning: waitpid() returned %d", pid); | |
311 perror(errmsg); | |
312 } | |
313 } | |
314 | |
315 static void | |
16888
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
316 exit_confirmed(gpointer null) |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
317 { |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
318 gnt_bindable_perform_action_named(GNT_BINDABLE(wm), "wm-quit", NULL); |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
319 } |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
320 |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
321 static void |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
322 exit_win_close(GntWidget *w, GntWidget **win) |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
323 { |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
324 *win = NULL; |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
325 } |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
326 |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
327 static void |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
328 ask_before_exit() |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
329 { |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
330 static GntWidget *win = NULL; |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
331 GntWidget *bbox, *button; |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
332 |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
333 if (win) |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
334 goto raise; |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
335 |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
336 win = gnt_vwindow_new(FALSE); |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
337 gnt_box_add_widget(GNT_BOX(win), gnt_label_new("Are you sure you want to quit?")); |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
338 gnt_box_set_title(GNT_BOX(win), "Quit?"); |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
339 gnt_box_set_alignment(GNT_BOX(win), GNT_ALIGN_MID); |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
340 g_signal_connect(G_OBJECT(win), "destroy", G_CALLBACK(exit_win_close), &win); |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
341 |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
342 bbox = gnt_hbox_new(FALSE); |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
343 gnt_box_add_widget(GNT_BOX(win), bbox); |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
344 |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
345 button = gnt_button_new("Quit"); |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
346 g_signal_connect(G_OBJECT(button), "activate", G_CALLBACK(exit_confirmed), NULL); |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
347 gnt_box_add_widget(GNT_BOX(bbox), button); |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
348 |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
349 button = gnt_button_new("Cancel"); |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
350 g_signal_connect_swapped(G_OBJECT(button), "activate", G_CALLBACK(gnt_widget_destroy), win); |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
351 gnt_box_add_widget(GNT_BOX(bbox), button); |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
352 |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
353 gnt_widget_show(win); |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
354 raise: |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
355 gnt_wm_raise_window(wm, win); |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
356 } |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
357 |
17047
a19b8d71f868
Do not process clicks on no widget.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16888
diff
changeset
|
358 #ifdef SIGWINCH |
a19b8d71f868
Do not process clicks on no widget.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16888
diff
changeset
|
359 static void (*org_winch_handler)(int); |
a19b8d71f868
Do not process clicks on no widget.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16888
diff
changeset
|
360 #endif |
a19b8d71f868
Do not process clicks on no widget.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16888
diff
changeset
|
361 |
16888
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
362 static void |
15817 | 363 sighandler(int sig) |
364 { | |
365 switch (sig) { | |
366 #ifdef SIGWINCH | |
367 case SIGWINCH: | |
368 werase(stdscr); | |
369 wrefresh(stdscr); | |
370 g_idle_add(refresh_screen, NULL); | |
17047
a19b8d71f868
Do not process clicks on no widget.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16888
diff
changeset
|
371 org_winch_handler(sig); |
15817 | 372 signal(SIGWINCH, sighandler); |
373 break; | |
374 #endif | |
375 case SIGCHLD: | |
376 clean_pid(); | |
377 signal(SIGCHLD, sighandler); | |
378 break; | |
16888
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
379 case SIGINT: |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
380 ask_before_exit(); |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
381 signal(SIGINT, sighandler); |
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
382 break; |
15817 | 383 } |
384 } | |
385 | |
386 static void | |
387 init_wm() | |
388 { | |
389 const char *name = gnt_style_get(GNT_STYLE_WM); | |
390 gpointer handle; | |
391 | |
392 if (name && *name) { | |
393 handle = g_module_open(name, G_MODULE_BIND_LAZY); | |
394 if (handle) { | |
395 gboolean (*init)(GntWM **); | |
396 if (g_module_symbol(handle, "gntwm_init", (gpointer)&init)) { | |
397 init(&wm); | |
398 } | |
399 } | |
400 } | |
401 if (wm == NULL) | |
402 wm = g_object_new(GNT_TYPE_WM, NULL); | |
403 } | |
404 | |
405 void gnt_init() | |
406 { | |
407 char *filename; | |
408 const char *locale; | |
409 | |
410 if (channel) | |
411 return; | |
412 | |
413 locale = setlocale(LC_ALL, ""); | |
414 | |
415 setup_io(); | |
416 | |
417 if (locale && (strstr(locale, "UTF") || strstr(locale, "utf"))) | |
418 ascii_only = FALSE; | |
419 else | |
420 ascii_only = TRUE; | |
421 | |
422 initscr(); | |
423 typeahead(-1); | |
424 noecho(); | |
425 curs_set(0); | |
426 | |
427 gnt_init_keys(); | |
428 gnt_init_styles(); | |
429 | |
430 filename = g_build_filename(g_get_home_dir(), ".gntrc", NULL); | |
431 gnt_style_read_configure_file(filename); | |
432 g_free(filename); | |
433 | |
434 gnt_init_colors(); | |
435 | |
436 wbkgdset(stdscr, '\0' | COLOR_PAIR(GNT_COLOR_NORMAL)); | |
437 refresh(); | |
438 | |
439 #ifdef ALL_MOUSE_EVENTS | |
440 if ((mouse_enabled = gnt_style_get_bool(GNT_STYLE_MOUSE, FALSE))) | |
441 mousemask(ALL_MOUSE_EVENTS | REPORT_MOUSE_POSITION, NULL); | |
442 #endif | |
443 | |
444 wbkgdset(stdscr, '\0' | COLOR_PAIR(GNT_COLOR_NORMAL)); | |
445 werase(stdscr); | |
446 wrefresh(stdscr); | |
447 | |
448 #ifdef SIGWINCH | |
17047
a19b8d71f868
Do not process clicks on no widget.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16888
diff
changeset
|
449 org_winch_handler = signal(SIGWINCH, sighandler); |
15817 | 450 #endif |
451 signal(SIGCHLD, sighandler); | |
16888
d2904afe89e2
Ask before exiting when ctrl+c is pressed.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16781
diff
changeset
|
452 signal(SIGINT, sighandler); |
15817 | 453 signal(SIGPIPE, SIG_IGN); |
454 | |
455 g_type_init(); | |
456 | |
457 init_wm(); | |
458 | |
459 clipboard = g_object_new(GNT_TYPE_CLIPBOARD, NULL); | |
460 } | |
461 | |
462 void gnt_main() | |
463 { | |
464 wm->loop = g_main_loop_new(NULL, FALSE); | |
465 g_main_loop_run(wm->loop); | |
466 } | |
467 | |
468 /********************************* | |
469 * Stuff for 'window management' * | |
470 *********************************/ | |
471 | |
472 void gnt_screen_occupy(GntWidget *widget) | |
473 { | |
474 gnt_wm_new_window(wm, widget); | |
475 } | |
476 | |
477 void gnt_screen_release(GntWidget *widget) | |
478 { | |
479 gnt_wm_window_close(wm, widget); | |
480 } | |
481 | |
482 void gnt_screen_update(GntWidget *widget) | |
483 { | |
484 gnt_wm_update_window(wm, widget); | |
485 } | |
486 | |
487 gboolean gnt_widget_has_focus(GntWidget *widget) | |
488 { | |
489 GntWidget *w; | |
490 if (!widget) | |
491 return FALSE; | |
492 | |
493 if (GNT_IS_MENU(widget)) | |
494 return TRUE; | |
495 | |
496 w = widget; | |
497 | |
498 while (widget->parent) | |
499 widget = widget->parent; | |
500 | |
501 if (widget == wm->_list.window) | |
502 return TRUE; | |
503 if (wm->ordered && wm->ordered->data == widget) { | |
504 if (GNT_IS_BOX(widget) && | |
505 (GNT_BOX(widget)->active == w || widget == w)) | |
506 return TRUE; | |
507 } | |
508 return FALSE; | |
509 } | |
510 | |
511 void gnt_widget_set_urgent(GntWidget *widget) | |
512 { | |
513 while (widget->parent) | |
514 widget = widget->parent; | |
515 | |
516 if (wm->ordered && wm->ordered->data == widget) | |
517 return; | |
518 | |
519 GNT_WIDGET_SET_FLAGS(widget, GNT_WIDGET_URGENT); | |
520 | |
521 gnt_wm_update_window(wm, widget); | |
522 } | |
523 | |
524 void gnt_quit() | |
525 { | |
526 g_hash_table_destroy(wm->nodes); /* XXX: */ | |
527 update_panels(); | |
528 doupdate(); | |
529 gnt_uninit_colors(); | |
530 gnt_uninit_styles(); | |
531 endwin(); | |
532 } | |
533 | |
534 gboolean gnt_ascii_only() | |
535 { | |
536 return ascii_only; | |
537 } | |
538 | |
539 void gnt_screen_resize_widget(GntWidget *widget, int width, int height) | |
540 { | |
541 gnt_wm_resize_window(wm, widget, width, height); | |
542 } | |
543 | |
544 void gnt_screen_move_widget(GntWidget *widget, int x, int y) | |
545 { | |
546 gnt_wm_move_window(wm, widget, x, y); | |
547 } | |
548 | |
549 void gnt_screen_rename_widget(GntWidget *widget, const char *text) | |
550 { | |
551 gnt_box_set_title(GNT_BOX(widget), text); | |
552 gnt_widget_draw(widget); | |
553 gnt_wm_update_window(wm, widget); | |
554 } | |
555 | |
556 void gnt_register_action(const char *label, void (*callback)()) | |
557 { | |
558 GntAction *action = g_new0(GntAction, 1); | |
559 action->label = g_strdup(label); | |
560 action->callback = callback; | |
561 | |
562 wm->acts = g_list_append(wm->acts, action); | |
563 } | |
564 | |
565 static void | |
566 reset_menu(GntWidget *widget, gpointer null) | |
567 { | |
568 wm->menu = NULL; | |
569 } | |
570 | |
571 gboolean gnt_screen_menu_show(gpointer newmenu) | |
572 { | |
573 if (wm->menu) { | |
574 /* For now, if a menu is being displayed, then another menu | |
575 * can NOT take over. */ | |
576 return FALSE; | |
577 } | |
578 | |
579 wm->menu = newmenu; | |
580 GNT_WIDGET_UNSET_FLAGS(GNT_WIDGET(wm->menu), GNT_WIDGET_INVISIBLE); | |
581 gnt_widget_draw(GNT_WIDGET(wm->menu)); | |
582 | |
583 g_signal_connect(G_OBJECT(wm->menu), "hide", G_CALLBACK(reset_menu), NULL); | |
16781
d0f9b2b217cf
Fix context menu unusualness in the buddylist.
Sadrul Habib Chowdhury <imadil@gmail.com>
parents:
16281
diff
changeset
|
584 g_signal_connect(G_OBJECT(wm->menu), "destroy", G_CALLBACK(reset_menu), NULL); |
15817 | 585 |
586 return TRUE; | |
587 } | |
588 | |
589 void gnt_set_clipboard_string(gchar *string) | |
590 { | |
591 gnt_clipboard_set_string(clipboard, string); | |
592 } | |
593 | |
594 GntClipboard *gnt_get_clipboard() | |
595 { | |
596 return clipboard; | |
597 } | |
598 gchar *gnt_get_clipboard_string() | |
599 { | |
600 return gnt_clipboard_get_string(clipboard); | |
601 } |