diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/daemon/daemon.c | 19 |
1 files changed, 6 insertions, 13 deletions
diff --git a/src/daemon/daemon.c b/src/daemon/daemon.c index 473a598..4ff9ea9 100644 --- a/src/daemon/daemon.c +++ b/src/daemon/daemon.c @@ -367,11 +367,11 @@ _gtk_get_monitor_num (GdkMonitor *monitor) return -1; } -static void create_stack_for_monitor(NotifyDaemon* daemon, GdkScreen* screen, GdkMonitor *monitor_num) +static void create_stack_for_monitor(NotifyDaemon* daemon, GdkScreen* screen, GdkMonitor *monitor_num, int num) { NotifyScreen* nscreen = daemon->screen; - nscreen->stacks[_gtk_get_monitor_num(monitor_num)] = notify_stack_new(daemon, screen, monitor_num, daemon->stack_location); + nscreen->stacks[num] = notify_stack_new(daemon, screen, monitor_num, daemon->stack_location); } static void on_screen_monitors_changed(GdkScreen* screen, NotifyDaemon* daemon) @@ -461,7 +461,7 @@ static void create_stacks_for_screen(NotifyDaemon* daemon, GdkScreen *screen) for (i = 0; i < nscreen->n_stacks; i++) { - create_stack_for_monitor(daemon, screen, gdk_display_get_monitor (display, i)); + create_stack_for_monitor(daemon, screen, gdk_display_get_monitor (display, i), i); } } @@ -1840,17 +1840,10 @@ static gboolean notify_daemon_notify_handler(NotifyDaemonNotifications *object, monitor_id = gdk_display_get_monitor (gdk_display_get_default(), (int) daemon->screen->n_stacks - 1); } - if (monitor_id != NULL && _gtk_get_monitor_num (monitor_id) >= daemon->screen->n_stacks) + int mon_num = monitor_id != NULL ? _gtk_get_monitor_num (monitor_id) : -1; + if (mon_num >= 0 && mon_num < (int) daemon->screen->n_stacks) { - /* screw it - dump it on the last one we'll get - a monitors-changed signal soon enough*/ - monitor_id = gdk_display_get_monitor (gdk_display_get_default(), (int) daemon->screen->n_stacks - 1); - } - - /* If we still don't have a valid monitor, something is seriously wrong */ - if (monitor_id != NULL && daemon->screen->n_stacks > 0) - { - notify_stack_add_window (daemon->screen->stacks[_gtk_get_monitor_num (monitor_id)], nw, new_notification); + notify_stack_add_window (daemon->screen->stacks[mon_num], nw, new_notification); } } |
