2008-01-13 01:10:12 +00:00
|
|
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
2006-10-01 22:30:10 +00:00
|
|
|
|
2014-05-02 13:34:02 +00:00
|
|
|
/*
|
2001-05-30 15:36:31 +00:00
|
|
|
* Copyright (C) 2001 Havoc Pennington
|
Fix bug 143333, support for update counter spec, and 109362, schedule
Sat Jun 19 02:21:08 2004 Soeren Sandmann <sandmann@daimi.au.dk>
Fix bug 143333, support for update counter spec, and 109362,
schedule compensation events when events are ignored.
* src/display.c (meta_display_open): Add _NET_WM_SYNC_REQUEST and
_NET_WM_SYNC_REQUEST_COUNTER atoms. Remove the old
METACITY_SYNC_COUNTER stuff.
(meta_display_begin_op): Setup the sync counter
* src/xprops.c, src/xprops.h, src/window-props.c, src/display.h:
Add new atoms.
* src/window.c (send_sync_request): new function.
(meta_window_move_resize_internal): send a sync request before
resizing.
(check_move_resize_frequence): Rework logic to also check the SYNC
case. If an event is ignored return the remaining time.
(update_resize_timeout): Timeout that gets called when a
compensation event is scheduled.
(uddate_resize): schedule compensation events when an event is
ignored.
(meta_window_handle_mouse_grap_op_event): When an alarm is
received and sync was turned off, turn it back on.
* src/window.h (struct MetaWindow) Add some variables
2004-06-19 00:45:24 +00:00
|
|
|
* Copyright (C) 2002, 2003, 2004 Red Hat, Inc.
|
2004-02-23 01:48:29 +00:00
|
|
|
* Copyright (C) 2003, 2004 Rob Adams
|
2006-01-10 19:43:21 +00:00
|
|
|
* Copyright (C) 2004-2006 Elijah Newren
|
2014-05-02 13:34:02 +00:00
|
|
|
*
|
2001-05-30 15:36:31 +00:00
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License as
|
|
|
|
* published by the Free Software Foundation; either version 2 of the
|
|
|
|
* License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful, but
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* General Public License for more details.
|
2014-05-02 13:34:02 +00:00
|
|
|
*
|
2001-05-30 15:36:31 +00:00
|
|
|
* You should have received a copy of the GNU General Public License
|
2014-01-12 01:42:06 +00:00
|
|
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
2001-05-30 15:36:31 +00:00
|
|
|
*/
|
|
|
|
|
2013-03-11 15:52:36 +00:00
|
|
|
/**
|
|
|
|
* SECTION:display
|
|
|
|
* @title: MetaDisplay
|
|
|
|
* @short_description: Mutter X display handler
|
2008-01-08 03:59:12 +00:00
|
|
|
*
|
2011-11-02 15:34:45 +00:00
|
|
|
* The display is represented as a #MetaDisplay struct.
|
2008-01-08 03:59:12 +00:00
|
|
|
*/
|
|
|
|
|
2010-06-07 17:09:46 +00:00
|
|
|
#define _XOPEN_SOURCE 600 /* for gethostname() */
|
|
|
|
|
2001-12-09 22:41:12 +00:00
|
|
|
#include <config.h>
|
2008-05-19 00:00:09 +00:00
|
|
|
#include "display-private.h"
|
2014-03-20 19:29:30 +00:00
|
|
|
#include "events.h"
|
2013-09-11 08:18:53 +00:00
|
|
|
#include "util-private.h"
|
2011-03-06 00:29:12 +00:00
|
|
|
#include <meta/main.h>
|
2017-08-27 18:44:58 +00:00
|
|
|
#include "main-private.h"
|
2008-05-19 00:00:09 +00:00
|
|
|
#include "window-private.h"
|
2017-08-26 16:37:29 +00:00
|
|
|
#include "boxes-private.h"
|
2011-03-06 00:29:12 +00:00
|
|
|
#include "frame.h"
|
|
|
|
#include <meta/errors.h>
|
2009-01-29 14:16:01 +00:00
|
|
|
#include "keybindings-private.h"
|
2011-03-06 00:29:12 +00:00
|
|
|
#include <meta/prefs.h>
|
2008-09-18 15:09:11 +00:00
|
|
|
#include "workspace-private.h"
|
2003-01-28 15:07:43 +00:00
|
|
|
#include "bell.h"
|
2011-03-06 00:29:12 +00:00
|
|
|
#include <meta/compositor.h>
|
2012-08-29 02:38:54 +00:00
|
|
|
#include <meta/compositor-mutter.h>
|
2001-06-10 03:17:15 +00:00
|
|
|
#include <X11/Xatom.h>
|
2015-07-06 04:58:45 +00:00
|
|
|
#include <meta/meta-enum-types.h>
|
2014-03-31 00:38:56 +00:00
|
|
|
#include "meta-idle-monitor-dbus.h"
|
2013-11-19 00:34:04 +00:00
|
|
|
#include "meta-cursor-tracker-private.h"
|
2014-08-05 12:11:59 +00:00
|
|
|
#include <meta/meta-backend.h>
|
2016-12-13 02:37:11 +00:00
|
|
|
#include "backends/meta-logical-monitor.h"
|
2015-01-16 08:50:51 +00:00
|
|
|
#include "backends/native/meta-backend-native.h"
|
2014-04-23 19:30:30 +00:00
|
|
|
#include "backends/x11/meta-backend-x11.h"
|
2018-05-02 16:53:11 +00:00
|
|
|
#include "backends/meta-stage-private.h"
|
2016-06-22 17:10:13 +00:00
|
|
|
#include "backends/meta-input-settings-private.h"
|
2014-06-19 21:13:38 +00:00
|
|
|
#include <clutter/x11/clutter-x11.h>
|
2012-02-10 15:27:14 +00:00
|
|
|
|
2003-01-03 19:06:53 +00:00
|
|
|
#ifdef HAVE_RANDR
|
|
|
|
#include <X11/extensions/Xrandr.h>
|
|
|
|
#endif
|
2003-01-05 07:51:02 +00:00
|
|
|
#include <X11/extensions/shape.h>
|
2005-07-11 13:25:08 +00:00
|
|
|
#include <X11/Xcursor/Xcursor.h>
|
Merge compositor branch.
2007-12-18 Iain Holmes <iain@gnome.org>
* configure.in, src/theme.c, src/display.c,
src/theme.h, src/display.h, src/theme-parser.c,
src/compositor.c, src/c-screen.c, src/compositor.h,
src/c-screen.h, src/ui.c, src/screen.c, src/ui.h,
src/screen.h, src/c-window.c, src/c-window.h,
src/theme-viewer.c, src/Makefile.am: Merge compositor branch.
svn path=/trunk/; revision=3483
2007-12-19 03:49:50 +00:00
|
|
|
#include <X11/extensions/Xcomposite.h>
|
|
|
|
#include <X11/extensions/Xdamage.h>
|
|
|
|
#include <X11/extensions/Xfixes.h>
|
2013-03-04 14:57:01 +00:00
|
|
|
#include <stdlib.h>
|
2001-06-10 03:17:15 +00:00
|
|
|
#include <string.h>
|
2010-06-07 16:32:56 +00:00
|
|
|
#include <unistd.h>
|
2001-05-30 15:36:31 +00:00
|
|
|
|
2014-08-15 16:48:55 +00:00
|
|
|
#include "x11/events.h"
|
2014-03-19 01:56:45 +00:00
|
|
|
#include "x11/window-x11.h"
|
|
|
|
#include "x11/xprops.h"
|
2017-08-26 16:24:46 +00:00
|
|
|
#include "x11/meta-x11-display-private.h"
|
2014-03-19 01:56:45 +00:00
|
|
|
|
2014-08-14 00:19:35 +00:00
|
|
|
#ifdef HAVE_WAYLAND
|
2014-03-19 02:01:31 +00:00
|
|
|
#include "wayland/meta-xwayland-private.h"
|
2016-06-22 17:10:13 +00:00
|
|
|
#include "wayland/meta-wayland-tablet-seat.h"
|
|
|
|
#include "wayland/meta-wayland-tablet-pad.h"
|
2014-08-14 00:19:35 +00:00
|
|
|
#endif
|
2013-08-12 13:31:18 +00:00
|
|
|
|
2014-02-15 16:33:12 +00:00
|
|
|
/*
|
|
|
|
* SECTION:pings
|
|
|
|
*
|
|
|
|
* Sometimes we want to see whether a window is responding,
|
|
|
|
* so we send it a "ping" message and see whether it sends us back a "pong"
|
|
|
|
* message within a reasonable time. Here we have a system which lets us
|
|
|
|
* nominate one function to be called if we get the pong in time and another
|
|
|
|
* function if we don't. The system is rather more complicated than it needs
|
|
|
|
* to be, since we only ever use it to destroy windows which are asked to
|
|
|
|
* close themselves and don't do so within a reasonable amount of time, and
|
|
|
|
* therefore we always use the same callbacks. It's possible that we might
|
|
|
|
* use it for other things in future, or on the other hand we might decide
|
|
|
|
* that we're never going to do so and simplify it a bit.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* MetaPingData:
|
|
|
|
*
|
|
|
|
* Describes a ping on a window. When we send a ping to a window, we build
|
|
|
|
* one of these structs, and it eventually gets passed to the timeout function
|
|
|
|
* or to the function which handles the response from the window. If the window
|
|
|
|
* does or doesn't respond to the ping, we use this information to deal with
|
|
|
|
* these facts; we have a handler function for each.
|
|
|
|
*/
|
|
|
|
typedef struct
|
|
|
|
{
|
2014-05-20 18:48:08 +00:00
|
|
|
MetaWindow *window;
|
|
|
|
guint32 serial;
|
|
|
|
guint ping_timeout_id;
|
2014-02-15 16:33:12 +00:00
|
|
|
} MetaPingData;
|
|
|
|
|
2008-12-02 22:58:07 +00:00
|
|
|
G_DEFINE_TYPE(MetaDisplay, meta_display, G_TYPE_OBJECT);
|
|
|
|
|
2008-12-02 23:13:11 +00:00
|
|
|
/* Signals */
|
|
|
|
enum
|
|
|
|
{
|
2017-08-26 16:37:29 +00:00
|
|
|
CURSOR_UPDATED,
|
2018-06-30 06:55:48 +00:00
|
|
|
X11_DISPLAY_OPENED,
|
|
|
|
X11_DISPLAY_CLOSING,
|
2008-12-02 23:13:11 +00:00
|
|
|
OVERLAY_KEY,
|
2012-08-28 13:28:11 +00:00
|
|
|
ACCELERATOR_ACTIVATED,
|
2013-04-10 11:34:26 +00:00
|
|
|
MODIFIERS_ACCELERATOR_ACTIVATED,
|
2009-07-30 21:33:11 +00:00
|
|
|
FOCUS_WINDOW,
|
2009-10-13 14:34:34 +00:00
|
|
|
WINDOW_CREATED,
|
2009-10-28 17:19:24 +00:00
|
|
|
WINDOW_DEMANDS_ATTENTION,
|
2009-11-17 10:24:18 +00:00
|
|
|
WINDOW_MARKED_URGENT,
|
2012-02-10 15:27:14 +00:00
|
|
|
GRAB_OP_BEGIN,
|
|
|
|
GRAB_OP_END,
|
2014-05-08 22:35:49 +00:00
|
|
|
SHOW_RESTART_MESSAGE,
|
|
|
|
RESTART,
|
2014-12-30 01:20:07 +00:00
|
|
|
SHOW_RESIZE_POPUP,
|
2016-05-20 17:22:23 +00:00
|
|
|
GL_VIDEO_MEMORY_PURGED,
|
2016-06-22 17:14:35 +00:00
|
|
|
SHOW_PAD_OSD,
|
2016-12-28 11:03:29 +00:00
|
|
|
SHOW_OSD,
|
2016-12-28 12:00:18 +00:00
|
|
|
PAD_MODE_SWITCH,
|
2017-08-26 19:10:38 +00:00
|
|
|
WINDOW_ENTERED_MONITOR,
|
|
|
|
WINDOW_LEFT_MONITOR,
|
2017-08-26 19:39:46 +00:00
|
|
|
WORKSPACE_ADDED,
|
|
|
|
WORKSPACE_REMOVED,
|
|
|
|
WORKSPACE_SWITCHED,
|
2017-08-26 20:29:10 +00:00
|
|
|
ACTIVE_WORKSPACE_CHANGED,
|
2017-08-26 19:10:38 +00:00
|
|
|
IN_FULLSCREEN_CHANGED,
|
2017-08-26 20:29:10 +00:00
|
|
|
SHOWING_DESKTOP_CHANGED,
|
2017-08-26 19:10:38 +00:00
|
|
|
STARTUP_SEQUENCE_CHANGED,
|
2017-08-26 17:03:51 +00:00
|
|
|
RESTACKED,
|
2017-08-26 19:10:38 +00:00
|
|
|
WORKAREAS_CHANGED,
|
2008-12-02 23:13:11 +00:00
|
|
|
LAST_SIGNAL
|
|
|
|
};
|
|
|
|
|
2009-07-30 21:33:11 +00:00
|
|
|
enum {
|
|
|
|
PROP_0,
|
|
|
|
|
2017-08-26 19:39:46 +00:00
|
|
|
PROP_FOCUS_WINDOW,
|
|
|
|
PROP_N_WORKSPACES
|
2009-07-30 21:33:11 +00:00
|
|
|
};
|
|
|
|
|
2008-12-02 23:13:11 +00:00
|
|
|
static guint display_signals [LAST_SIGNAL] = { 0 };
|
|
|
|
|
2011-11-02 15:34:45 +00:00
|
|
|
/*
|
MetaDisplay becomes a singleton. The static variable which holds this
2008-03-25 Thomas Thurman <tthurman@gnome.org>
* src/core/display.c (meta_display_queue_retheme_all_windows,
meta_set_syncing, meta_display_set_cursor_theme, disable_compositor,
meta_display_for_x_display, meta_display_open, meta_display_close,
meta_display_ungrab): MetaDisplay becomes a singleton. The static
variable which holds this singleton is renamed "the_display" so as
not to mask the this parameter in the methods.
* src/core/main.c (main):
* src/core/session.c (warn_about_lame_clients_and_finish_inte,
save_state, io_from_warning_dialog):
* src/core/core.c (meta_core_increment_event_serial):
* src/core/delete.c (release_window_with_fd, search_and_destroy_window):
sympathy changes for this, and consequent simplification.
Closes #499301.
svn path=/trunk/; revision=3663
2008-03-25 03:39:13 +00:00
|
|
|
* The display we're managing. This is a singleton object. (Historically,
|
|
|
|
* this was a list of displays, but there was never any way to add more
|
|
|
|
* than one element to it.) The goofy name is because we don't want it
|
|
|
|
* to shadow the parameter in its object methods.
|
|
|
|
*/
|
|
|
|
static MetaDisplay *the_display = NULL;
|
Screw around with Anders's ping patch so he'll get plenty of CVS
2002-02-26 Havoc Pennington <hp@pobox.com>
Screw around with Anders's ping patch so he'll get plenty of CVS
conflicts. ;-)
* src/display.c (meta_display_ping_window): spew warnings
if we try to call this with CurrentTime
(meta_display_ping_timeout): remove ping from the pending pings
after it times out.
* src/util.h: added PING debug category
* src/display.c (remove_pending_pings_for_window): don't remove
"tmp" just before "tmp->next", don't break out of loop after
finding the first match
(meta_display_open): no trailing comma in array init
(event_callback): move the processing of ping replies into a
separate function
* src/screen.c (set_supported_hint): add _NET_WM_PING to supported
list
* src/display.h: change gpointer to void*
2002-02-26 Anders Carlsson <andersca@gnu.org>
* src/display.c: (ping_data_free),
(remove_pending_pings_for_window), (meta_display_open),
(event_callback), (meta_display_unregister_x_window),
(meta_display_ping_timeout), (meta_display_ping_window),
(meta_display_window_has_pending_pings):
Implement meta_display_ping_window, and filter out scroll wheel
events.
* src/display.h:
Add MetaWindowPingFunc, meta_display_ping_window and
meta_display_window_has_pending_pings.
2002-02-27 02:05:39 +00:00
|
|
|
|
2017-08-26 16:37:29 +00:00
|
|
|
static void on_monitors_changed_internal (MetaMonitorManager *monitor_manager,
|
|
|
|
MetaDisplay *display);
|
|
|
|
|
2002-10-07 23:14:40 +00:00
|
|
|
static void prefs_changed_callback (MetaPreference pref,
|
|
|
|
void *data);
|
2014-04-24 14:48:47 +00:00
|
|
|
|
2014-09-29 22:01:17 +00:00
|
|
|
static int mru_cmp (gconstpointer a,
|
|
|
|
gconstpointer b);
|
|
|
|
|
2009-07-30 21:33:11 +00:00
|
|
|
static void
|
|
|
|
meta_display_get_property(GObject *object,
|
|
|
|
guint prop_id,
|
|
|
|
GValue *value,
|
|
|
|
GParamSpec *pspec)
|
|
|
|
{
|
|
|
|
MetaDisplay *display = META_DISPLAY (object);
|
|
|
|
|
|
|
|
switch (prop_id)
|
|
|
|
{
|
|
|
|
case PROP_FOCUS_WINDOW:
|
|
|
|
g_value_set_object (value, display->focus_window);
|
|
|
|
break;
|
2017-08-26 19:39:46 +00:00
|
|
|
case PROP_N_WORKSPACES:
|
|
|
|
g_value_set_int (value, meta_display_get_n_workspaces (display));
|
|
|
|
break;
|
2009-07-30 21:33:11 +00:00
|
|
|
default:
|
|
|
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
meta_display_set_property(GObject *object,
|
|
|
|
guint prop_id,
|
|
|
|
const GValue *value,
|
|
|
|
GParamSpec *pspec)
|
|
|
|
{
|
|
|
|
switch (prop_id)
|
|
|
|
{
|
|
|
|
default:
|
|
|
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-12-02 22:58:07 +00:00
|
|
|
static void
|
|
|
|
meta_display_class_init (MetaDisplayClass *klass)
|
|
|
|
{
|
2009-07-30 21:33:11 +00:00
|
|
|
GObjectClass *object_class = G_OBJECT_CLASS (klass);
|
|
|
|
|
|
|
|
object_class->get_property = meta_display_get_property;
|
|
|
|
object_class->set_property = meta_display_set_property;
|
|
|
|
|
2017-08-26 16:37:29 +00:00
|
|
|
display_signals[CURSOR_UPDATED] =
|
|
|
|
g_signal_new ("cursor-updated",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0,
|
|
|
|
NULL, NULL, NULL,
|
|
|
|
G_TYPE_NONE, 0);
|
|
|
|
|
2018-06-30 06:55:48 +00:00
|
|
|
display_signals[X11_DISPLAY_OPENED] =
|
|
|
|
g_signal_new ("x11-display-opened",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0,
|
|
|
|
NULL, NULL, NULL,
|
|
|
|
G_TYPE_NONE, 0);
|
|
|
|
|
|
|
|
display_signals[X11_DISPLAY_CLOSING] =
|
|
|
|
g_signal_new ("x11-display-closing",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0,
|
|
|
|
NULL, NULL, NULL,
|
|
|
|
G_TYPE_NONE, 0);
|
|
|
|
|
2008-12-02 23:13:11 +00:00
|
|
|
display_signals[OVERLAY_KEY] =
|
|
|
|
g_signal_new ("overlay-key",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0,
|
2011-10-18 22:06:14 +00:00
|
|
|
NULL, NULL, NULL,
|
2009-07-30 21:33:11 +00:00
|
|
|
G_TYPE_NONE, 0);
|
|
|
|
|
2012-08-28 13:28:11 +00:00
|
|
|
display_signals[ACCELERATOR_ACTIVATED] =
|
|
|
|
g_signal_new ("accelerator-activated",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0,
|
|
|
|
NULL, NULL, NULL,
|
2013-07-25 12:13:27 +00:00
|
|
|
G_TYPE_NONE, 3, G_TYPE_UINT, G_TYPE_UINT, G_TYPE_UINT);
|
2012-08-28 13:28:11 +00:00
|
|
|
|
2013-04-10 11:34:26 +00:00
|
|
|
/**
|
|
|
|
* MetaDisplay::modifiers-accelerator-activated:
|
|
|
|
* @display: the #MetaDisplay instance
|
|
|
|
*
|
|
|
|
* The ::modifiers-accelerator-activated signal will be emitted when
|
|
|
|
* a special modifiers-only keybinding is activated.
|
|
|
|
*
|
|
|
|
* Returns: %TRUE means that the keyboard device should remain
|
|
|
|
* frozen and %FALSE for the default behavior of unfreezing the
|
|
|
|
* keyboard.
|
|
|
|
*/
|
|
|
|
display_signals[MODIFIERS_ACCELERATOR_ACTIVATED] =
|
|
|
|
g_signal_new ("modifiers-accelerator-activated",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0,
|
|
|
|
g_signal_accumulator_first_wins, NULL, NULL,
|
|
|
|
G_TYPE_BOOLEAN, 0);
|
|
|
|
|
2009-10-13 14:34:34 +00:00
|
|
|
display_signals[WINDOW_CREATED] =
|
|
|
|
g_signal_new ("window-created",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0,
|
2011-10-18 22:06:14 +00:00
|
|
|
NULL, NULL, NULL,
|
2009-10-13 14:34:34 +00:00
|
|
|
G_TYPE_NONE, 1, META_TYPE_WINDOW);
|
|
|
|
|
2009-10-28 17:19:24 +00:00
|
|
|
display_signals[WINDOW_DEMANDS_ATTENTION] =
|
|
|
|
g_signal_new ("window-demands-attention",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0,
|
2011-10-18 22:06:14 +00:00
|
|
|
NULL, NULL, NULL,
|
2009-10-28 17:19:24 +00:00
|
|
|
G_TYPE_NONE, 1, META_TYPE_WINDOW);
|
2009-10-13 14:34:34 +00:00
|
|
|
|
2009-11-17 10:24:18 +00:00
|
|
|
display_signals[WINDOW_MARKED_URGENT] =
|
|
|
|
g_signal_new ("window-marked-urgent",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0,
|
2011-10-18 22:06:14 +00:00
|
|
|
NULL, NULL, NULL,
|
2009-11-17 10:24:18 +00:00
|
|
|
G_TYPE_NONE, 1,
|
|
|
|
META_TYPE_WINDOW);
|
|
|
|
|
2012-02-10 15:27:14 +00:00
|
|
|
display_signals[GRAB_OP_BEGIN] =
|
|
|
|
g_signal_new ("grab-op-begin",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0,
|
|
|
|
NULL, NULL, NULL,
|
|
|
|
G_TYPE_NONE, 3,
|
2017-08-26 19:43:17 +00:00
|
|
|
META_TYPE_DISPLAY,
|
2012-02-10 15:27:14 +00:00
|
|
|
META_TYPE_WINDOW,
|
|
|
|
META_TYPE_GRAB_OP);
|
|
|
|
|
|
|
|
display_signals[GRAB_OP_END] =
|
|
|
|
g_signal_new ("grab-op-end",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0,
|
|
|
|
NULL, NULL, NULL,
|
|
|
|
G_TYPE_NONE, 3,
|
2017-08-26 19:43:17 +00:00
|
|
|
META_TYPE_DISPLAY,
|
2012-02-10 15:27:14 +00:00
|
|
|
META_TYPE_WINDOW,
|
|
|
|
META_TYPE_GRAB_OP);
|
|
|
|
|
2014-05-08 22:35:49 +00:00
|
|
|
/**
|
|
|
|
* MetaDisplay::show-restart-message:
|
|
|
|
* @display: the #MetaDisplay instance
|
|
|
|
* @message: (allow-none): The message to display, or %NULL
|
|
|
|
* to clear a previous restart message.
|
|
|
|
*
|
|
|
|
* The ::show-restart-message signal will be emitted to indicate
|
|
|
|
* that the compositor should show a message during restart. This is
|
|
|
|
* emitted when meta_restart() is called, either by Mutter
|
|
|
|
* internally or by the embedding compositor. The message should be
|
|
|
|
* immediately added to the Clutter stage in its final form -
|
|
|
|
* ::restart will be emitted to exit the application and leave the
|
|
|
|
* stage contents frozen as soon as the the stage is painted again.
|
|
|
|
*
|
|
|
|
* On case of failure to restart, this signal will be emitted again
|
|
|
|
* with %NULL for @message.
|
|
|
|
*
|
|
|
|
* Returns: %TRUE means the message was added to the stage; %FALSE
|
|
|
|
* indicates that the compositor did not show the message.
|
|
|
|
*/
|
|
|
|
display_signals[SHOW_RESTART_MESSAGE] =
|
|
|
|
g_signal_new ("show-restart-message",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0,
|
|
|
|
g_signal_accumulator_true_handled,
|
|
|
|
NULL, NULL,
|
|
|
|
G_TYPE_BOOLEAN, 1,
|
|
|
|
G_TYPE_STRING);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* MetaDisplay::restart:
|
|
|
|
* @display: the #MetaDisplay instance
|
|
|
|
*
|
|
|
|
* The ::restart signal is emitted to indicate that compositor
|
|
|
|
* should reexec the process. This is
|
|
|
|
* emitted when meta_restart() is called, either by Mutter
|
|
|
|
* internally or by the embedding compositor. See also
|
|
|
|
* ::show-restart-message.
|
|
|
|
*
|
|
|
|
* Returns: %FALSE to indicate that the compositor could not
|
|
|
|
* be restarted. When the compositor is restarted, the signal
|
|
|
|
* should not return.
|
|
|
|
*/
|
|
|
|
display_signals[RESTART] =
|
|
|
|
g_signal_new ("restart",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0,
|
|
|
|
g_signal_accumulator_true_handled,
|
|
|
|
NULL, NULL,
|
|
|
|
G_TYPE_BOOLEAN, 0);
|
|
|
|
|
2014-12-30 01:20:07 +00:00
|
|
|
display_signals[SHOW_RESIZE_POPUP] =
|
|
|
|
g_signal_new ("show-resize-popup",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0,
|
|
|
|
g_signal_accumulator_true_handled,
|
|
|
|
NULL, NULL,
|
|
|
|
G_TYPE_BOOLEAN, 4,
|
|
|
|
G_TYPE_BOOLEAN, META_TYPE_RECTANGLE, G_TYPE_INT, G_TYPE_INT);
|
|
|
|
|
2016-05-20 17:22:23 +00:00
|
|
|
display_signals[GL_VIDEO_MEMORY_PURGED] =
|
|
|
|
g_signal_new ("gl-video-memory-purged",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0,
|
|
|
|
NULL, NULL, NULL,
|
|
|
|
G_TYPE_NONE, 0);
|
|
|
|
|
2016-06-22 17:14:35 +00:00
|
|
|
/**
|
|
|
|
* MetaDisplay::show-pad-osd:
|
|
|
|
* @display: the #MetaDisplay instance
|
|
|
|
* @pad: the pad device
|
|
|
|
* @settings: the pad device settings
|
2016-06-22 17:17:40 +00:00
|
|
|
* @layout_path: path to the layout image
|
2016-06-22 17:14:35 +00:00
|
|
|
* @edition_mode: Whether the OSD should be shown in edition mode
|
2016-06-22 17:17:40 +00:00
|
|
|
* @monitor_idx: Monitor to show the OSD on
|
2016-06-22 17:14:35 +00:00
|
|
|
*
|
|
|
|
* Requests the pad button mapping OSD to be shown.
|
|
|
|
*
|
|
|
|
* Returns: (transfer none) (nullable): The OSD actor
|
|
|
|
*/
|
|
|
|
display_signals[SHOW_PAD_OSD] =
|
|
|
|
g_signal_new ("show-pad-osd",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0, NULL, NULL, NULL,
|
2016-06-22 17:17:40 +00:00
|
|
|
CLUTTER_TYPE_ACTOR, 5, CLUTTER_TYPE_INPUT_DEVICE,
|
|
|
|
G_TYPE_SETTINGS, G_TYPE_STRING, G_TYPE_BOOLEAN, G_TYPE_INT);
|
2016-06-22 17:14:35 +00:00
|
|
|
|
2016-12-28 11:03:29 +00:00
|
|
|
display_signals[SHOW_OSD] =
|
|
|
|
g_signal_new ("show-osd",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0, NULL, NULL, NULL,
|
|
|
|
G_TYPE_NONE, 3, G_TYPE_INT, G_TYPE_STRING, G_TYPE_STRING);
|
|
|
|
|
2016-12-28 12:00:18 +00:00
|
|
|
display_signals[PAD_MODE_SWITCH] =
|
|
|
|
g_signal_new ("pad-mode-switch",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0, NULL, NULL, NULL,
|
|
|
|
G_TYPE_NONE, 3, CLUTTER_TYPE_INPUT_DEVICE,
|
|
|
|
G_TYPE_UINT, G_TYPE_UINT);
|
|
|
|
|
2017-08-26 19:10:38 +00:00
|
|
|
display_signals[WINDOW_ENTERED_MONITOR] =
|
|
|
|
g_signal_new ("window-entered-monitor",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0, NULL, NULL, NULL,
|
|
|
|
G_TYPE_NONE, 2,
|
|
|
|
G_TYPE_INT,
|
|
|
|
META_TYPE_WINDOW);
|
|
|
|
|
|
|
|
display_signals[WINDOW_LEFT_MONITOR] =
|
|
|
|
g_signal_new ("window-left-monitor",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0, NULL, NULL, NULL,
|
|
|
|
G_TYPE_NONE, 2,
|
|
|
|
G_TYPE_INT,
|
|
|
|
META_TYPE_WINDOW);
|
|
|
|
|
2017-08-26 19:39:46 +00:00
|
|
|
display_signals[WORKSPACE_ADDED] =
|
|
|
|
g_signal_new ("workspace-added",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0,
|
|
|
|
NULL, NULL, NULL,
|
|
|
|
G_TYPE_NONE,
|
|
|
|
1,
|
|
|
|
G_TYPE_INT);
|
|
|
|
|
|
|
|
display_signals[WORKSPACE_REMOVED] =
|
|
|
|
g_signal_new ("workspace-removed",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0,
|
|
|
|
NULL, NULL, NULL,
|
|
|
|
G_TYPE_NONE,
|
|
|
|
1,
|
|
|
|
G_TYPE_INT);
|
|
|
|
|
|
|
|
display_signals[WORKSPACE_SWITCHED] =
|
|
|
|
g_signal_new ("workspace-switched",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0,
|
|
|
|
NULL, NULL, NULL,
|
|
|
|
G_TYPE_NONE,
|
|
|
|
3,
|
|
|
|
G_TYPE_INT,
|
|
|
|
G_TYPE_INT,
|
|
|
|
META_TYPE_MOTION_DIRECTION);
|
|
|
|
|
2017-08-26 20:29:10 +00:00
|
|
|
display_signals[ACTIVE_WORKSPACE_CHANGED] =
|
|
|
|
g_signal_new ("active-workspace-changed",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0,
|
|
|
|
NULL, NULL, NULL,
|
|
|
|
G_TYPE_NONE, 0);
|
|
|
|
|
2017-08-26 19:10:38 +00:00
|
|
|
display_signals[IN_FULLSCREEN_CHANGED] =
|
|
|
|
g_signal_new ("in-fullscreen-changed",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0, NULL, NULL, NULL,
|
|
|
|
G_TYPE_NONE, 0);
|
|
|
|
|
2017-08-26 20:29:10 +00:00
|
|
|
display_signals[SHOWING_DESKTOP_CHANGED] =
|
|
|
|
g_signal_new ("showing-desktop-changed",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0,
|
|
|
|
NULL, NULL, NULL,
|
|
|
|
G_TYPE_NONE, 0);
|
|
|
|
|
2017-08-26 19:10:38 +00:00
|
|
|
display_signals[STARTUP_SEQUENCE_CHANGED] =
|
|
|
|
g_signal_new ("startup-sequence-changed",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0, NULL, NULL, NULL,
|
|
|
|
G_TYPE_NONE, 1, G_TYPE_POINTER);
|
|
|
|
|
2017-08-26 17:03:51 +00:00
|
|
|
display_signals[RESTACKED] =
|
|
|
|
g_signal_new ("restacked",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0, NULL, NULL, NULL,
|
|
|
|
G_TYPE_NONE, 0);
|
|
|
|
|
2017-08-26 19:10:38 +00:00
|
|
|
display_signals[WORKAREAS_CHANGED] =
|
|
|
|
g_signal_new ("workareas-changed",
|
|
|
|
G_TYPE_FROM_CLASS (klass),
|
|
|
|
G_SIGNAL_RUN_LAST,
|
|
|
|
0, NULL, NULL, NULL,
|
|
|
|
G_TYPE_NONE, 0);
|
|
|
|
|
2009-07-30 21:33:11 +00:00
|
|
|
g_object_class_install_property (object_class,
|
|
|
|
PROP_FOCUS_WINDOW,
|
|
|
|
g_param_spec_object ("focus-window",
|
|
|
|
"Focus window",
|
|
|
|
"Currently focused window",
|
|
|
|
META_TYPE_WINDOW,
|
|
|
|
G_PARAM_READABLE));
|
2017-08-26 19:39:46 +00:00
|
|
|
|
|
|
|
g_object_class_install_property (object_class,
|
|
|
|
PROP_N_WORKSPACES,
|
|
|
|
g_param_spec_int ("n-workspaces",
|
|
|
|
"N Workspaces",
|
|
|
|
"Number of workspaces",
|
|
|
|
1, G_MAXINT, 1,
|
|
|
|
G_PARAM_READABLE));
|
|
|
|
|
2008-12-02 22:58:07 +00:00
|
|
|
}
|
|
|
|
|
2014-02-15 16:33:12 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* ping_data_free:
|
|
|
|
*
|
|
|
|
* Destructor for #MetaPingData structs. Will destroy the
|
|
|
|
* event source for the struct as well.
|
|
|
|
*/
|
|
|
|
static void
|
|
|
|
ping_data_free (MetaPingData *ping_data)
|
|
|
|
{
|
|
|
|
/* Remove the timeout */
|
|
|
|
if (ping_data->ping_timeout_id != 0)
|
|
|
|
g_source_remove (ping_data->ping_timeout_id);
|
|
|
|
|
|
|
|
g_free (ping_data);
|
|
|
|
}
|
|
|
|
|
2014-07-08 16:16:11 +00:00
|
|
|
void
|
|
|
|
meta_display_remove_pending_pings_for_window (MetaDisplay *display,
|
|
|
|
MetaWindow *window)
|
2014-02-15 16:33:12 +00:00
|
|
|
{
|
|
|
|
GSList *tmp;
|
|
|
|
GSList *dead;
|
|
|
|
|
|
|
|
/* could obviously be more efficient, don't care */
|
|
|
|
|
|
|
|
/* build list to be removed */
|
|
|
|
dead = NULL;
|
|
|
|
for (tmp = display->pending_pings; tmp; tmp = tmp->next)
|
|
|
|
{
|
|
|
|
MetaPingData *ping_data = tmp->data;
|
|
|
|
|
2014-07-08 16:16:11 +00:00
|
|
|
if (ping_data->window == window)
|
2014-02-15 16:33:12 +00:00
|
|
|
dead = g_slist_prepend (dead, ping_data);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* remove what we found */
|
|
|
|
for (tmp = dead; tmp; tmp = tmp->next)
|
|
|
|
{
|
|
|
|
MetaPingData *ping_data = tmp->data;
|
|
|
|
|
|
|
|
display->pending_pings = g_slist_remove (display->pending_pings, ping_data);
|
|
|
|
ping_data_free (ping_data);
|
|
|
|
}
|
|
|
|
|
|
|
|
g_slist_free (dead);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2006-02-16 20:26:05 +00:00
|
|
|
static void
|
2013-02-07 11:48:12 +00:00
|
|
|
enable_compositor (MetaDisplay *display)
|
2006-02-16 20:26:05 +00:00
|
|
|
{
|
2017-08-26 16:28:53 +00:00
|
|
|
MetaX11Display *x11_display = display->x11_display;
|
|
|
|
|
2017-08-26 20:24:21 +00:00
|
|
|
if (x11_display)
|
Merge compositor branch.
2007-12-18 Iain Holmes <iain@gnome.org>
* configure.in, src/theme.c, src/display.c,
src/theme.h, src/display.h, src/theme-parser.c,
src/compositor.c, src/c-screen.c, src/compositor.h,
src/c-screen.h, src/ui.c, src/screen.c, src/ui.h,
src/screen.h, src/c-window.c, src/c-window.h,
src/theme-viewer.c, src/Makefile.am: Merge compositor branch.
svn path=/trunk/; revision=3483
2007-12-19 03:49:50 +00:00
|
|
|
{
|
2017-08-26 20:24:21 +00:00
|
|
|
if (!META_X11_DISPLAY_HAS_COMPOSITE (x11_display) ||
|
|
|
|
!META_X11_DISPLAY_HAS_DAMAGE (x11_display))
|
|
|
|
{
|
|
|
|
meta_warning ("Missing %s extension required for compositing",
|
|
|
|
!META_X11_DISPLAY_HAS_COMPOSITE (x11_display) ?
|
|
|
|
"composite" : "damage");
|
|
|
|
return;
|
|
|
|
}
|
Merge compositor branch.
2007-12-18 Iain Holmes <iain@gnome.org>
* configure.in, src/theme.c, src/display.c,
src/theme.h, src/display.h, src/theme-parser.c,
src/compositor.c, src/c-screen.c, src/compositor.h,
src/c-screen.h, src/ui.c, src/screen.c, src/ui.h,
src/screen.h, src/c-window.c, src/c-window.h,
src/theme-viewer.c, src/Makefile.am: Merge compositor branch.
svn path=/trunk/; revision=3483
2007-12-19 03:49:50 +00:00
|
|
|
|
2017-08-26 20:24:21 +00:00
|
|
|
int version = (x11_display->composite_major_version * 10) +
|
|
|
|
x11_display->composite_minor_version;
|
|
|
|
if (version < 3)
|
|
|
|
{
|
|
|
|
meta_warning ("Your version of COMPOSITE is too old.");
|
|
|
|
return;
|
|
|
|
}
|
2014-08-13 23:32:39 +00:00
|
|
|
}
|
2006-02-16 20:26:05 +00:00
|
|
|
|
|
|
|
if (!display->compositor)
|
2014-08-13 23:32:39 +00:00
|
|
|
display->compositor = meta_compositor_new (display);
|
2013-10-03 22:31:09 +00:00
|
|
|
|
2014-03-18 21:31:22 +00:00
|
|
|
meta_compositor_manage (display->compositor);
|
2006-02-16 20:26:05 +00:00
|
|
|
}
|
|
|
|
|
2008-12-02 22:58:07 +00:00
|
|
|
static void
|
|
|
|
meta_display_init (MetaDisplay *disp)
|
|
|
|
{
|
|
|
|
/* Some stuff could go in here that's currently in _open,
|
|
|
|
* but it doesn't really matter. */
|
|
|
|
}
|
|
|
|
|
2014-07-22 00:07:19 +00:00
|
|
|
void
|
2014-07-22 00:07:19 +00:00
|
|
|
meta_display_cancel_touch (MetaDisplay *display)
|
|
|
|
{
|
2014-08-14 00:19:35 +00:00
|
|
|
#ifdef HAVE_WAYLAND
|
2014-07-22 00:07:19 +00:00
|
|
|
MetaWaylandCompositor *compositor;
|
|
|
|
|
|
|
|
if (!meta_is_wayland_compositor ())
|
|
|
|
return;
|
|
|
|
|
|
|
|
compositor = meta_wayland_compositor_get_default ();
|
2016-04-01 08:39:30 +00:00
|
|
|
meta_wayland_touch_cancel (compositor->seat->touch);
|
2014-08-14 00:19:35 +00:00
|
|
|
#endif
|
2014-07-22 00:07:19 +00:00
|
|
|
}
|
|
|
|
|
2014-06-19 21:13:38 +00:00
|
|
|
static void
|
|
|
|
gesture_tracker_state_changed (MetaGestureTracker *tracker,
|
|
|
|
ClutterEventSequence *sequence,
|
|
|
|
MetaSequenceState state,
|
|
|
|
MetaDisplay *display)
|
|
|
|
{
|
2014-07-21 23:46:42 +00:00
|
|
|
if (meta_is_wayland_compositor ())
|
|
|
|
{
|
|
|
|
if (state == META_SEQUENCE_ACCEPTED)
|
|
|
|
meta_display_cancel_touch (display);
|
|
|
|
}
|
2014-06-19 21:13:38 +00:00
|
|
|
else
|
2014-07-21 23:46:42 +00:00
|
|
|
{
|
|
|
|
MetaBackendX11 *backend = META_BACKEND_X11 (meta_get_backend ());
|
|
|
|
int event_mode;
|
|
|
|
|
|
|
|
if (state == META_SEQUENCE_ACCEPTED)
|
|
|
|
event_mode = XIAcceptTouch;
|
|
|
|
else if (state == META_SEQUENCE_REJECTED)
|
|
|
|
event_mode = XIRejectTouch;
|
|
|
|
else
|
|
|
|
return;
|
|
|
|
|
|
|
|
XIAllowTouchEvents (meta_backend_x11_get_xdisplay (backend),
|
|
|
|
META_VIRTUAL_CORE_POINTER_ID,
|
|
|
|
clutter_x11_event_sequence_get_touch_detail (sequence),
|
2017-08-26 16:26:30 +00:00
|
|
|
DefaultRootWindow (display->x11_display->xdisplay), event_mode);
|
2014-07-21 23:46:42 +00:00
|
|
|
}
|
2014-06-19 21:13:38 +00:00
|
|
|
}
|
|
|
|
|
2016-02-06 13:52:03 +00:00
|
|
|
static void
|
|
|
|
on_startup_notification_changed (MetaStartupNotification *sn,
|
|
|
|
gpointer sequence,
|
|
|
|
MetaDisplay *display)
|
|
|
|
{
|
2017-08-26 19:10:38 +00:00
|
|
|
g_slist_free (display->startup_sequences);
|
|
|
|
display->startup_sequences =
|
2016-02-06 13:52:03 +00:00
|
|
|
meta_startup_notification_get_sequences (display->startup_notification);
|
2017-08-26 19:10:38 +00:00
|
|
|
g_signal_emit_by_name (display, "startup-sequence-changed", sequence);
|
2016-02-06 13:52:03 +00:00
|
|
|
}
|
|
|
|
|
2017-08-26 19:39:46 +00:00
|
|
|
static void
|
|
|
|
reload_logical_monitors (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
GList *l;
|
|
|
|
|
|
|
|
for (l = display->workspaces; l != NULL; l = l->next)
|
|
|
|
{
|
|
|
|
MetaWorkspace *space = l->data;
|
|
|
|
meta_workspace_invalidate_work_area (space);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-01-13 01:01:21 +00:00
|
|
|
/**
|
2011-11-02 15:34:45 +00:00
|
|
|
* meta_display_open:
|
|
|
|
*
|
2008-01-13 01:01:21 +00:00
|
|
|
* Opens a new display, sets it up, initialises all the X extensions
|
2008-01-08 03:59:12 +00:00
|
|
|
* we will need, and adds it to the list of displays.
|
|
|
|
*
|
2011-11-02 15:34:45 +00:00
|
|
|
* Returns: %TRUE if the display was opened successfully, and %FALSE
|
2008-01-08 03:59:12 +00:00
|
|
|
* otherwise-- that is, if the display doesn't exist or it already
|
|
|
|
* has a window manager.
|
|
|
|
*/
|
2001-05-30 15:36:31 +00:00
|
|
|
gboolean
|
2006-05-04 17:32:26 +00:00
|
|
|
meta_display_open (void)
|
2001-05-30 15:36:31 +00:00
|
|
|
{
|
2017-08-26 16:24:46 +00:00
|
|
|
GError *error = NULL;
|
2014-07-10 21:58:58 +00:00
|
|
|
MetaDisplay *display;
|
2017-08-26 16:24:46 +00:00
|
|
|
MetaX11Display *x11_display;
|
2002-03-02 15:26:07 +00:00
|
|
|
int i;
|
Fix issues on 64-bit machines with timestamps by using guint32 (like gtk+
2006-09-13 Elijah Newren <newren gmail com>
* src/common.h (MetaWindowMenuFunc):
* src/core.[ch] (meta_core_user_lower_and_unfocus,
meta_core_user_focus, meta_core_show_window_menu,
meta_core_begin_grab_op, meta_core_end_grab_op):
* src/delete.c (delete_ping_reply_func, delete_ping_timeout_func,
meta_window_delete):
* src/display.[ch] (struct MetaDisplay, struct MetaPingData,
sanity_check_timestamps, meta_display_open, event_callback,
meta_spew_event, meta_display_set_grab_op_cursor,
meta_display_begin_grab_op, meta_display_end_grab_op,
meta_display_ping_timeout, meta_display_ping_window,
process_pong_message, timestamp_too_old,
meta_display_set_input_focus_window):
* src/keybindings.[ch] (grab_keyboard, ungrab_keyboard,
meta_screen_grab_all_keys, meta_window_grab_all_keys,
meta_window_ungrab_all_keys, error_on_generic_command,
error_on_command, error_on_terminal_command):
* src/metacity-dialog.c (on_realize, warn_about_no_sm_support,
error_about_command, main):
* src/screen.[ch] (struct _MetaScreen, meta_screen_new,
meta_screen_show_desktop, meta_screen_apply_startup_properties):
* src/session.c (warn_about_lame_clients_and_finish_interact):
* src/window.[ch] (struct _MetaWindow,
intervening_user_event_occurred, window_activate,
meta_window_delete, meta_window_focus,
meta_window_send_icccm_message, meta_window_client_message,
menu_callback, meta_window_show_menu, struct EventScannerData,
check_use_this_motion_notify, meta_window_begin_grab_op,
meta_window_set_user_time):
* src/workspace.[ch] (focus_ancestor_or_mru_window,
meta_workspace_activate_with_focus, meta_workspace_activate,
meta_workspace_focus_default_window,
focus_ancestor_or_mru_window):
Fix issues on 64-bit machines with timestamps by using guint32
(like gtk+ does) instead of Time. #348305
2006-09-13 16:32:33 +00:00
|
|
|
guint32 timestamp;
|
2016-05-10 21:36:51 +00:00
|
|
|
Window old_active_xwindow = None;
|
2017-08-26 16:37:29 +00:00
|
|
|
MetaBackend *backend = meta_get_backend ();
|
|
|
|
MetaMonitorManager *monitor_manager;
|
2008-05-02 18:49:01 +00:00
|
|
|
|
MetaDisplay becomes a singleton. The static variable which holds this
2008-03-25 Thomas Thurman <tthurman@gnome.org>
* src/core/display.c (meta_display_queue_retheme_all_windows,
meta_set_syncing, meta_display_set_cursor_theme, disable_compositor,
meta_display_for_x_display, meta_display_open, meta_display_close,
meta_display_ungrab): MetaDisplay becomes a singleton. The static
variable which holds this singleton is renamed "the_display" so as
not to mask the this parameter in the methods.
* src/core/main.c (main):
* src/core/session.c (warn_about_lame_clients_and_finish_inte,
save_state, io_from_warning_dialog):
* src/core/core.c (meta_core_increment_event_serial):
* src/core/delete.c (release_window_with_fd, search_and_destroy_window):
sympathy changes for this, and consequent simplification.
Closes #499301.
svn path=/trunk/; revision=3663
2008-03-25 03:39:13 +00:00
|
|
|
g_assert (the_display == NULL);
|
2014-07-10 21:58:58 +00:00
|
|
|
display = the_display = g_object_new (META_TYPE_DISPLAY, NULL);
|
2001-06-03 01:33:27 +00:00
|
|
|
|
2014-07-10 21:58:58 +00:00
|
|
|
display->closing = 0;
|
|
|
|
display->display_opening = TRUE;
|
|
|
|
|
|
|
|
display->pending_pings = NULL;
|
|
|
|
display->autoraise_timeout_id = 0;
|
|
|
|
display->autoraise_window = NULL;
|
|
|
|
display->focus_window = NULL;
|
2017-08-26 16:24:46 +00:00
|
|
|
display->x11_display = NULL;
|
2014-07-10 21:58:58 +00:00
|
|
|
|
2017-08-26 16:37:29 +00:00
|
|
|
display->current_cursor = -1; /* invalid/unset */
|
2017-08-26 19:10:38 +00:00
|
|
|
display->tile_preview_timeout_id = 0;
|
|
|
|
display->check_fullscreen_later = 0;
|
|
|
|
display->work_area_later = 0;
|
2017-08-26 16:37:29 +00:00
|
|
|
|
2014-07-10 21:58:58 +00:00
|
|
|
display->mouse_mode = TRUE; /* Only relevant for mouse or sloppy focus */
|
|
|
|
display->allow_terminal_deactivation = TRUE; /* Only relevant for when a
|
2006-01-15 17:03:57 +00:00
|
|
|
terminal has the focus */
|
2014-05-02 13:34:02 +00:00
|
|
|
|
2017-08-26 16:24:46 +00:00
|
|
|
i = 0;
|
|
|
|
while (i < N_IGNORED_CROSSING_SERIALS)
|
|
|
|
{
|
|
|
|
display->ignored_crossing_serials[i] = 0;
|
|
|
|
++i;
|
|
|
|
}
|
|
|
|
|
2017-08-26 20:24:21 +00:00
|
|
|
display->current_time = META_CURRENT_TIME;
|
2017-08-26 16:24:46 +00:00
|
|
|
display->sentinel_counter = 0;
|
|
|
|
|
|
|
|
display->grab_resize_timeout_id = 0;
|
|
|
|
display->grab_have_keyboard = FALSE;
|
|
|
|
|
|
|
|
display->grab_op = META_GRAB_OP_NONE;
|
|
|
|
display->grab_window = NULL;
|
|
|
|
display->grab_tile_mode = META_TILE_NONE;
|
|
|
|
display->grab_tile_monitor_number = -1;
|
|
|
|
|
2017-08-26 19:39:46 +00:00
|
|
|
display->active_workspace = NULL;
|
|
|
|
display->workspaces = NULL;
|
|
|
|
display->rows_of_workspaces = 1;
|
|
|
|
display->columns_of_workspaces = -1;
|
|
|
|
display->vertical_workspaces = FALSE;
|
|
|
|
display->starting_corner = META_DISPLAY_TOPLEFT;
|
|
|
|
|
2017-08-26 16:24:46 +00:00
|
|
|
display->grab_edge_resistance_data = NULL;
|
2003-01-28 15:07:43 +00:00
|
|
|
|
2014-07-10 21:58:58 +00:00
|
|
|
meta_display_init_keys (display);
|
2001-06-09 05:14:43 +00:00
|
|
|
|
2014-07-10 21:58:58 +00:00
|
|
|
meta_prefs_add_listener (prefs_changed_callback, display);
|
Merge compositor branch.
2007-12-18 Iain Holmes <iain@gnome.org>
* configure.in, src/theme.c, src/display.c,
src/theme.h, src/display.h, src/theme-parser.c,
src/compositor.c, src/c-screen.c, src/compositor.h,
src/c-screen.h, src/ui.c, src/screen.c, src/ui.h,
src/screen.h, src/c-window.c, src/c-window.h,
src/theme-viewer.c, src/Makefile.am: Merge compositor branch.
svn path=/trunk/; revision=3483
2007-12-19 03:49:50 +00:00
|
|
|
|
2017-08-26 16:24:46 +00:00
|
|
|
/* Get events */
|
|
|
|
meta_display_init_events (display);
|
|
|
|
|
|
|
|
display->stamps = g_hash_table_new (g_int64_hash,
|
|
|
|
g_int64_equal);
|
|
|
|
display->wayland_windows = g_hash_table_new (NULL, NULL);
|
|
|
|
|
2017-08-26 16:37:29 +00:00
|
|
|
monitor_manager = meta_backend_get_monitor_manager (backend);
|
|
|
|
g_signal_connect (monitor_manager, "monitors-changed-internal",
|
|
|
|
G_CALLBACK (on_monitors_changed_internal), display);
|
|
|
|
|
|
|
|
meta_display_set_cursor (display, META_CURSOR_DEFAULT);
|
|
|
|
|
2017-08-26 20:43:28 +00:00
|
|
|
display->stack = meta_stack_new (display);
|
|
|
|
display->stack_tracker = meta_stack_tracker_new (display);
|
|
|
|
|
2017-08-26 20:29:10 +00:00
|
|
|
/* This is the default layout extracted from default
|
|
|
|
* variable values in update_num_workspaces ()
|
|
|
|
* This can be overriden using _NET_DESKTOP_LAYOUT in
|
|
|
|
* meta_x11_display_new (), if it's specified */
|
|
|
|
meta_display_update_workspace_layout (display,
|
|
|
|
META_DISPLAY_TOPLEFT,
|
|
|
|
FALSE,
|
|
|
|
-1,
|
|
|
|
1);
|
|
|
|
|
|
|
|
/* There must be at least one workspace at all times,
|
|
|
|
* so create that required workspace.
|
|
|
|
*/
|
|
|
|
meta_workspace_new (display);
|
|
|
|
|
|
|
|
meta_display_init_workspaces (display);
|
|
|
|
|
|
|
|
reload_logical_monitors (display);
|
|
|
|
|
2017-08-26 20:35:18 +00:00
|
|
|
display->startup_notification = meta_startup_notification_get (display);
|
|
|
|
g_signal_connect (display->startup_notification, "changed",
|
|
|
|
G_CALLBACK (on_startup_notification_changed), display);
|
|
|
|
|
|
|
|
display->bell = meta_bell_new (display);
|
|
|
|
|
2017-08-27 18:44:58 +00:00
|
|
|
if (meta_should_autostart_x11_display ())
|
|
|
|
{
|
|
|
|
x11_display = meta_x11_display_new (display, &error);
|
|
|
|
g_assert (x11_display != NULL); /* Required, for now */
|
|
|
|
display->x11_display = x11_display;
|
|
|
|
g_signal_emit (display, display_signals[X11_DISPLAY_OPENED], 0);
|
2017-08-26 16:24:46 +00:00
|
|
|
|
2017-08-27 18:44:58 +00:00
|
|
|
timestamp = display->x11_display->timestamp;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
timestamp = meta_display_get_current_time_roundtrip (display);
|
|
|
|
}
|
2017-08-26 16:24:46 +00:00
|
|
|
|
2014-07-10 21:58:58 +00:00
|
|
|
display->last_focus_time = timestamp;
|
|
|
|
display->last_user_time = timestamp;
|
|
|
|
display->compositor = NULL;
|
2013-10-03 22:31:09 +00:00
|
|
|
|
2016-05-10 21:36:51 +00:00
|
|
|
if (!meta_is_wayland_compositor ())
|
2017-08-26 18:51:28 +00:00
|
|
|
meta_prop_get_window (display->x11_display,
|
|
|
|
display->x11_display->xroot,
|
2017-08-26 16:26:30 +00:00
|
|
|
display->x11_display->atom__NET_ACTIVE_WINDOW,
|
2016-05-10 21:36:51 +00:00
|
|
|
&old_active_xwindow);
|
|
|
|
|
2014-07-10 21:58:58 +00:00
|
|
|
enable_compositor (display);
|
2006-01-13 19:41:01 +00:00
|
|
|
|
2017-08-26 20:24:21 +00:00
|
|
|
if (display->x11_display)
|
|
|
|
meta_x11_display_create_guard_window (display->x11_display);
|
2014-02-08 00:52:34 +00:00
|
|
|
|
2014-06-19 20:28:48 +00:00
|
|
|
/* Set up touch support */
|
2014-07-10 21:58:58 +00:00
|
|
|
display->gesture_tracker = meta_gesture_tracker_new ();
|
|
|
|
g_signal_connect (display->gesture_tracker, "state-changed",
|
|
|
|
G_CALLBACK (gesture_tracker_state_changed), display);
|
2014-06-19 20:28:48 +00:00
|
|
|
|
2014-02-08 00:52:34 +00:00
|
|
|
/* We know that if mutter is running as a Wayland compositor,
|
|
|
|
* we start out with no windows.
|
|
|
|
*/
|
|
|
|
if (!meta_is_wayland_compositor ())
|
2017-08-26 17:03:51 +00:00
|
|
|
meta_display_manage_all_windows (display);
|
2002-07-24 15:41:44 +00:00
|
|
|
|
2016-05-10 21:36:51 +00:00
|
|
|
if (old_active_xwindow != None)
|
|
|
|
{
|
2017-08-26 16:56:44 +00:00
|
|
|
MetaWindow *old_active_window;
|
|
|
|
old_active_window = meta_x11_display_lookup_x_window (display->x11_display,
|
|
|
|
old_active_xwindow);
|
2016-05-10 21:36:51 +00:00
|
|
|
if (old_active_window)
|
|
|
|
meta_window_focus (old_active_window, timestamp);
|
|
|
|
else
|
2017-08-26 18:51:28 +00:00
|
|
|
meta_x11_display_focus_the_no_focus_window (display->x11_display, timestamp);
|
2016-05-10 21:36:51 +00:00
|
|
|
}
|
2017-08-26 20:24:21 +00:00
|
|
|
else if (display->x11_display)
|
2017-08-26 18:51:28 +00:00
|
|
|
meta_x11_display_focus_the_no_focus_window (display->x11_display, timestamp);
|
2013-08-14 11:51:05 +00:00
|
|
|
|
|
|
|
meta_idle_monitor_init_dbus ();
|
|
|
|
|
2006-10-01 21:59:09 +00:00
|
|
|
/* Done opening new display */
|
2014-07-10 21:58:58 +00:00
|
|
|
display->display_opening = FALSE;
|
2006-10-01 21:59:09 +00:00
|
|
|
|
2001-05-30 15:36:31 +00:00
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2001-06-03 18:33:59 +00:00
|
|
|
static gint
|
|
|
|
ptrcmp (gconstpointer a, gconstpointer b)
|
|
|
|
{
|
|
|
|
if (a < b)
|
|
|
|
return -1;
|
|
|
|
else if (a > b)
|
|
|
|
return 1;
|
|
|
|
else
|
|
|
|
return 0;
|
2001-05-30 15:36:31 +00:00
|
|
|
}
|
|
|
|
|
2009-06-15 19:32:23 +00:00
|
|
|
/**
|
|
|
|
* meta_display_list_windows:
|
|
|
|
* @display: a #MetaDisplay
|
|
|
|
* @flags: options for listing
|
|
|
|
*
|
|
|
|
* Lists windows for the display, the @flags parameter for
|
|
|
|
* now determines whether override-redirect windows will be
|
|
|
|
* included.
|
|
|
|
*
|
|
|
|
* Return value: (transfer container): the list of windows.
|
|
|
|
*/
|
2001-06-24 08:09:10 +00:00
|
|
|
GSList*
|
2009-06-15 19:32:23 +00:00
|
|
|
meta_display_list_windows (MetaDisplay *display,
|
|
|
|
MetaListWindowsFlags flags)
|
2001-05-30 15:36:31 +00:00
|
|
|
{
|
2001-06-03 18:33:59 +00:00
|
|
|
GSList *winlist;
|
2001-06-24 08:09:10 +00:00
|
|
|
GSList *prev;
|
2013-10-03 22:31:09 +00:00
|
|
|
GSList *tmp;
|
2009-06-15 19:32:23 +00:00
|
|
|
GHashTableIter iter;
|
|
|
|
gpointer key, value;
|
|
|
|
|
2001-06-03 18:33:59 +00:00
|
|
|
winlist = NULL;
|
2009-06-15 19:32:23 +00:00
|
|
|
|
2017-08-26 16:56:44 +00:00
|
|
|
if (display->x11_display)
|
2009-06-15 19:32:23 +00:00
|
|
|
{
|
2017-08-26 16:56:44 +00:00
|
|
|
g_hash_table_iter_init (&iter, display->x11_display->xids);
|
|
|
|
while (g_hash_table_iter_next (&iter, &key, &value))
|
|
|
|
{
|
|
|
|
MetaWindow *window = value;
|
2009-06-15 19:32:23 +00:00
|
|
|
|
2017-08-26 16:56:44 +00:00
|
|
|
if (!META_IS_WINDOW (window) || window->unmanaging)
|
|
|
|
continue;
|
2012-07-30 18:57:53 +00:00
|
|
|
|
2017-08-26 16:56:44 +00:00
|
|
|
if (!window->override_redirect ||
|
|
|
|
(flags & META_LIST_INCLUDE_OVERRIDE_REDIRECT) != 0)
|
|
|
|
winlist = g_slist_prepend (winlist, window);
|
|
|
|
}
|
2009-06-15 19:32:23 +00:00
|
|
|
}
|
2001-06-03 18:33:59 +00:00
|
|
|
|
2013-09-16 09:24:01 +00:00
|
|
|
g_hash_table_iter_init (&iter, display->wayland_windows);
|
|
|
|
while (g_hash_table_iter_next (&iter, &key, &value))
|
|
|
|
{
|
|
|
|
MetaWindow *window = value;
|
|
|
|
|
2014-10-07 15:13:15 +00:00
|
|
|
if (!META_IS_WINDOW (window) || window->unmanaging)
|
2013-09-16 09:24:01 +00:00
|
|
|
continue;
|
|
|
|
|
|
|
|
if (!window->override_redirect ||
|
|
|
|
(flags & META_LIST_INCLUDE_OVERRIDE_REDIRECT) != 0)
|
|
|
|
winlist = g_slist_prepend (winlist, window);
|
|
|
|
}
|
|
|
|
|
2001-06-24 08:09:10 +00:00
|
|
|
/* Uniquify the list, since both frame windows and plain
|
|
|
|
* windows are in the hash
|
|
|
|
*/
|
2001-06-03 18:33:59 +00:00
|
|
|
winlist = g_slist_sort (winlist, ptrcmp);
|
|
|
|
|
2001-06-24 08:09:10 +00:00
|
|
|
prev = NULL;
|
|
|
|
tmp = winlist;
|
|
|
|
while (tmp != NULL)
|
|
|
|
{
|
|
|
|
GSList *next;
|
|
|
|
|
|
|
|
next = tmp->next;
|
2014-05-02 13:34:02 +00:00
|
|
|
|
2001-06-24 08:09:10 +00:00
|
|
|
if (next &&
|
|
|
|
next->data == tmp->data)
|
|
|
|
{
|
|
|
|
/* Delete tmp from list */
|
|
|
|
|
|
|
|
if (prev)
|
|
|
|
prev->next = next;
|
|
|
|
|
|
|
|
if (tmp == winlist)
|
|
|
|
winlist = next;
|
2014-05-02 13:34:02 +00:00
|
|
|
|
2001-06-24 08:09:10 +00:00
|
|
|
g_slist_free_1 (tmp);
|
|
|
|
|
|
|
|
/* leave prev unchanged */
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
prev = tmp;
|
|
|
|
}
|
2014-05-02 13:34:02 +00:00
|
|
|
|
2001-06-24 08:09:10 +00:00
|
|
|
tmp = next;
|
|
|
|
}
|
|
|
|
|
2014-09-29 22:01:17 +00:00
|
|
|
if (flags & META_LIST_SORTED)
|
|
|
|
winlist = g_slist_sort (winlist, mru_cmp);
|
|
|
|
|
2001-06-24 08:09:10 +00:00
|
|
|
return winlist;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
Partial audit to fix timestamp usage. One step towards fixing #355180; see
2006-09-18 Elijah Newren <newren gmail com>
Partial audit to fix timestamp usage. One step towards fixing
#355180; see important comments in that bug.
* src/core.[ch] (meta_core_unshade, meta_core_shade):
* src/delete.c (meta_window_present_delete_dialog,
delete_ping_timeout_func):
* src/display.[ch] (meta_display_open, meta_display_close,
event_callback, meta_display_begin_grab_op,
process_selection_clear, meta_display_unmanage_screen,
meta_display_unmanage_windows_for_screen):
* src/frames.c (meta_frames_button_press_event):
* src/keybindings.c (handle_toggle_shade):
* src/main.c (main):
* src/screen.[ch] (update_num_workspaces, meta_screen_new,
meta_screen_free, prefs_changed_callback):
* src/window.[ch] (meta_window_free, finish_minimize,
implement_showing, meta_window_show, meta_window_maximize,
meta_window_make_fullscreen_internal,
meta_window_unmake_fullscreen, meta_window_shade,
meta_window_unshade, window_activate, send_sync_request,
meta_window_client_message, menu_callback,
meta_window_update_keyboard_resize):
Remove usage of CurrentTime, meta_display_get_current_time() and
meta_display_get_current_time_roundtrip() where possible, or
document why it isn't possible, or at very least add a FIXME with
some explanation of my laziness and what needs to be done.
2006-09-18 17:27:24 +00:00
|
|
|
meta_display_close (MetaDisplay *display,
|
|
|
|
guint32 timestamp)
|
2001-06-24 08:09:10 +00:00
|
|
|
{
|
MetaDisplay becomes a singleton. The static variable which holds this
2008-03-25 Thomas Thurman <tthurman@gnome.org>
* src/core/display.c (meta_display_queue_retheme_all_windows,
meta_set_syncing, meta_display_set_cursor_theme, disable_compositor,
meta_display_for_x_display, meta_display_open, meta_display_close,
meta_display_ungrab): MetaDisplay becomes a singleton. The static
variable which holds this singleton is renamed "the_display" so as
not to mask the this parameter in the methods.
* src/core/main.c (main):
* src/core/session.c (warn_about_lame_clients_and_finish_inte,
save_state, io_from_warning_dialog):
* src/core/core.c (meta_core_increment_event_serial):
* src/core/delete.c (release_window_with_fd, search_and_destroy_window):
sympathy changes for this, and consequent simplification.
Closes #499301.
svn path=/trunk/; revision=3663
2008-03-25 03:39:13 +00:00
|
|
|
g_assert (display != NULL);
|
2014-07-13 15:36:34 +00:00
|
|
|
g_assert (display == the_display);
|
MetaDisplay becomes a singleton. The static variable which holds this
2008-03-25 Thomas Thurman <tthurman@gnome.org>
* src/core/display.c (meta_display_queue_retheme_all_windows,
meta_set_syncing, meta_display_set_cursor_theme, disable_compositor,
meta_display_for_x_display, meta_display_open, meta_display_close,
meta_display_ungrab): MetaDisplay becomes a singleton. The static
variable which holds this singleton is renamed "the_display" so as
not to mask the this parameter in the methods.
* src/core/main.c (main):
* src/core/session.c (warn_about_lame_clients_and_finish_inte,
save_state, io_from_warning_dialog):
* src/core/core.c (meta_core_increment_event_serial):
* src/core/delete.c (release_window_with_fd, search_and_destroy_window):
sympathy changes for this, and consequent simplification.
Closes #499301.
svn path=/trunk/; revision=3663
2008-03-25 03:39:13 +00:00
|
|
|
|
2008-03-27 12:32:50 +00:00
|
|
|
if (display->closing != 0)
|
MetaDisplay becomes a singleton. The static variable which holds this
2008-03-25 Thomas Thurman <tthurman@gnome.org>
* src/core/display.c (meta_display_queue_retheme_all_windows,
meta_set_syncing, meta_display_set_cursor_theme, disable_compositor,
meta_display_for_x_display, meta_display_open, meta_display_close,
meta_display_ungrab): MetaDisplay becomes a singleton. The static
variable which holds this singleton is renamed "the_display" so as
not to mask the this parameter in the methods.
* src/core/main.c (main):
* src/core/session.c (warn_about_lame_clients_and_finish_inte,
save_state, io_from_warning_dialog):
* src/core/core.c (meta_core_increment_event_serial):
* src/core/delete.c (release_window_with_fd, search_and_destroy_window):
sympathy changes for this, and consequent simplification.
Closes #499301.
svn path=/trunk/; revision=3663
2008-03-25 03:39:13 +00:00
|
|
|
{
|
2008-03-27 12:32:50 +00:00
|
|
|
/* The display's already been closed. */
|
MetaDisplay becomes a singleton. The static variable which holds this
2008-03-25 Thomas Thurman <tthurman@gnome.org>
* src/core/display.c (meta_display_queue_retheme_all_windows,
meta_set_syncing, meta_display_set_cursor_theme, disable_compositor,
meta_display_for_x_display, meta_display_open, meta_display_close,
meta_display_ungrab): MetaDisplay becomes a singleton. The static
variable which holds this singleton is renamed "the_display" so as
not to mask the this parameter in the methods.
* src/core/main.c (main):
* src/core/session.c (warn_about_lame_clients_and_finish_inte,
save_state, io_from_warning_dialog):
* src/core/core.c (meta_core_increment_event_serial):
* src/core/delete.c (release_window_with_fd, search_and_destroy_window):
sympathy changes for this, and consequent simplification.
Closes #499301.
svn path=/trunk/; revision=3663
2008-03-25 03:39:13 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2002-06-22 05:11:04 +00:00
|
|
|
display->closing += 1;
|
2002-10-07 23:14:40 +00:00
|
|
|
|
2018-06-29 10:44:17 +00:00
|
|
|
meta_compositor_unmanage (display->compositor);
|
|
|
|
|
|
|
|
meta_display_unmanage_windows (display, timestamp);
|
|
|
|
|
2002-10-07 23:14:40 +00:00
|
|
|
meta_prefs_remove_listener (prefs_changed_callback, display);
|
2014-05-02 13:34:02 +00:00
|
|
|
|
2004-10-04 21:09:08 +00:00
|
|
|
meta_display_remove_autoraise_callback (display);
|
2005-01-24 05:58:30 +00:00
|
|
|
|
2014-06-19 21:13:38 +00:00
|
|
|
g_clear_object (&display->gesture_tracker);
|
|
|
|
|
2017-08-26 17:03:51 +00:00
|
|
|
g_clear_pointer (&display->stack, (GDestroyNotify) meta_stack_free);
|
|
|
|
g_clear_pointer (&display->stack_tracker,
|
|
|
|
(GDestroyNotify) meta_stack_tracker_free);
|
|
|
|
|
2012-12-04 21:45:35 +00:00
|
|
|
if (display->focus_timeout_id)
|
2012-08-29 02:38:54 +00:00
|
|
|
g_source_remove (display->focus_timeout_id);
|
|
|
|
display->focus_timeout_id = 0;
|
|
|
|
|
2017-08-26 19:10:38 +00:00
|
|
|
if (display->tile_preview_timeout_id)
|
|
|
|
g_source_remove (display->tile_preview_timeout_id);
|
|
|
|
display->tile_preview_timeout_id = 0;
|
|
|
|
|
|
|
|
if (display->work_area_later != 0)
|
|
|
|
meta_later_remove (display->work_area_later);
|
|
|
|
if (display->check_fullscreen_later != 0)
|
|
|
|
meta_later_remove (display->check_fullscreen_later);
|
|
|
|
|
2001-06-20 03:01:26 +00:00
|
|
|
/* Stop caring about events */
|
2014-03-20 19:29:30 +00:00
|
|
|
meta_display_free_events (display);
|
2014-05-02 13:34:02 +00:00
|
|
|
|
2008-11-07 09:57:00 +00:00
|
|
|
/* Must be after all calls to meta_window_unmanage() since they
|
2001-06-04 04:58:22 +00:00
|
|
|
* unregister windows
|
|
|
|
*/
|
2014-05-07 16:24:43 +00:00
|
|
|
g_hash_table_destroy (display->wayland_windows);
|
2017-11-06 19:38:43 +00:00
|
|
|
g_hash_table_destroy (display->stamps);
|
2001-06-09 21:58:30 +00:00
|
|
|
|
2017-08-26 16:24:46 +00:00
|
|
|
if (display->compositor)
|
|
|
|
meta_compositor_destroy (display->compositor);
|
|
|
|
|
|
|
|
if (display->x11_display)
|
|
|
|
{
|
2018-06-30 06:55:48 +00:00
|
|
|
g_signal_emit (display, display_signals[X11_DISPLAY_CLOSING], 0);
|
2017-08-26 16:24:46 +00:00
|
|
|
g_object_run_dispose (G_OBJECT (display->x11_display));
|
|
|
|
g_clear_object (&display->x11_display);
|
|
|
|
}
|
2003-11-21 02:32:05 +00:00
|
|
|
|
2017-08-26 16:24:46 +00:00
|
|
|
meta_display_shutdown_keys (display);
|
2014-05-02 13:34:02 +00:00
|
|
|
|
2017-08-26 20:35:18 +00:00
|
|
|
g_clear_object (&display->bell);
|
|
|
|
g_clear_object (&display->startup_notification);
|
|
|
|
|
2009-02-03 09:11:32 +00:00
|
|
|
g_object_unref (display);
|
2009-08-22 19:55:17 +00:00
|
|
|
the_display = NULL;
|
2001-05-30 15:36:31 +00:00
|
|
|
|
MetaDisplay becomes a singleton. The static variable which holds this
2008-03-25 Thomas Thurman <tthurman@gnome.org>
* src/core/display.c (meta_display_queue_retheme_all_windows,
meta_set_syncing, meta_display_set_cursor_theme, disable_compositor,
meta_display_for_x_display, meta_display_open, meta_display_close,
meta_display_ungrab): MetaDisplay becomes a singleton. The static
variable which holds this singleton is renamed "the_display" so as
not to mask the this parameter in the methods.
* src/core/main.c (main):
* src/core/session.c (warn_about_lame_clients_and_finish_inte,
save_state, io_from_warning_dialog):
* src/core/core.c (meta_core_increment_event_serial):
* src/core/delete.c (release_window_with_fd, search_and_destroy_window):
sympathy changes for this, and consequent simplification.
Closes #499301.
svn path=/trunk/; revision=3663
2008-03-25 03:39:13 +00:00
|
|
|
meta_quit (META_EXIT_SUCCESS);
|
2001-05-30 15:36:31 +00:00
|
|
|
}
|
|
|
|
|
MetaDisplay becomes a singleton. The static variable which holds this
2008-03-25 Thomas Thurman <tthurman@gnome.org>
* src/core/display.c (meta_display_queue_retheme_all_windows,
meta_set_syncing, meta_display_set_cursor_theme, disable_compositor,
meta_display_for_x_display, meta_display_open, meta_display_close,
meta_display_ungrab): MetaDisplay becomes a singleton. The static
variable which holds this singleton is renamed "the_display" so as
not to mask the this parameter in the methods.
* src/core/main.c (main):
* src/core/session.c (warn_about_lame_clients_and_finish_inte,
save_state, io_from_warning_dialog):
* src/core/core.c (meta_core_increment_event_serial):
* src/core/delete.c (release_window_with_fd, search_and_destroy_window):
sympathy changes for this, and consequent simplification.
Closes #499301.
svn path=/trunk/; revision=3663
2008-03-25 03:39:13 +00:00
|
|
|
/**
|
2011-11-02 15:34:45 +00:00
|
|
|
* meta_display_for_x_display:
|
|
|
|
* @xdisplay: An X display
|
|
|
|
*
|
|
|
|
* Returns the singleton MetaDisplay if @xdisplay matches the X display it's
|
|
|
|
* managing; otherwise gives a warning and returns %NULL. When we were claiming
|
MetaDisplay becomes a singleton. The static variable which holds this
2008-03-25 Thomas Thurman <tthurman@gnome.org>
* src/core/display.c (meta_display_queue_retheme_all_windows,
meta_set_syncing, meta_display_set_cursor_theme, disable_compositor,
meta_display_for_x_display, meta_display_open, meta_display_close,
meta_display_ungrab): MetaDisplay becomes a singleton. The static
variable which holds this singleton is renamed "the_display" so as
not to mask the this parameter in the methods.
* src/core/main.c (main):
* src/core/session.c (warn_about_lame_clients_and_finish_inte,
save_state, io_from_warning_dialog):
* src/core/core.c (meta_core_increment_event_serial):
* src/core/delete.c (release_window_with_fd, search_and_destroy_window):
sympathy changes for this, and consequent simplification.
Closes #499301.
svn path=/trunk/; revision=3663
2008-03-25 03:39:13 +00:00
|
|
|
* to be able to manage multiple displays, this was supposed to find the
|
|
|
|
* display out of the list which matched that display. Now it's merely an
|
|
|
|
* extra sanity check.
|
|
|
|
*
|
2011-11-02 15:34:45 +00:00
|
|
|
* Returns: The singleton X display, or %NULL if @xdisplay isn't the one
|
MetaDisplay becomes a singleton. The static variable which holds this
2008-03-25 Thomas Thurman <tthurman@gnome.org>
* src/core/display.c (meta_display_queue_retheme_all_windows,
meta_set_syncing, meta_display_set_cursor_theme, disable_compositor,
meta_display_for_x_display, meta_display_open, meta_display_close,
meta_display_ungrab): MetaDisplay becomes a singleton. The static
variable which holds this singleton is renamed "the_display" so as
not to mask the this parameter in the methods.
* src/core/main.c (main):
* src/core/session.c (warn_about_lame_clients_and_finish_inte,
save_state, io_from_warning_dialog):
* src/core/core.c (meta_core_increment_event_serial):
* src/core/delete.c (release_window_with_fd, search_and_destroy_window):
sympathy changes for this, and consequent simplification.
Closes #499301.
svn path=/trunk/; revision=3663
2008-03-25 03:39:13 +00:00
|
|
|
* we're managing.
|
|
|
|
*/
|
2001-05-31 03:30:58 +00:00
|
|
|
MetaDisplay*
|
|
|
|
meta_display_for_x_display (Display *xdisplay)
|
|
|
|
{
|
2017-08-26 16:26:30 +00:00
|
|
|
if (the_display->x11_display->xdisplay == xdisplay)
|
MetaDisplay becomes a singleton. The static variable which holds this
2008-03-25 Thomas Thurman <tthurman@gnome.org>
* src/core/display.c (meta_display_queue_retheme_all_windows,
meta_set_syncing, meta_display_set_cursor_theme, disable_compositor,
meta_display_for_x_display, meta_display_open, meta_display_close,
meta_display_ungrab): MetaDisplay becomes a singleton. The static
variable which holds this singleton is renamed "the_display" so as
not to mask the this parameter in the methods.
* src/core/main.c (main):
* src/core/session.c (warn_about_lame_clients_and_finish_inte,
save_state, io_from_warning_dialog):
* src/core/core.c (meta_core_increment_event_serial):
* src/core/delete.c (release_window_with_fd, search_and_destroy_window):
sympathy changes for this, and consequent simplification.
Closes #499301.
svn path=/trunk/; revision=3663
2008-03-25 03:39:13 +00:00
|
|
|
return the_display;
|
2001-05-31 03:30:58 +00:00
|
|
|
|
2002-03-06 22:27:24 +00:00
|
|
|
meta_warning ("Could not find display for X display %p, probably going to crash\n",
|
|
|
|
xdisplay);
|
2014-05-02 13:34:02 +00:00
|
|
|
|
2001-05-31 03:30:58 +00:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
MetaDisplay becomes a singleton. The static variable which holds this
2008-03-25 Thomas Thurman <tthurman@gnome.org>
* src/core/display.c (meta_display_queue_retheme_all_windows,
meta_set_syncing, meta_display_set_cursor_theme, disable_compositor,
meta_display_for_x_display, meta_display_open, meta_display_close,
meta_display_ungrab): MetaDisplay becomes a singleton. The static
variable which holds this singleton is renamed "the_display" so as
not to mask the this parameter in the methods.
* src/core/main.c (main):
* src/core/session.c (warn_about_lame_clients_and_finish_inte,
save_state, io_from_warning_dialog):
* src/core/core.c (meta_core_increment_event_serial):
* src/core/delete.c (release_window_with_fd, search_and_destroy_window):
sympathy changes for this, and consequent simplification.
Closes #499301.
svn path=/trunk/; revision=3663
2008-03-25 03:39:13 +00:00
|
|
|
/**
|
2011-11-02 15:34:45 +00:00
|
|
|
* meta_get_display:
|
|
|
|
*
|
MetaDisplay becomes a singleton. The static variable which holds this
2008-03-25 Thomas Thurman <tthurman@gnome.org>
* src/core/display.c (meta_display_queue_retheme_all_windows,
meta_set_syncing, meta_display_set_cursor_theme, disable_compositor,
meta_display_for_x_display, meta_display_open, meta_display_close,
meta_display_ungrab): MetaDisplay becomes a singleton. The static
variable which holds this singleton is renamed "the_display" so as
not to mask the this parameter in the methods.
* src/core/main.c (main):
* src/core/session.c (warn_about_lame_clients_and_finish_inte,
save_state, io_from_warning_dialog):
* src/core/core.c (meta_core_increment_event_serial):
* src/core/delete.c (release_window_with_fd, search_and_destroy_window):
sympathy changes for this, and consequent simplification.
Closes #499301.
svn path=/trunk/; revision=3663
2008-03-25 03:39:13 +00:00
|
|
|
* Accessor for the singleton MetaDisplay.
|
|
|
|
*
|
2011-11-02 15:34:45 +00:00
|
|
|
* Returns: The only #MetaDisplay there is. This can be %NULL, but only
|
MetaDisplay becomes a singleton. The static variable which holds this
2008-03-25 Thomas Thurman <tthurman@gnome.org>
* src/core/display.c (meta_display_queue_retheme_all_windows,
meta_set_syncing, meta_display_set_cursor_theme, disable_compositor,
meta_display_for_x_display, meta_display_open, meta_display_close,
meta_display_ungrab): MetaDisplay becomes a singleton. The static
variable which holds this singleton is renamed "the_display" so as
not to mask the this parameter in the methods.
* src/core/main.c (main):
* src/core/session.c (warn_about_lame_clients_and_finish_inte,
save_state, io_from_warning_dialog):
* src/core/core.c (meta_core_increment_event_serial):
* src/core/delete.c (release_window_with_fd, search_and_destroy_window):
sympathy changes for this, and consequent simplification.
Closes #499301.
svn path=/trunk/; revision=3663
2008-03-25 03:39:13 +00:00
|
|
|
* during startup.
|
|
|
|
*/
|
|
|
|
MetaDisplay*
|
|
|
|
meta_get_display (void)
|
2001-05-31 06:42:58 +00:00
|
|
|
{
|
MetaDisplay becomes a singleton. The static variable which holds this
2008-03-25 Thomas Thurman <tthurman@gnome.org>
* src/core/display.c (meta_display_queue_retheme_all_windows,
meta_set_syncing, meta_display_set_cursor_theme, disable_compositor,
meta_display_for_x_display, meta_display_open, meta_display_close,
meta_display_ungrab): MetaDisplay becomes a singleton. The static
variable which holds this singleton is renamed "the_display" so as
not to mask the this parameter in the methods.
* src/core/main.c (main):
* src/core/session.c (warn_about_lame_clients_and_finish_inte,
save_state, io_from_warning_dialog):
* src/core/core.c (meta_core_increment_event_serial):
* src/core/delete.c (release_window_with_fd, search_and_destroy_window):
sympathy changes for this, and consequent simplification.
Closes #499301.
svn path=/trunk/; revision=3663
2008-03-25 03:39:13 +00:00
|
|
|
return the_display;
|
2001-05-31 06:42:58 +00:00
|
|
|
}
|
|
|
|
|
2014-08-15 21:44:25 +00:00
|
|
|
static inline gboolean
|
|
|
|
grab_op_is_window (MetaGrabOp op)
|
|
|
|
{
|
|
|
|
return GRAB_OP_GET_BASE_TYPE (op) == META_GRAB_OP_WINDOW_BASE;
|
|
|
|
}
|
|
|
|
|
2014-04-20 15:41:22 +00:00
|
|
|
gboolean
|
2014-04-20 15:45:38 +00:00
|
|
|
meta_grab_op_is_mouse (MetaGrabOp op)
|
2006-08-21 18:38:21 +00:00
|
|
|
{
|
2014-08-16 19:23:19 +00:00
|
|
|
if (!grab_op_is_window (op))
|
2014-08-15 18:05:04 +00:00
|
|
|
return FALSE;
|
2006-08-21 18:38:21 +00:00
|
|
|
|
2014-08-15 18:05:04 +00:00
|
|
|
return (op & META_GRAB_OP_WINDOW_FLAG_KEYBOARD) == 0;
|
2006-08-21 18:38:21 +00:00
|
|
|
}
|
|
|
|
|
2014-03-20 19:29:30 +00:00
|
|
|
gboolean
|
|
|
|
meta_grab_op_is_keyboard (MetaGrabOp op)
|
2001-07-26 03:14:45 +00:00
|
|
|
{
|
2014-08-16 19:23:19 +00:00
|
|
|
if (!grab_op_is_window (op))
|
2014-08-15 18:05:04 +00:00
|
|
|
return FALSE;
|
2001-07-26 03:14:45 +00:00
|
|
|
|
2014-08-15 18:05:04 +00:00
|
|
|
return (op & META_GRAB_OP_WINDOW_FLAG_KEYBOARD) != 0;
|
2001-07-26 03:14:45 +00:00
|
|
|
}
|
|
|
|
|
2002-12-10 03:23:04 +00:00
|
|
|
gboolean
|
|
|
|
meta_grab_op_is_resizing (MetaGrabOp op)
|
|
|
|
{
|
2014-08-16 19:23:19 +00:00
|
|
|
if (!grab_op_is_window (op))
|
2014-08-15 18:05:04 +00:00
|
|
|
return FALSE;
|
2002-12-10 03:23:04 +00:00
|
|
|
|
2014-12-01 16:31:26 +00:00
|
|
|
return (op & META_GRAB_OP_WINDOW_DIR_MASK) != 0 || op == META_GRAB_OP_KEYBOARD_RESIZING_UNKNOWN;
|
2002-12-10 03:23:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
gboolean
|
|
|
|
meta_grab_op_is_moving (MetaGrabOp op)
|
|
|
|
{
|
2014-08-16 19:23:19 +00:00
|
|
|
if (!grab_op_is_window (op))
|
2014-08-15 18:05:04 +00:00
|
|
|
return FALSE;
|
2014-05-02 13:34:02 +00:00
|
|
|
|
2015-01-20 16:09:31 +00:00
|
|
|
return !meta_grab_op_is_resizing (op);
|
2002-12-10 03:23:04 +00:00
|
|
|
}
|
|
|
|
|
2014-04-12 07:13:57 +00:00
|
|
|
/**
|
2016-03-10 15:48:45 +00:00
|
|
|
* meta_display_windows_are_interactable:
|
2014-04-12 07:13:57 +00:00
|
|
|
* @op: A #MetaGrabOp
|
|
|
|
*
|
2014-08-15 17:12:22 +00:00
|
|
|
* Whether windows can be interacted with.
|
2014-04-12 07:13:57 +00:00
|
|
|
*/
|
2014-03-17 19:53:19 +00:00
|
|
|
gboolean
|
2014-08-15 17:12:22 +00:00
|
|
|
meta_display_windows_are_interactable (MetaDisplay *display)
|
2014-03-17 19:53:19 +00:00
|
|
|
{
|
2014-08-15 17:12:22 +00:00
|
|
|
switch (display->event_route)
|
2014-04-24 17:04:15 +00:00
|
|
|
{
|
2014-08-15 17:12:22 +00:00
|
|
|
case META_EVENT_ROUTE_NORMAL:
|
|
|
|
case META_EVENT_ROUTE_WAYLAND_POPUP:
|
2014-04-24 17:04:15 +00:00
|
|
|
return TRUE;
|
2014-08-15 17:30:31 +00:00
|
|
|
default:
|
|
|
|
return FALSE;
|
2014-04-24 17:04:15 +00:00
|
|
|
}
|
2014-03-17 19:53:19 +00:00
|
|
|
}
|
|
|
|
|
2010-04-17 18:43:08 +00:00
|
|
|
/**
|
|
|
|
* meta_display_xserver_time_is_before:
|
|
|
|
* @display: a #MetaDisplay
|
|
|
|
* @time1: An event timestamp
|
|
|
|
* @time2: An event timestamp
|
|
|
|
*
|
|
|
|
* Xserver time can wraparound, thus comparing two timestamps needs to take
|
|
|
|
* this into account. If no wraparound has occurred, this is equivalent to
|
|
|
|
* time1 < time2
|
|
|
|
* Otherwise, we need to account for the fact that wraparound can occur
|
|
|
|
* and the fact that a timestamp of 0 must be special-cased since it
|
|
|
|
* means "older than anything else".
|
|
|
|
*
|
|
|
|
* Note that this is NOT an equivalent for time1 <= time2; if that's what
|
|
|
|
* you need then you'll need to swap the order of the arguments and negate
|
|
|
|
* the result.
|
|
|
|
*/
|
|
|
|
gboolean
|
|
|
|
meta_display_xserver_time_is_before (MetaDisplay *display,
|
|
|
|
guint32 time1,
|
|
|
|
guint32 time2)
|
|
|
|
{
|
|
|
|
return XSERVER_TIME_IS_BEFORE(time1, time2);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* meta_display_get_last_user_time:
|
|
|
|
* @display: a #MetaDisplay
|
|
|
|
*
|
|
|
|
* Returns: Timestamp of the last user interaction event with a window
|
|
|
|
*/
|
|
|
|
guint32
|
|
|
|
meta_display_get_last_user_time (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
return display->last_user_time;
|
|
|
|
}
|
|
|
|
|
2002-01-03 23:28:19 +00:00
|
|
|
/* Get time of current event, or CurrentTime if none. */
|
|
|
|
guint32
|
|
|
|
meta_display_get_current_time (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
return display->current_time;
|
|
|
|
}
|
|
|
|
|
Fix a variety of focus race conditions in all focus modes, or at least
2004-10-04 Elijah Newren <newren@math.utah.edu>
Fix a variety of focus race conditions in all focus modes, or at
least make them harder to trigger (fixes #152000)
* src/core.[ch] (meta_core_user_lower_and_unfocus): add a
timestamp parameter; pass it along to
meta_workspace_focus_default_window
* src/display.[ch] (meta_display_get_current_time_roundtrip): new
function
* src/display.c (event_callback): pass a timestamp to the
meta_workspace_activate and meta_workspace_focus_default_window
function calls
* src/frames.c (meta_frames_button_press_event): pass a timestamp
to meta_core_user_lower_and_unfocus
* src/keybindings.c (handle_activate_workspace): pass a timestamp
to meta_workspace_activate, (process_workspace_switch_grab): pass
a timestamp to meta_workspace_focus_default_window and
meta_workspace_activate, (handle_toggle_desktop): pass a timestamp
to meta_workspace_focus_default_window,
(do_handle_move_to_workspace): pass a timestamp to
meta_workspace_activate_with_focus, (handle_workspace_switch):
meta_workspace_activate
* src/screen.c (meta_screen_new): pass a timestamp to
meta_workspace_activate
* src/window.c (meta_window_free): pass a timestamp to
meta_workspace_focus_default_window, (idle_calc_showing): don't
increment the focus sentinel here, (meta_window_minimize): pass a
timestamp to meta_workspace_focus_default_window,
(meta_window_client_message), pass a timestamp to
meta_workspace_focus_default_window
* src/workspace.h (meta_workspace_activate): add timestamp
parameter, (meta_workspace_activate_with_focus): add timestamp
parameter, (meta_workspace_focus_default_window): add timestamp
parameter
* src/workspace.c (meta_workspace_focus_mru_window): make this
function take a timestamp and use it for meta_window_focus or
XSetInputFocus, (meta_workspace_activate_with_focus): make this
function take a timestamp and pass it along to meta_window_focus
and meta_workspace_focus_default_window,
(meta_workspace_activate): make this function take a timestamp and
pass it to meta_workspace_activate_with_focus),
(meta_workspace_focus_default_window): make this function take a
timestamp, warn if its 0 but try to handle that case sanely, and
pass the timestamp on to meta_window_focus or
meta_workspace_focus_mru_window or XSetInputFocus
2004-10-04 20:32:59 +00:00
|
|
|
guint32
|
|
|
|
meta_display_get_current_time_roundtrip (MetaDisplay *display)
|
|
|
|
{
|
2017-08-26 20:24:21 +00:00
|
|
|
if (meta_is_wayland_compositor ())
|
|
|
|
/* Xwayland uses monotonic clock, so lets use it here as well */
|
|
|
|
return (guint32) (g_get_monotonic_time () / 1000);
|
|
|
|
else
|
|
|
|
return meta_x11_display_get_current_time_roundtrip (display->x11_display);
|
Fix a variety of focus race conditions in all focus modes, or at least
2004-10-04 Elijah Newren <newren@math.utah.edu>
Fix a variety of focus race conditions in all focus modes, or at
least make them harder to trigger (fixes #152000)
* src/core.[ch] (meta_core_user_lower_and_unfocus): add a
timestamp parameter; pass it along to
meta_workspace_focus_default_window
* src/display.[ch] (meta_display_get_current_time_roundtrip): new
function
* src/display.c (event_callback): pass a timestamp to the
meta_workspace_activate and meta_workspace_focus_default_window
function calls
* src/frames.c (meta_frames_button_press_event): pass a timestamp
to meta_core_user_lower_and_unfocus
* src/keybindings.c (handle_activate_workspace): pass a timestamp
to meta_workspace_activate, (process_workspace_switch_grab): pass
a timestamp to meta_workspace_focus_default_window and
meta_workspace_activate, (handle_toggle_desktop): pass a timestamp
to meta_workspace_focus_default_window,
(do_handle_move_to_workspace): pass a timestamp to
meta_workspace_activate_with_focus, (handle_workspace_switch):
meta_workspace_activate
* src/screen.c (meta_screen_new): pass a timestamp to
meta_workspace_activate
* src/window.c (meta_window_free): pass a timestamp to
meta_workspace_focus_default_window, (idle_calc_showing): don't
increment the focus sentinel here, (meta_window_minimize): pass a
timestamp to meta_workspace_focus_default_window,
(meta_window_client_message), pass a timestamp to
meta_workspace_focus_default_window
* src/workspace.h (meta_workspace_activate): add timestamp
parameter, (meta_workspace_activate_with_focus): add timestamp
parameter, (meta_workspace_focus_default_window): add timestamp
parameter
* src/workspace.c (meta_workspace_focus_mru_window): make this
function take a timestamp and use it for meta_window_focus or
XSetInputFocus, (meta_workspace_activate_with_focus): make this
function take a timestamp and pass it along to meta_window_focus
and meta_workspace_focus_default_window,
(meta_workspace_activate): make this function take a timestamp and
pass it to meta_workspace_activate_with_focus),
(meta_workspace_focus_default_window): make this function take a
timestamp, warn if its 0 but try to handle that case sanely, and
pass the timestamp on to meta_window_focus or
meta_workspace_focus_mru_window or XSetInputFocus
2004-10-04 20:32:59 +00:00
|
|
|
}
|
|
|
|
|
2011-09-07 15:19:15 +00:00
|
|
|
/**
|
|
|
|
* meta_display_add_ignored_crossing_serial:
|
|
|
|
* @display: a #MetaDisplay
|
|
|
|
* @serial: the serial to ignore
|
|
|
|
*
|
|
|
|
* Save the specified serial and ignore crossing events with that
|
|
|
|
* serial for the purpose of focus-follows-mouse. This can be used
|
|
|
|
* for certain changes to the window hierarchy that we don't want
|
|
|
|
* to change the focus window, even if they cause the pointer to
|
|
|
|
* end up in a new window.
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
meta_display_add_ignored_crossing_serial (MetaDisplay *display,
|
|
|
|
unsigned long serial)
|
2002-03-02 15:26:07 +00:00
|
|
|
{
|
|
|
|
int i;
|
|
|
|
|
|
|
|
/* don't add the same serial more than once */
|
2011-09-12 13:50:30 +00:00
|
|
|
if (display->ignored_crossing_serials[N_IGNORED_CROSSING_SERIALS-1] == serial)
|
2002-03-02 15:26:07 +00:00
|
|
|
return;
|
2014-05-02 13:34:02 +00:00
|
|
|
|
2002-03-02 15:26:07 +00:00
|
|
|
/* shift serials to the left */
|
|
|
|
i = 0;
|
2011-09-12 13:50:30 +00:00
|
|
|
while (i < (N_IGNORED_CROSSING_SERIALS - 1))
|
2002-03-02 15:26:07 +00:00
|
|
|
{
|
2011-09-12 13:50:30 +00:00
|
|
|
display->ignored_crossing_serials[i] = display->ignored_crossing_serials[i+1];
|
2002-03-02 15:26:07 +00:00
|
|
|
++i;
|
|
|
|
}
|
|
|
|
/* put new one on the end */
|
2011-09-12 13:50:30 +00:00
|
|
|
display->ignored_crossing_serials[i] = serial;
|
2002-03-02 15:26:07 +00:00
|
|
|
}
|
|
|
|
|
2014-05-02 13:34:02 +00:00
|
|
|
static gboolean
|
2002-05-24 02:23:46 +00:00
|
|
|
window_raise_with_delay_callback (void *data)
|
|
|
|
{
|
2013-10-16 04:19:33 +00:00
|
|
|
MetaWindow *window = data;
|
2002-05-24 02:23:46 +00:00
|
|
|
|
2013-10-16 04:19:33 +00:00
|
|
|
window->display->autoraise_timeout_id = 0;
|
|
|
|
window->display->autoraise_window = NULL;
|
2002-05-24 02:23:46 +00:00
|
|
|
|
|
|
|
/* If we aren't already on top, check whether the pointer is inside
|
|
|
|
* the window and raise the window if so.
|
2014-05-02 13:34:02 +00:00
|
|
|
*/
|
2017-08-26 17:03:51 +00:00
|
|
|
if (meta_stack_get_top (window->display->stack) != window)
|
2002-05-24 02:23:46 +00:00
|
|
|
{
|
2014-06-12 21:01:13 +00:00
|
|
|
if (meta_window_has_pointer (window))
|
2002-05-24 02:23:46 +00:00
|
|
|
meta_window_raise (window);
|
|
|
|
else
|
2014-05-02 13:34:02 +00:00
|
|
|
meta_topic (META_DEBUG_FOCUS,
|
|
|
|
"Pointer not inside window, not raising %s\n",
|
2002-05-24 02:23:46 +00:00
|
|
|
window->desc);
|
|
|
|
}
|
|
|
|
|
2014-06-12 21:02:14 +00:00
|
|
|
return G_SOURCE_REMOVE;
|
2002-05-24 02:23:46 +00:00
|
|
|
}
|
|
|
|
|
2004-10-04 21:09:08 +00:00
|
|
|
void
|
|
|
|
meta_display_queue_autoraise_callback (MetaDisplay *display,
|
|
|
|
MetaWindow *window)
|
|
|
|
{
|
2014-05-02 13:34:02 +00:00
|
|
|
meta_topic (META_DEBUG_FOCUS,
|
|
|
|
"Queuing an autoraise timeout for %s with delay %d\n",
|
|
|
|
window->desc,
|
2004-10-04 21:09:08 +00:00
|
|
|
meta_prefs_get_auto_raise_delay ());
|
2014-05-02 13:34:02 +00:00
|
|
|
|
2004-10-04 21:09:08 +00:00
|
|
|
if (display->autoraise_timeout_id != 0)
|
|
|
|
g_source_remove (display->autoraise_timeout_id);
|
|
|
|
|
2014-05-02 13:34:02 +00:00
|
|
|
display->autoraise_timeout_id =
|
2004-10-04 21:09:08 +00:00
|
|
|
g_timeout_add_full (G_PRIORITY_DEFAULT,
|
|
|
|
meta_prefs_get_auto_raise_delay (),
|
|
|
|
window_raise_with_delay_callback,
|
2013-10-16 04:19:33 +00:00
|
|
|
window, NULL);
|
2014-04-10 16:58:58 +00:00
|
|
|
g_source_set_name_by_id (display->autoraise_timeout_id, "[mutter] window_raise_with_delay_callback");
|
2004-10-04 21:09:08 +00:00
|
|
|
display->autoraise_window = window;
|
|
|
|
}
|
|
|
|
|
2014-03-11 17:45:39 +00:00
|
|
|
void
|
|
|
|
meta_display_sync_wayland_input_focus (MetaDisplay *display)
|
|
|
|
{
|
2014-08-14 00:19:35 +00:00
|
|
|
#ifdef HAVE_WAYLAND
|
2014-03-11 17:45:39 +00:00
|
|
|
MetaWaylandCompositor *compositor = meta_wayland_compositor_get_default ();
|
2014-03-25 15:27:09 +00:00
|
|
|
MetaWindow *focus_window = NULL;
|
2015-03-24 16:40:10 +00:00
|
|
|
MetaBackend *backend = meta_get_backend ();
|
|
|
|
MetaStage *stage = META_STAGE (meta_backend_get_stage (backend));
|
2017-08-26 20:24:21 +00:00
|
|
|
gboolean is_focus_xwindow = FALSE;
|
|
|
|
|
|
|
|
if (display->x11_display)
|
2017-08-26 18:51:28 +00:00
|
|
|
meta_x11_display_xwindow_is_a_no_focus_window (display->x11_display,
|
|
|
|
display->x11_display->focus_xwindow);
|
2014-03-11 17:45:39 +00:00
|
|
|
|
2014-08-15 17:12:22 +00:00
|
|
|
if (!meta_display_windows_are_interactable (display))
|
2014-03-11 17:45:39 +00:00
|
|
|
focus_window = NULL;
|
2017-08-26 18:51:28 +00:00
|
|
|
else if (is_focus_xwindow)
|
2014-03-11 17:45:39 +00:00
|
|
|
focus_window = NULL;
|
|
|
|
else if (display->focus_window && display->focus_window->surface)
|
|
|
|
focus_window = display->focus_window;
|
|
|
|
else
|
|
|
|
meta_topic (META_DEBUG_FOCUS, "Focus change has no effect, because there is no matching wayland surface");
|
|
|
|
|
2015-03-24 16:40:10 +00:00
|
|
|
meta_stage_set_active (stage, focus_window == NULL);
|
2014-03-11 17:45:39 +00:00
|
|
|
meta_wayland_compositor_set_input_focus (compositor, focus_window);
|
|
|
|
|
2014-04-17 22:46:14 +00:00
|
|
|
meta_wayland_seat_repick (compositor->seat);
|
2014-08-14 00:19:35 +00:00
|
|
|
#endif
|
2014-03-11 17:45:39 +00:00
|
|
|
}
|
|
|
|
|
2014-03-20 19:29:30 +00:00
|
|
|
void
|
|
|
|
meta_display_update_focus_window (MetaDisplay *display,
|
|
|
|
MetaWindow *window,
|
|
|
|
Window xwindow,
|
|
|
|
gulong serial,
|
|
|
|
gboolean focused_by_us)
|
2011-04-26 12:12:04 +00:00
|
|
|
{
|
2017-08-26 18:51:28 +00:00
|
|
|
display->x11_display->focus_serial = serial;
|
2013-12-16 21:01:04 +00:00
|
|
|
display->focused_by_us = focused_by_us;
|
2011-04-26 12:12:04 +00:00
|
|
|
|
2017-08-26 18:51:28 +00:00
|
|
|
if (display->x11_display->focus_xwindow == xwindow &&
|
2013-08-12 16:04:34 +00:00
|
|
|
display->focus_window == window)
|
2011-04-26 12:12:04 +00:00
|
|
|
return;
|
|
|
|
|
|
|
|
if (display->focus_window)
|
|
|
|
{
|
|
|
|
MetaWindow *previous;
|
|
|
|
|
|
|
|
meta_topic (META_DEBUG_FOCUS,
|
|
|
|
"%s is now the previous focus window due to being focused out or unmapped\n",
|
|
|
|
display->focus_window->desc);
|
|
|
|
|
|
|
|
/* Make sure that signals handlers invoked by
|
|
|
|
* meta_window_set_focused_internal() don't see
|
|
|
|
* display->focus_window->has_focus == FALSE
|
|
|
|
*/
|
|
|
|
previous = display->focus_window;
|
|
|
|
display->focus_window = NULL;
|
2017-08-26 18:51:28 +00:00
|
|
|
display->x11_display->focus_xwindow = None;
|
2011-04-26 12:12:04 +00:00
|
|
|
|
|
|
|
meta_window_set_focused_internal (previous, FALSE);
|
|
|
|
}
|
|
|
|
|
|
|
|
display->focus_window = window;
|
2017-08-26 18:51:28 +00:00
|
|
|
display->x11_display->focus_xwindow = xwindow;
|
2011-04-26 12:12:04 +00:00
|
|
|
|
|
|
|
if (display->focus_window)
|
|
|
|
{
|
|
|
|
meta_topic (META_DEBUG_FOCUS, "* Focus --> %s with serial %lu\n",
|
|
|
|
display->focus_window->desc, serial);
|
|
|
|
meta_window_set_focused_internal (display->focus_window, TRUE);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
meta_topic (META_DEBUG_FOCUS, "* Focus --> NULL with serial %lu\n", serial);
|
|
|
|
|
2013-08-12 16:04:34 +00:00
|
|
|
if (meta_is_wayland_compositor ())
|
2014-03-11 17:45:39 +00:00
|
|
|
meta_display_sync_wayland_input_focus (display);
|
2013-08-12 16:04:34 +00:00
|
|
|
|
2011-04-26 12:12:04 +00:00
|
|
|
g_object_notify (G_OBJECT (display), "focus-window");
|
2017-08-26 18:51:28 +00:00
|
|
|
meta_x11_display_update_active_window_hint (display->x11_display);
|
2011-04-26 12:12:04 +00:00
|
|
|
}
|
|
|
|
|
2014-03-20 20:06:24 +00:00
|
|
|
gboolean
|
|
|
|
meta_display_timestamp_too_old (MetaDisplay *display,
|
|
|
|
guint32 *timestamp)
|
2013-05-23 19:54:39 +00:00
|
|
|
{
|
|
|
|
/* FIXME: If Soeren's suggestion in bug 151984 is implemented, it will allow
|
|
|
|
* us to sanity check the timestamp here and ensure it doesn't correspond to
|
|
|
|
* a future time (though we would want to rename to
|
|
|
|
* timestamp_too_old_or_in_future).
|
|
|
|
*/
|
|
|
|
|
2017-08-26 20:24:21 +00:00
|
|
|
if (*timestamp == META_CURRENT_TIME)
|
2013-05-23 19:54:39 +00:00
|
|
|
{
|
|
|
|
*timestamp = meta_display_get_current_time_roundtrip (display);
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
else if (XSERVER_TIME_IS_BEFORE (*timestamp, display->last_focus_time))
|
|
|
|
{
|
|
|
|
if (XSERVER_TIME_IS_BEFORE (*timestamp, display->last_user_time))
|
|
|
|
return TRUE;
|
|
|
|
else
|
|
|
|
{
|
|
|
|
*timestamp = display->last_focus_time;
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2014-03-20 19:29:30 +00:00
|
|
|
void
|
|
|
|
meta_display_register_wayland_window (MetaDisplay *display,
|
|
|
|
MetaWindow *window)
|
2013-10-03 19:23:24 +00:00
|
|
|
{
|
2014-03-20 19:29:30 +00:00
|
|
|
g_hash_table_add (display->wayland_windows, window);
|
|
|
|
}
|
2013-10-03 19:23:24 +00:00
|
|
|
|
2014-03-20 19:29:30 +00:00
|
|
|
void
|
|
|
|
meta_display_unregister_wayland_window (MetaDisplay *display,
|
|
|
|
MetaWindow *window)
|
|
|
|
{
|
|
|
|
g_hash_table_remove (display->wayland_windows, window);
|
|
|
|
}
|
2013-10-03 19:23:24 +00:00
|
|
|
|
2014-09-09 01:20:14 +00:00
|
|
|
MetaWindow*
|
|
|
|
meta_display_lookup_stamp (MetaDisplay *display,
|
|
|
|
guint64 stamp)
|
|
|
|
{
|
|
|
|
return g_hash_table_lookup (display->stamps, &stamp);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_register_stamp (MetaDisplay *display,
|
|
|
|
guint64 *stampp,
|
|
|
|
MetaWindow *window)
|
|
|
|
{
|
|
|
|
g_return_if_fail (g_hash_table_lookup (display->stamps, stampp) == NULL);
|
|
|
|
|
|
|
|
g_hash_table_insert (display->stamps, stampp, window);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_unregister_stamp (MetaDisplay *display,
|
|
|
|
guint64 stamp)
|
|
|
|
{
|
|
|
|
g_return_if_fail (g_hash_table_lookup (display->stamps, &stamp) != NULL);
|
|
|
|
|
|
|
|
g_hash_table_remove (display->stamps, &stamp);
|
|
|
|
}
|
|
|
|
|
|
|
|
MetaWindow*
|
|
|
|
meta_display_lookup_stack_id (MetaDisplay *display,
|
|
|
|
guint64 stack_id)
|
|
|
|
{
|
|
|
|
if (META_STACK_ID_IS_X11 (stack_id))
|
2017-08-26 16:56:44 +00:00
|
|
|
return meta_x11_display_lookup_x_window (display->x11_display,
|
|
|
|
(Window)stack_id);
|
2014-09-09 01:20:14 +00:00
|
|
|
else
|
|
|
|
return meta_display_lookup_stamp (display, stack_id);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* We return a pointer into a ring of static buffers. This is to make
|
|
|
|
* using this function for debug-logging convenient and avoid tempory
|
|
|
|
* strings that must be freed. */
|
|
|
|
const char *
|
|
|
|
meta_display_describe_stack_id (MetaDisplay *display,
|
|
|
|
guint64 stack_id)
|
|
|
|
{
|
|
|
|
/* 0x<64-bit: 16 characters> (<10 characters of title>)\0' */
|
|
|
|
static char buffer[5][32];
|
|
|
|
MetaWindow *window;
|
|
|
|
static int pos = 0;
|
|
|
|
char *result;
|
|
|
|
|
|
|
|
result = buffer[pos];
|
|
|
|
pos = (pos + 1) % 5;
|
|
|
|
|
|
|
|
window = meta_display_lookup_stack_id (display, stack_id);
|
|
|
|
|
|
|
|
if (window && window->title)
|
|
|
|
snprintf (result, sizeof(buffer[0]), "%#" G_GINT64_MODIFIER "x (%.10s)", stack_id, window->title);
|
|
|
|
else
|
|
|
|
snprintf (result, sizeof(buffer[0]), "%#" G_GINT64_MODIFIER "x", stack_id);
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2014-03-20 19:29:30 +00:00
|
|
|
void
|
|
|
|
meta_display_notify_window_created (MetaDisplay *display,
|
|
|
|
MetaWindow *window)
|
|
|
|
{
|
|
|
|
g_signal_emit (display, display_signals[WINDOW_CREATED], 0, window);
|
|
|
|
}
|
2013-10-03 22:03:53 +00:00
|
|
|
|
2014-03-20 19:29:30 +00:00
|
|
|
static MetaCursor
|
|
|
|
meta_cursor_for_grab_op (MetaGrabOp op)
|
2013-10-03 19:29:44 +00:00
|
|
|
{
|
2014-03-20 19:29:30 +00:00
|
|
|
switch (op)
|
2001-07-26 03:14:45 +00:00
|
|
|
{
|
|
|
|
case META_GRAB_OP_RESIZING_SE:
|
Patch to provide extra cues to the user when using window menu move and
2002-08-08 Craig Black <blackc@speakeasy.net>
Patch to provide extra cues to the user when using
window menu move and resize, #85724.
* src/common.h: add new cursors
* src/display.c: (grab_op_is_mouse)
(meta_display_create_x_cursor), (xcursor_for_op),
(meta_display_set_grab_op_cursor),
(meta_display_begin_grab_op):
The keyboard move and resize grab ops now also use the mouse.
Allow the grab cursor to be changed during the grab op.
Hold onto the initial grab position in case of reset.
* src/display.h: save the initial grab position
* src/keybindings.c: (process_keyboard_move_grab),
(process_keyboard_resize_grab), (handle_begin_move),
(handle_begin_resize):
The keyboard move and resize grab ops now also use the mouse.
* src/window.c: (meta_window_client_message), (menu_callback),
(update_move), (update_resize),
(meta_window_handle_mouse_grab_op_event), (warp_pointer),
(meta_window_warp_pointer), (meta_window_begin_grab_op),
(meta_window_update_resize_grab_op):
When moving or resizing a window use the last grab position
in computing change increment.
Provide support for warping the mouse pointer.
* src/window.h: new warp pointer and grab op helper functions
2002-08-09 04:27:23 +00:00
|
|
|
case META_GRAB_OP_KEYBOARD_RESIZING_SE:
|
2013-11-19 00:34:04 +00:00
|
|
|
return META_CURSOR_SE_RESIZE;
|
2001-07-26 03:14:45 +00:00
|
|
|
break;
|
|
|
|
case META_GRAB_OP_RESIZING_S:
|
Patch to provide extra cues to the user when using window menu move and
2002-08-08 Craig Black <blackc@speakeasy.net>
Patch to provide extra cues to the user when using
window menu move and resize, #85724.
* src/common.h: add new cursors
* src/display.c: (grab_op_is_mouse)
(meta_display_create_x_cursor), (xcursor_for_op),
(meta_display_set_grab_op_cursor),
(meta_display_begin_grab_op):
The keyboard move and resize grab ops now also use the mouse.
Allow the grab cursor to be changed during the grab op.
Hold onto the initial grab position in case of reset.
* src/display.h: save the initial grab position
* src/keybindings.c: (process_keyboard_move_grab),
(process_keyboard_resize_grab), (handle_begin_move),
(handle_begin_resize):
The keyboard move and resize grab ops now also use the mouse.
* src/window.c: (meta_window_client_message), (menu_callback),
(update_move), (update_resize),
(meta_window_handle_mouse_grab_op_event), (warp_pointer),
(meta_window_warp_pointer), (meta_window_begin_grab_op),
(meta_window_update_resize_grab_op):
When moving or resizing a window use the last grab position
in computing change increment.
Provide support for warping the mouse pointer.
* src/window.h: new warp pointer and grab op helper functions
2002-08-09 04:27:23 +00:00
|
|
|
case META_GRAB_OP_KEYBOARD_RESIZING_S:
|
2013-11-19 00:34:04 +00:00
|
|
|
return META_CURSOR_SOUTH_RESIZE;
|
2001-07-26 03:14:45 +00:00
|
|
|
break;
|
|
|
|
case META_GRAB_OP_RESIZING_SW:
|
Patch to provide extra cues to the user when using window menu move and
2002-08-08 Craig Black <blackc@speakeasy.net>
Patch to provide extra cues to the user when using
window menu move and resize, #85724.
* src/common.h: add new cursors
* src/display.c: (grab_op_is_mouse)
(meta_display_create_x_cursor), (xcursor_for_op),
(meta_display_set_grab_op_cursor),
(meta_display_begin_grab_op):
The keyboard move and resize grab ops now also use the mouse.
Allow the grab cursor to be changed during the grab op.
Hold onto the initial grab position in case of reset.
* src/display.h: save the initial grab position
* src/keybindings.c: (process_keyboard_move_grab),
(process_keyboard_resize_grab), (handle_begin_move),
(handle_begin_resize):
The keyboard move and resize grab ops now also use the mouse.
* src/window.c: (meta_window_client_message), (menu_callback),
(update_move), (update_resize),
(meta_window_handle_mouse_grab_op_event), (warp_pointer),
(meta_window_warp_pointer), (meta_window_begin_grab_op),
(meta_window_update_resize_grab_op):
When moving or resizing a window use the last grab position
in computing change increment.
Provide support for warping the mouse pointer.
* src/window.h: new warp pointer and grab op helper functions
2002-08-09 04:27:23 +00:00
|
|
|
case META_GRAB_OP_KEYBOARD_RESIZING_SW:
|
2013-11-19 00:34:04 +00:00
|
|
|
return META_CURSOR_SW_RESIZE;
|
2001-07-26 03:14:45 +00:00
|
|
|
break;
|
|
|
|
case META_GRAB_OP_RESIZING_N:
|
Patch to provide extra cues to the user when using window menu move and
2002-08-08 Craig Black <blackc@speakeasy.net>
Patch to provide extra cues to the user when using
window menu move and resize, #85724.
* src/common.h: add new cursors
* src/display.c: (grab_op_is_mouse)
(meta_display_create_x_cursor), (xcursor_for_op),
(meta_display_set_grab_op_cursor),
(meta_display_begin_grab_op):
The keyboard move and resize grab ops now also use the mouse.
Allow the grab cursor to be changed during the grab op.
Hold onto the initial grab position in case of reset.
* src/display.h: save the initial grab position
* src/keybindings.c: (process_keyboard_move_grab),
(process_keyboard_resize_grab), (handle_begin_move),
(handle_begin_resize):
The keyboard move and resize grab ops now also use the mouse.
* src/window.c: (meta_window_client_message), (menu_callback),
(update_move), (update_resize),
(meta_window_handle_mouse_grab_op_event), (warp_pointer),
(meta_window_warp_pointer), (meta_window_begin_grab_op),
(meta_window_update_resize_grab_op):
When moving or resizing a window use the last grab position
in computing change increment.
Provide support for warping the mouse pointer.
* src/window.h: new warp pointer and grab op helper functions
2002-08-09 04:27:23 +00:00
|
|
|
case META_GRAB_OP_KEYBOARD_RESIZING_N:
|
2013-11-19 00:34:04 +00:00
|
|
|
return META_CURSOR_NORTH_RESIZE;
|
2001-07-26 03:14:45 +00:00
|
|
|
break;
|
|
|
|
case META_GRAB_OP_RESIZING_NE:
|
Patch to provide extra cues to the user when using window menu move and
2002-08-08 Craig Black <blackc@speakeasy.net>
Patch to provide extra cues to the user when using
window menu move and resize, #85724.
* src/common.h: add new cursors
* src/display.c: (grab_op_is_mouse)
(meta_display_create_x_cursor), (xcursor_for_op),
(meta_display_set_grab_op_cursor),
(meta_display_begin_grab_op):
The keyboard move and resize grab ops now also use the mouse.
Allow the grab cursor to be changed during the grab op.
Hold onto the initial grab position in case of reset.
* src/display.h: save the initial grab position
* src/keybindings.c: (process_keyboard_move_grab),
(process_keyboard_resize_grab), (handle_begin_move),
(handle_begin_resize):
The keyboard move and resize grab ops now also use the mouse.
* src/window.c: (meta_window_client_message), (menu_callback),
(update_move), (update_resize),
(meta_window_handle_mouse_grab_op_event), (warp_pointer),
(meta_window_warp_pointer), (meta_window_begin_grab_op),
(meta_window_update_resize_grab_op):
When moving or resizing a window use the last grab position
in computing change increment.
Provide support for warping the mouse pointer.
* src/window.h: new warp pointer and grab op helper functions
2002-08-09 04:27:23 +00:00
|
|
|
case META_GRAB_OP_KEYBOARD_RESIZING_NE:
|
2013-11-19 00:34:04 +00:00
|
|
|
return META_CURSOR_NE_RESIZE;
|
2001-07-26 03:14:45 +00:00
|
|
|
break;
|
|
|
|
case META_GRAB_OP_RESIZING_NW:
|
Patch to provide extra cues to the user when using window menu move and
2002-08-08 Craig Black <blackc@speakeasy.net>
Patch to provide extra cues to the user when using
window menu move and resize, #85724.
* src/common.h: add new cursors
* src/display.c: (grab_op_is_mouse)
(meta_display_create_x_cursor), (xcursor_for_op),
(meta_display_set_grab_op_cursor),
(meta_display_begin_grab_op):
The keyboard move and resize grab ops now also use the mouse.
Allow the grab cursor to be changed during the grab op.
Hold onto the initial grab position in case of reset.
* src/display.h: save the initial grab position
* src/keybindings.c: (process_keyboard_move_grab),
(process_keyboard_resize_grab), (handle_begin_move),
(handle_begin_resize):
The keyboard move and resize grab ops now also use the mouse.
* src/window.c: (meta_window_client_message), (menu_callback),
(update_move), (update_resize),
(meta_window_handle_mouse_grab_op_event), (warp_pointer),
(meta_window_warp_pointer), (meta_window_begin_grab_op),
(meta_window_update_resize_grab_op):
When moving or resizing a window use the last grab position
in computing change increment.
Provide support for warping the mouse pointer.
* src/window.h: new warp pointer and grab op helper functions
2002-08-09 04:27:23 +00:00
|
|
|
case META_GRAB_OP_KEYBOARD_RESIZING_NW:
|
2013-11-19 00:34:04 +00:00
|
|
|
return META_CURSOR_NW_RESIZE;
|
2001-07-26 03:14:45 +00:00
|
|
|
break;
|
|
|
|
case META_GRAB_OP_RESIZING_W:
|
Patch to provide extra cues to the user when using window menu move and
2002-08-08 Craig Black <blackc@speakeasy.net>
Patch to provide extra cues to the user when using
window menu move and resize, #85724.
* src/common.h: add new cursors
* src/display.c: (grab_op_is_mouse)
(meta_display_create_x_cursor), (xcursor_for_op),
(meta_display_set_grab_op_cursor),
(meta_display_begin_grab_op):
The keyboard move and resize grab ops now also use the mouse.
Allow the grab cursor to be changed during the grab op.
Hold onto the initial grab position in case of reset.
* src/display.h: save the initial grab position
* src/keybindings.c: (process_keyboard_move_grab),
(process_keyboard_resize_grab), (handle_begin_move),
(handle_begin_resize):
The keyboard move and resize grab ops now also use the mouse.
* src/window.c: (meta_window_client_message), (menu_callback),
(update_move), (update_resize),
(meta_window_handle_mouse_grab_op_event), (warp_pointer),
(meta_window_warp_pointer), (meta_window_begin_grab_op),
(meta_window_update_resize_grab_op):
When moving or resizing a window use the last grab position
in computing change increment.
Provide support for warping the mouse pointer.
* src/window.h: new warp pointer and grab op helper functions
2002-08-09 04:27:23 +00:00
|
|
|
case META_GRAB_OP_KEYBOARD_RESIZING_W:
|
2013-11-19 00:34:04 +00:00
|
|
|
return META_CURSOR_WEST_RESIZE;
|
2001-07-26 03:14:45 +00:00
|
|
|
break;
|
|
|
|
case META_GRAB_OP_RESIZING_E:
|
Patch to provide extra cues to the user when using window menu move and
2002-08-08 Craig Black <blackc@speakeasy.net>
Patch to provide extra cues to the user when using
window menu move and resize, #85724.
* src/common.h: add new cursors
* src/display.c: (grab_op_is_mouse)
(meta_display_create_x_cursor), (xcursor_for_op),
(meta_display_set_grab_op_cursor),
(meta_display_begin_grab_op):
The keyboard move and resize grab ops now also use the mouse.
Allow the grab cursor to be changed during the grab op.
Hold onto the initial grab position in case of reset.
* src/display.h: save the initial grab position
* src/keybindings.c: (process_keyboard_move_grab),
(process_keyboard_resize_grab), (handle_begin_move),
(handle_begin_resize):
The keyboard move and resize grab ops now also use the mouse.
* src/window.c: (meta_window_client_message), (menu_callback),
(update_move), (update_resize),
(meta_window_handle_mouse_grab_op_event), (warp_pointer),
(meta_window_warp_pointer), (meta_window_begin_grab_op),
(meta_window_update_resize_grab_op):
When moving or resizing a window use the last grab position
in computing change increment.
Provide support for warping the mouse pointer.
* src/window.h: new warp pointer and grab op helper functions
2002-08-09 04:27:23 +00:00
|
|
|
case META_GRAB_OP_KEYBOARD_RESIZING_E:
|
2013-11-19 00:34:04 +00:00
|
|
|
return META_CURSOR_EAST_RESIZE;
|
2001-07-26 03:14:45 +00:00
|
|
|
break;
|
2003-08-16 14:36:56 +00:00
|
|
|
case META_GRAB_OP_MOVING:
|
Patch to provide extra cues to the user when using window menu move and
2002-08-08 Craig Black <blackc@speakeasy.net>
Patch to provide extra cues to the user when using
window menu move and resize, #85724.
* src/common.h: add new cursors
* src/display.c: (grab_op_is_mouse)
(meta_display_create_x_cursor), (xcursor_for_op),
(meta_display_set_grab_op_cursor),
(meta_display_begin_grab_op):
The keyboard move and resize grab ops now also use the mouse.
Allow the grab cursor to be changed during the grab op.
Hold onto the initial grab position in case of reset.
* src/display.h: save the initial grab position
* src/keybindings.c: (process_keyboard_move_grab),
(process_keyboard_resize_grab), (handle_begin_move),
(handle_begin_resize):
The keyboard move and resize grab ops now also use the mouse.
* src/window.c: (meta_window_client_message), (menu_callback),
(update_move), (update_resize),
(meta_window_handle_mouse_grab_op_event), (warp_pointer),
(meta_window_warp_pointer), (meta_window_begin_grab_op),
(meta_window_update_resize_grab_op):
When moving or resizing a window use the last grab position
in computing change increment.
Provide support for warping the mouse pointer.
* src/window.h: new warp pointer and grab op helper functions
2002-08-09 04:27:23 +00:00
|
|
|
case META_GRAB_OP_KEYBOARD_MOVING:
|
|
|
|
case META_GRAB_OP_KEYBOARD_RESIZING_UNKNOWN:
|
2013-11-19 00:34:04 +00:00
|
|
|
return META_CURSOR_MOVE_OR_RESIZE_WINDOW;
|
Patch to provide extra cues to the user when using window menu move and
2002-08-08 Craig Black <blackc@speakeasy.net>
Patch to provide extra cues to the user when using
window menu move and resize, #85724.
* src/common.h: add new cursors
* src/display.c: (grab_op_is_mouse)
(meta_display_create_x_cursor), (xcursor_for_op),
(meta_display_set_grab_op_cursor),
(meta_display_begin_grab_op):
The keyboard move and resize grab ops now also use the mouse.
Allow the grab cursor to be changed during the grab op.
Hold onto the initial grab position in case of reset.
* src/display.h: save the initial grab position
* src/keybindings.c: (process_keyboard_move_grab),
(process_keyboard_resize_grab), (handle_begin_move),
(handle_begin_resize):
The keyboard move and resize grab ops now also use the mouse.
* src/window.c: (meta_window_client_message), (menu_callback),
(update_move), (update_resize),
(meta_window_handle_mouse_grab_op_event), (warp_pointer),
(meta_window_warp_pointer), (meta_window_begin_grab_op),
(meta_window_update_resize_grab_op):
When moving or resizing a window use the last grab position
in computing change increment.
Provide support for warping the mouse pointer.
* src/window.h: new warp pointer and grab op helper functions
2002-08-09 04:27:23 +00:00
|
|
|
break;
|
2001-07-26 03:14:45 +00:00
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2013-11-19 00:34:04 +00:00
|
|
|
return META_CURSOR_DEFAULT;
|
2001-07-26 03:14:45 +00:00
|
|
|
}
|
|
|
|
|
2017-08-26 16:37:29 +00:00
|
|
|
static int
|
|
|
|
find_highest_logical_monitor_scale (MetaBackend *backend,
|
|
|
|
MetaCursorSprite *cursor_sprite)
|
|
|
|
{
|
|
|
|
MetaMonitorManager *monitor_manager =
|
|
|
|
meta_backend_get_monitor_manager (backend);
|
|
|
|
MetaCursorRenderer *cursor_renderer =
|
|
|
|
meta_backend_get_cursor_renderer (backend);
|
|
|
|
ClutterRect cursor_rect;
|
|
|
|
GList *logical_monitors;
|
|
|
|
GList *l;
|
|
|
|
int highest_scale = 0.0;
|
|
|
|
|
|
|
|
cursor_rect = meta_cursor_renderer_calculate_rect (cursor_renderer,
|
|
|
|
cursor_sprite);
|
|
|
|
|
|
|
|
logical_monitors =
|
|
|
|
meta_monitor_manager_get_logical_monitors (monitor_manager);
|
|
|
|
for (l = logical_monitors; l; l = l->next)
|
|
|
|
{
|
|
|
|
MetaLogicalMonitor *logical_monitor = l->data;
|
|
|
|
ClutterRect logical_monitor_rect =
|
|
|
|
meta_rectangle_to_clutter_rect (&logical_monitor->rect);
|
|
|
|
|
|
|
|
if (!clutter_rect_intersection (&cursor_rect,
|
|
|
|
&logical_monitor_rect,
|
|
|
|
NULL))
|
|
|
|
continue;
|
|
|
|
|
|
|
|
highest_scale = MAX (highest_scale, logical_monitor->scale);
|
|
|
|
}
|
|
|
|
|
|
|
|
return highest_scale;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
root_cursor_prepare_at (MetaCursorSpriteXcursor *sprite_xcursor,
|
|
|
|
int x,
|
|
|
|
int y,
|
|
|
|
MetaDisplay *display)
|
|
|
|
{
|
|
|
|
MetaCursorSprite *cursor_sprite = META_CURSOR_SPRITE (sprite_xcursor);
|
|
|
|
MetaBackend *backend = meta_get_backend ();
|
|
|
|
|
|
|
|
if (meta_is_stage_views_scaled ())
|
|
|
|
{
|
|
|
|
int scale;
|
|
|
|
|
|
|
|
scale = find_highest_logical_monitor_scale (backend, cursor_sprite);
|
|
|
|
if (scale != 0.0)
|
|
|
|
{
|
|
|
|
meta_cursor_sprite_xcursor_set_theme_scale (sprite_xcursor, scale);
|
|
|
|
meta_cursor_sprite_set_texture_scale (cursor_sprite, 1.0 / scale);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
MetaMonitorManager *monitor_manager =
|
|
|
|
meta_backend_get_monitor_manager (backend);
|
|
|
|
MetaLogicalMonitor *logical_monitor;
|
|
|
|
|
|
|
|
logical_monitor =
|
|
|
|
meta_monitor_manager_get_logical_monitor_at (monitor_manager, x, y);
|
|
|
|
|
|
|
|
/* Reload the cursor texture if the scale has changed. */
|
|
|
|
if (logical_monitor)
|
|
|
|
{
|
|
|
|
meta_cursor_sprite_xcursor_set_theme_scale (sprite_xcursor,
|
|
|
|
logical_monitor->scale);
|
|
|
|
meta_cursor_sprite_set_texture_scale (cursor_sprite, 1.0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
manage_root_cursor_sprite_scale (MetaDisplay *display,
|
|
|
|
MetaCursorSpriteXcursor *sprite_xcursor)
|
|
|
|
{
|
|
|
|
g_signal_connect_object (sprite_xcursor,
|
|
|
|
"prepare-at",
|
|
|
|
G_CALLBACK (root_cursor_prepare_at),
|
|
|
|
display,
|
|
|
|
0);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_reload_cursor (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
MetaCursor cursor = display->current_cursor;
|
|
|
|
MetaCursorSpriteXcursor *sprite_xcursor;
|
|
|
|
MetaBackend *backend = meta_get_backend ();
|
|
|
|
MetaCursorTracker *cursor_tracker = meta_backend_get_cursor_tracker (backend);
|
|
|
|
|
|
|
|
sprite_xcursor = meta_cursor_sprite_xcursor_new (cursor);
|
|
|
|
|
|
|
|
if (meta_is_wayland_compositor ())
|
|
|
|
manage_root_cursor_sprite_scale (display, sprite_xcursor);
|
|
|
|
|
|
|
|
meta_cursor_tracker_set_root_cursor (cursor_tracker,
|
|
|
|
META_CURSOR_SPRITE (sprite_xcursor));
|
|
|
|
g_object_unref (sprite_xcursor);
|
|
|
|
|
|
|
|
g_signal_emit (display, display_signals[CURSOR_UPDATED], 0, display);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_set_cursor (MetaDisplay *display,
|
|
|
|
MetaCursor cursor)
|
|
|
|
{
|
|
|
|
if (cursor == display->current_cursor)
|
|
|
|
return;
|
|
|
|
|
|
|
|
display->current_cursor = cursor;
|
|
|
|
meta_display_reload_cursor (display);
|
|
|
|
}
|
|
|
|
|
Patch to provide extra cues to the user when using window menu move and
2002-08-08 Craig Black <blackc@speakeasy.net>
Patch to provide extra cues to the user when using
window menu move and resize, #85724.
* src/common.h: add new cursors
* src/display.c: (grab_op_is_mouse)
(meta_display_create_x_cursor), (xcursor_for_op),
(meta_display_set_grab_op_cursor),
(meta_display_begin_grab_op):
The keyboard move and resize grab ops now also use the mouse.
Allow the grab cursor to be changed during the grab op.
Hold onto the initial grab position in case of reset.
* src/display.h: save the initial grab position
* src/keybindings.c: (process_keyboard_move_grab),
(process_keyboard_resize_grab), (handle_begin_move),
(handle_begin_resize):
The keyboard move and resize grab ops now also use the mouse.
* src/window.c: (meta_window_client_message), (menu_callback),
(update_move), (update_resize),
(meta_window_handle_mouse_grab_op_event), (warp_pointer),
(meta_window_warp_pointer), (meta_window_begin_grab_op),
(meta_window_update_resize_grab_op):
When moving or resizing a window use the last grab position
in computing change increment.
Provide support for warping the mouse pointer.
* src/window.h: new warp pointer and grab op helper functions
2002-08-09 04:27:23 +00:00
|
|
|
void
|
2014-05-14 13:16:20 +00:00
|
|
|
meta_display_update_cursor (MetaDisplay *display)
|
Patch to provide extra cues to the user when using window menu move and
2002-08-08 Craig Black <blackc@speakeasy.net>
Patch to provide extra cues to the user when using
window menu move and resize, #85724.
* src/common.h: add new cursors
* src/display.c: (grab_op_is_mouse)
(meta_display_create_x_cursor), (xcursor_for_op),
(meta_display_set_grab_op_cursor),
(meta_display_begin_grab_op):
The keyboard move and resize grab ops now also use the mouse.
Allow the grab cursor to be changed during the grab op.
Hold onto the initial grab position in case of reset.
* src/display.h: save the initial grab position
* src/keybindings.c: (process_keyboard_move_grab),
(process_keyboard_resize_grab), (handle_begin_move),
(handle_begin_resize):
The keyboard move and resize grab ops now also use the mouse.
* src/window.c: (meta_window_client_message), (menu_callback),
(update_move), (update_resize),
(meta_window_handle_mouse_grab_op_event), (warp_pointer),
(meta_window_warp_pointer), (meta_window_begin_grab_op),
(meta_window_update_resize_grab_op):
When moving or resizing a window use the last grab position
in computing change increment.
Provide support for warping the mouse pointer.
* src/window.h: new warp pointer and grab op helper functions
2002-08-09 04:27:23 +00:00
|
|
|
{
|
2017-08-26 16:37:29 +00:00
|
|
|
meta_display_set_cursor (display, meta_cursor_for_grab_op (display->grab_op));
|
Patch to provide extra cues to the user when using window menu move and
2002-08-08 Craig Black <blackc@speakeasy.net>
Patch to provide extra cues to the user when using
window menu move and resize, #85724.
* src/common.h: add new cursors
* src/display.c: (grab_op_is_mouse)
(meta_display_create_x_cursor), (xcursor_for_op),
(meta_display_set_grab_op_cursor),
(meta_display_begin_grab_op):
The keyboard move and resize grab ops now also use the mouse.
Allow the grab cursor to be changed during the grab op.
Hold onto the initial grab position in case of reset.
* src/display.h: save the initial grab position
* src/keybindings.c: (process_keyboard_move_grab),
(process_keyboard_resize_grab), (handle_begin_move),
(handle_begin_resize):
The keyboard move and resize grab ops now also use the mouse.
* src/window.c: (meta_window_client_message), (menu_callback),
(update_move), (update_resize),
(meta_window_handle_mouse_grab_op_event), (warp_pointer),
(meta_window_warp_pointer), (meta_window_begin_grab_op),
(meta_window_update_resize_grab_op):
When moving or resizing a window use the last grab position
in computing change increment.
Provide support for warping the mouse pointer.
* src/window.h: new warp pointer and grab op helper functions
2002-08-09 04:27:23 +00:00
|
|
|
}
|
|
|
|
|
2014-04-28 21:23:20 +00:00
|
|
|
static MetaWindow *
|
2014-06-11 20:36:17 +00:00
|
|
|
get_first_freefloating_window (MetaWindow *window)
|
2014-04-28 21:23:20 +00:00
|
|
|
{
|
2014-06-11 20:36:17 +00:00
|
|
|
while (meta_window_is_attached_dialog (window))
|
|
|
|
window = meta_window_get_transient_for (window);
|
|
|
|
|
|
|
|
/* Attached dialogs should always have a non-NULL transient-for */
|
|
|
|
g_assert (window != NULL);
|
|
|
|
|
|
|
|
return window;
|
2014-04-28 21:23:20 +00:00
|
|
|
}
|
|
|
|
|
2014-08-15 17:12:22 +00:00
|
|
|
static MetaEventRoute
|
|
|
|
get_event_route_from_grab_op (MetaGrabOp op)
|
|
|
|
{
|
2014-08-15 18:05:04 +00:00
|
|
|
switch (GRAB_OP_GET_BASE_TYPE (op))
|
2014-08-15 17:12:22 +00:00
|
|
|
{
|
|
|
|
case META_GRAB_OP_NONE:
|
|
|
|
/* begin_grab_op shouldn't be called with META_GRAB_OP_NONE. */
|
|
|
|
g_assert_not_reached ();
|
|
|
|
|
2014-08-15 18:05:04 +00:00
|
|
|
case META_GRAB_OP_WINDOW_BASE:
|
2014-08-15 17:12:22 +00:00
|
|
|
return META_EVENT_ROUTE_WINDOW_OP;
|
|
|
|
|
|
|
|
case META_GRAB_OP_COMPOSITOR:
|
|
|
|
/* begin_grab_op shouldn't be called with META_GRAB_OP_COMPOSITOR. */
|
|
|
|
g_assert_not_reached ();
|
|
|
|
|
|
|
|
case META_GRAB_OP_WAYLAND_POPUP:
|
|
|
|
return META_EVENT_ROUTE_WAYLAND_POPUP;
|
|
|
|
|
2015-01-19 19:27:27 +00:00
|
|
|
case META_GRAB_OP_FRAME_BUTTON:
|
|
|
|
return META_EVENT_ROUTE_FRAME_BUTTON;
|
|
|
|
|
2014-08-15 17:12:22 +00:00
|
|
|
default:
|
|
|
|
g_assert_not_reached ();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2001-07-11 06:22:00 +00:00
|
|
|
gboolean
|
|
|
|
meta_display_begin_grab_op (MetaDisplay *display,
|
|
|
|
MetaWindow *window,
|
|
|
|
MetaGrabOp op,
|
|
|
|
gboolean pointer_already_grabbed,
|
2006-10-13 00:28:34 +00:00
|
|
|
gboolean frame_action,
|
2001-07-11 06:22:00 +00:00
|
|
|
int button,
|
2014-04-07 21:22:55 +00:00
|
|
|
gulong modmask, /* XXX - ignored */
|
Fix issues on 64-bit machines with timestamps by using guint32 (like gtk+
2006-09-13 Elijah Newren <newren gmail com>
* src/common.h (MetaWindowMenuFunc):
* src/core.[ch] (meta_core_user_lower_and_unfocus,
meta_core_user_focus, meta_core_show_window_menu,
meta_core_begin_grab_op, meta_core_end_grab_op):
* src/delete.c (delete_ping_reply_func, delete_ping_timeout_func,
meta_window_delete):
* src/display.[ch] (struct MetaDisplay, struct MetaPingData,
sanity_check_timestamps, meta_display_open, event_callback,
meta_spew_event, meta_display_set_grab_op_cursor,
meta_display_begin_grab_op, meta_display_end_grab_op,
meta_display_ping_timeout, meta_display_ping_window,
process_pong_message, timestamp_too_old,
meta_display_set_input_focus_window):
* src/keybindings.[ch] (grab_keyboard, ungrab_keyboard,
meta_screen_grab_all_keys, meta_window_grab_all_keys,
meta_window_ungrab_all_keys, error_on_generic_command,
error_on_command, error_on_terminal_command):
* src/metacity-dialog.c (on_realize, warn_about_no_sm_support,
error_about_command, main):
* src/screen.[ch] (struct _MetaScreen, meta_screen_new,
meta_screen_show_desktop, meta_screen_apply_startup_properties):
* src/session.c (warn_about_lame_clients_and_finish_interact):
* src/window.[ch] (struct _MetaWindow,
intervening_user_event_occurred, window_activate,
meta_window_delete, meta_window_focus,
meta_window_send_icccm_message, meta_window_client_message,
menu_callback, meta_window_show_menu, struct EventScannerData,
check_use_this_motion_notify, meta_window_begin_grab_op,
meta_window_set_user_time):
* src/workspace.[ch] (focus_ancestor_or_mru_window,
meta_workspace_activate_with_focus, meta_workspace_activate,
meta_workspace_focus_default_window,
focus_ancestor_or_mru_window):
Fix issues on 64-bit machines with timestamps by using guint32
(like gtk+ does) instead of Time. #348305
2006-09-13 16:32:33 +00:00
|
|
|
guint32 timestamp,
|
2001-07-11 06:22:00 +00:00
|
|
|
int root_x,
|
|
|
|
int root_y)
|
|
|
|
{
|
2014-05-14 13:16:20 +00:00
|
|
|
MetaBackend *backend = meta_get_backend ();
|
2011-01-04 16:42:51 +00:00
|
|
|
MetaWindow *grab_window = NULL;
|
2014-08-15 17:12:22 +00:00
|
|
|
MetaEventRoute event_route;
|
2014-04-28 21:11:47 +00:00
|
|
|
|
2014-05-02 13:36:10 +00:00
|
|
|
g_assert (window != NULL);
|
|
|
|
|
2002-02-24 19:58:27 +00:00
|
|
|
meta_topic (META_DEBUG_WINDOW_OPS,
|
2006-01-20 22:03:56 +00:00
|
|
|
"Doing grab op %u on window %s button %d pointer already grabbed: %d pointer pos %d,%d\n",
|
2014-05-02 13:36:10 +00:00
|
|
|
op, window->desc, button, pointer_already_grabbed,
|
2003-10-12 06:25:38 +00:00
|
|
|
root_x, root_y);
|
2014-04-24 14:42:18 +00:00
|
|
|
|
2001-07-11 06:22:00 +00:00
|
|
|
if (display->grab_op != META_GRAB_OP_NONE)
|
|
|
|
{
|
2014-05-02 13:36:10 +00:00
|
|
|
meta_warning ("Attempt to perform window operation %u on window %s when operation %u on %s already in effect\n",
|
|
|
|
op, window->desc, display->grab_op,
|
|
|
|
display->grab_window ? display->grab_window->desc : "none");
|
2001-07-11 06:22:00 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
2001-07-26 03:14:45 +00:00
|
|
|
|
2014-08-15 17:12:22 +00:00
|
|
|
event_route = get_event_route_from_grab_op (op);
|
|
|
|
|
|
|
|
if (event_route == META_EVENT_ROUTE_WINDOW_OP)
|
Add a raise on click option, basically only because all the major distros
2006-01-10 Elijah Newren <newren@gmail.com>
Add a raise on click option, basically only because all the major
distros are patching it in anyway. See #326156.
* src/metacity.schemas.in: add the new gconf key and explanation
* src/prefs.[ch] (#define KEY_RAISE_ON_CLICK, static gboolean
raise_on_click, update_raise_on_click, meta_prefs_init,
change_notify, meta_prefs_get_raise_on_click,
meta_preference_to_string):
Add all the normal preference handling stuff for this new
raise-on-click option.
* src/core.c (meta_core_show_window_menu):
* src/display.c (event_callback, meta_display_begin_grab_op):
* src/window.c (window_activate, meta_window_configure_request, ):
Only raise the window if in raise_on_click mode.
* src/display.c (meta_display_begin_grab_op,
meta_display_end_grab_op, meta_display_check_threshold_reached):
* src/display.h (struct MetaDisplay):
* src/window.c (meta_window_handle_mouse_grab_op_event):
if not in raise-on-click mode only raise on button release if the
click didn't start a move or resize operation; needs a few extra
MetaDisplay fields to handle this
* src/core.c (meta_core_user_lower_and_unfocus):
no need to do the MRU shuffling if not maintaining the stacking
order == MRU order invariant
* src/frames.c (meta_frames_button_press_event):
* src/window.c (meta_window_begin_grab_op):
remove an unneeded window raising that is already handled elsewhere
2006-01-10 19:35:03 +00:00
|
|
|
{
|
|
|
|
if (meta_prefs_get_raise_on_click ())
|
|
|
|
meta_window_raise (window);
|
|
|
|
else
|
|
|
|
{
|
|
|
|
display->grab_initial_x = root_x;
|
|
|
|
display->grab_initial_y = root_y;
|
|
|
|
display->grab_threshold_movement_reached = FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-04-28 21:23:20 +00:00
|
|
|
grab_window = window;
|
|
|
|
|
2014-06-11 20:36:17 +00:00
|
|
|
/* If we're trying to move a window, move the first
|
|
|
|
* non-attached dialog instead.
|
2011-01-04 16:42:51 +00:00
|
|
|
*/
|
2014-06-11 20:36:17 +00:00
|
|
|
if (meta_grab_op_is_moving (op))
|
|
|
|
grab_window = get_first_freefloating_window (window);
|
2011-01-04 16:42:51 +00:00
|
|
|
|
2014-04-28 21:12:39 +00:00
|
|
|
g_assert (grab_window != NULL);
|
|
|
|
g_assert (op != META_GRAB_OP_NONE);
|
|
|
|
|
2003-10-11 04:27:06 +00:00
|
|
|
display->grab_have_pointer = FALSE;
|
2014-04-23 14:38:30 +00:00
|
|
|
|
2001-07-11 06:22:00 +00:00
|
|
|
if (pointer_already_grabbed)
|
2001-07-26 03:14:45 +00:00
|
|
|
display->grab_have_pointer = TRUE;
|
2014-04-23 14:53:06 +00:00
|
|
|
|
2014-04-24 14:42:18 +00:00
|
|
|
/* Since grab operations often happen as a result of implicit
|
|
|
|
* pointer operations on the display X11 connection, we need
|
|
|
|
* to ungrab here to ensure that the backend's X11 can take
|
|
|
|
* the device grab. */
|
2017-08-26 16:26:30 +00:00
|
|
|
XIUngrabDevice (display->x11_display->xdisplay,
|
2014-04-24 14:42:18 +00:00
|
|
|
META_VIRTUAL_CORE_POINTER_ID,
|
|
|
|
timestamp);
|
2017-08-26 16:26:30 +00:00
|
|
|
XSync (display->x11_display->xdisplay, False);
|
2014-04-24 14:42:18 +00:00
|
|
|
|
2014-05-14 13:16:20 +00:00
|
|
|
if (meta_backend_grab_device (backend, META_VIRTUAL_CORE_POINTER_ID, timestamp))
|
|
|
|
display->grab_have_pointer = TRUE;
|
2001-07-11 06:22:00 +00:00
|
|
|
|
2014-03-20 19:29:30 +00:00
|
|
|
if (!display->grab_have_pointer && !meta_grab_op_is_keyboard (op))
|
2001-07-11 06:22:00 +00:00
|
|
|
{
|
2014-04-23 14:50:07 +00:00
|
|
|
meta_topic (META_DEBUG_WINDOW_OPS, "XIGrabDevice() failed\n");
|
2001-07-11 06:22:00 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
2001-08-19 18:09:10 +00:00
|
|
|
|
2014-08-15 17:12:22 +00:00
|
|
|
/* Grab keys when beginning window ops; see #126497 */
|
|
|
|
if (event_route == META_EVENT_ROUTE_WINDOW_OP)
|
2001-07-11 06:22:00 +00:00
|
|
|
{
|
2014-04-28 21:12:39 +00:00
|
|
|
display->grab_have_keyboard = meta_window_grab_all_keys (grab_window, timestamp);
|
2014-04-23 14:50:07 +00:00
|
|
|
|
2001-07-11 06:22:00 +00:00
|
|
|
if (!display->grab_have_keyboard)
|
|
|
|
{
|
2014-04-23 14:50:07 +00:00
|
|
|
meta_topic (META_DEBUG_WINDOW_OPS, "grabbing all keys failed, ungrabbing pointer\n");
|
|
|
|
meta_backend_ungrab_device (backend, META_VIRTUAL_CORE_POINTER_ID, timestamp);
|
Partial audit to fix timestamp usage. One step towards fixing #355180; see
2006-09-18 Elijah Newren <newren gmail com>
Partial audit to fix timestamp usage. One step towards fixing
#355180; see important comments in that bug.
* src/core.[ch] (meta_core_unshade, meta_core_shade):
* src/delete.c (meta_window_present_delete_dialog,
delete_ping_timeout_func):
* src/display.[ch] (meta_display_open, meta_display_close,
event_callback, meta_display_begin_grab_op,
process_selection_clear, meta_display_unmanage_screen,
meta_display_unmanage_windows_for_screen):
* src/frames.c (meta_frames_button_press_event):
* src/keybindings.c (handle_toggle_shade):
* src/main.c (main):
* src/screen.[ch] (update_num_workspaces, meta_screen_new,
meta_screen_free, prefs_changed_callback):
* src/window.[ch] (meta_window_free, finish_minimize,
implement_showing, meta_window_show, meta_window_maximize,
meta_window_make_fullscreen_internal,
meta_window_unmake_fullscreen, meta_window_shade,
meta_window_unshade, window_activate, send_sync_request,
meta_window_client_message, menu_callback,
meta_window_update_keyboard_resize):
Remove usage of CurrentTime, meta_display_get_current_time() and
meta_display_get_current_time_roundtrip() where possible, or
document why it isn't possible, or at very least add a FIXME with
some explanation of my laziness and what needs to be done.
2006-09-18 17:27:24 +00:00
|
|
|
display->grab_have_pointer = FALSE;
|
2001-07-11 06:22:00 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
}
|
2014-04-28 21:11:47 +00:00
|
|
|
|
2014-08-15 17:12:22 +00:00
|
|
|
display->event_route = event_route;
|
2001-07-11 06:22:00 +00:00
|
|
|
display->grab_op = op;
|
2011-01-04 16:42:51 +00:00
|
|
|
display->grab_window = grab_window;
|
2001-07-11 06:22:00 +00:00
|
|
|
display->grab_button = button;
|
2016-01-10 14:16:09 +00:00
|
|
|
display->grab_tile_mode = grab_window->tile_mode;
|
|
|
|
display->grab_tile_monitor_number = grab_window->tile_monitor_number;
|
2003-10-12 06:25:38 +00:00
|
|
|
display->grab_anchor_root_x = root_x;
|
|
|
|
display->grab_anchor_root_y = root_y;
|
2002-12-10 03:23:04 +00:00
|
|
|
display->grab_latest_motion_x = root_x;
|
|
|
|
display->grab_latest_motion_y = root_y;
|
2002-08-10 05:27:17 +00:00
|
|
|
display->grab_last_moveresize_time.tv_sec = 0;
|
|
|
|
display->grab_last_moveresize_time.tv_usec = 0;
|
Merge of all the changes on the constraints_experiments branch. This is
2005-11-18 Elijah Newren <newren@gmail.com>
Merge of all the changes on the constraints_experiments branch.
This is just a summary, to get the full ChangeLog of those
changes (approx. 2000 lines):
cvs -q -z3 update -Pd -r constraints_experiments
cvs -q -z3 diff -pu -r CONSTRAINTS_EXPERIMENTS_BRANCHPOINT ChangeLog
Bugs fixed:
unfiled - constraints.c is overly complicated[1]
unfiled - constraints.c is not robust when all constraints
cannot simultaneously be met (constraints need to be
prioritized)
unfiled - keep-titlebar-onscreen constraint is decoration
unaware (since get_outermost_onscreen_positions()
forgets to include decorations)
unfiled - keyboard snap-moving and snap-resizing snap to hidden
edges
109553 - gravity w/ simultaneous move & resize doesn't work
113601 - maximize vertical and horizontal should toggle and be
constrained
122196 - windows show up under vertical panels
122670 - jerky/random resizing of window via keyboard[2]
124582 - keyboard and mouse snap-resizing and snap-moving
erroneously moves the window multidimensionally
136307 - don't allow apps to resize themselves off the screen
(*cough* filechooser *cough*)
142016, 143784 - windows should not span multiple xineramas
unless placed there by the user
143145 - clamp new windows to screensize and force them
onscreen, if they'll fit
144126 - Handle pathological strut lists sanely[3]
149867 - fixed aspect ratio windows are difficult to resize[4]
152898 - make screen edges consistent; allow easy slamming of
windows into the left, right, and bottom edges of the
screen too.
154706 - bouncing weirdness at screen edge with keyboard moving
or resizing
156699 - avoid struts when placing windows, if possible (nasty
a11y blocker)
302456 - dragging offscreen too restrictive
304857 - wireframe moving off the top of the screen is misleading
308521 - make uni-directional resizing easier with
alt-middle-drag and prevent the occasional super
annoying resize-the-wrong-side(s) behavior
312007 - snap-resize moves windows with a minimum size
constraint
312104 - resizing the top of a window can cause the bottom to
grow
319351 - don't instantly snap on mouse-move-snapping, remove
braindeadedness of having order of releasing shift and
releasing button press matter so much
[1] fixed in my opinion, anyway.
[2] Actually, it's not totally fixed--it's just annoying
instead of almost completely unusable. Matthias had a
suggestion that may fix the remainder of the problems (see
http://tinyurl.com/bwzuu).
[3] This bug was originally about not-quite-so-pathological
cases but was left open for the worse cases. The code from
the branch handles the remainder of the cases mentioned in
this bug.
[4] Actually, although it's far better there's still some minor
issues left: a slight drift that's only noticeable after
lots of resizing, and potential problems with partially
onscreen constraints due to not clearing any
fixed_directions flags (aspect ratio windows get resized in
both directions and thus aren't fixed in one of them)
New feature:
81704 - edge resistance for user move and resize operations;
in particular 3 different kinds of resistance are
implemented:
Pixel-Distance: window movement is resisted when it
aligns with an edge unless the movement is greater than
a threshold number of pixels
Timeout: window movement past an edge is prevented until
a certain amount of time has elapsed during the
operation since the first request to move it past that
edge
Keyboard-Buildup: when moving or resizing with the
keyboard, once a window is aligned with a certain edge
it cannot move past until the correct direction has
been pressed enough times (e.g. 2 or 3 times)
Major changes:
- constraints.c has been rewritten; very few lines of code from
the old version remain. There is a comment near the top of
the function explaining the basics of how the new framework
works. A more detailed explanation can be found in
doc/how-constraints-works.txt
- edge-resistance.[ch] are new files implementing edge-resistance.
- boxes.[ch] are new files containing low-level error-prone
functions used heavily in constraints.c and edge-resistance.c,
among various places throughout the code. testboxes.c
contains a thorough testsuite for the boxes.[ch] functions
compiled into a program, testboxes.
- meta_window_move_resize_internal() *must* be told the gravity
of the associated operation (if it's just a move operation,
the gravity will be ignored, but for resize and move+resize
the correct value is needed)
- the craziness of different values that
meta_window_move_resize_internal() accepts has been documented
in a large comment at the beginning of the function. It may
be possible to clean this up some, but until then things will
remain as they were before--caller beware.
- screen and xinerama usable areas (i.e. places not covered by
e.g. panels) are cached in the workspace now, as are the
screen and xinerama edges. These get updated with the
workarea in src/workspace.c:ensure_work_areas_validated()
2005-11-19 14:58:50 +00:00
|
|
|
display->grab_last_user_action_was_snap = FALSE;
|
2006-10-13 00:28:34 +00:00
|
|
|
display->grab_frame_action = frame_action;
|
|
|
|
|
2014-05-14 13:16:20 +00:00
|
|
|
meta_display_update_cursor (display);
|
|
|
|
|
Fix bug 143333, support for update counter spec, and 109362, schedule
Sat Jun 19 02:21:08 2004 Soeren Sandmann <sandmann@daimi.au.dk>
Fix bug 143333, support for update counter spec, and 109362,
schedule compensation events when events are ignored.
* src/display.c (meta_display_open): Add _NET_WM_SYNC_REQUEST and
_NET_WM_SYNC_REQUEST_COUNTER atoms. Remove the old
METACITY_SYNC_COUNTER stuff.
(meta_display_begin_op): Setup the sync counter
* src/xprops.c, src/xprops.h, src/window-props.c, src/display.h:
Add new atoms.
* src/window.c (send_sync_request): new function.
(meta_window_move_resize_internal): send a sync request before
resizing.
(check_move_resize_frequence): Rework logic to also check the SYNC
case. If an event is ignored return the remaining time.
(update_resize_timeout): Timeout that gets called when a
compensation event is scheduled.
(uddate_resize): schedule compensation events when an event is
ignored.
(meta_window_handle_mouse_grap_op_event): When an alarm is
received and sync was turned off, turn it back on.
* src/window.h (struct MetaWindow) Add some variables
2004-06-19 00:45:24 +00:00
|
|
|
if (display->grab_resize_timeout_id)
|
|
|
|
{
|
|
|
|
g_source_remove (display->grab_resize_timeout_id);
|
|
|
|
display->grab_resize_timeout_id = 0;
|
|
|
|
}
|
2014-04-28 21:11:47 +00:00
|
|
|
|
2002-02-24 19:58:27 +00:00
|
|
|
meta_topic (META_DEBUG_WINDOW_OPS,
|
2006-01-20 22:03:56 +00:00
|
|
|
"Grab op %u on window %s successful\n",
|
2002-06-27 05:08:32 +00:00
|
|
|
display->grab_op, window ? window->desc : "(null)");
|
2001-07-11 06:22:00 +00:00
|
|
|
|
2014-05-20 21:47:10 +00:00
|
|
|
meta_window_get_frame_rect (display->grab_window,
|
|
|
|
&display->grab_initial_window_pos);
|
|
|
|
display->grab_anchor_window_pos = display->grab_initial_window_pos;
|
2014-04-28 21:12:39 +00:00
|
|
|
|
2014-03-11 17:45:39 +00:00
|
|
|
if (meta_is_wayland_compositor ())
|
2014-07-22 00:07:19 +00:00
|
|
|
{
|
|
|
|
meta_display_sync_wayland_input_focus (display);
|
|
|
|
meta_display_cancel_touch (display);
|
|
|
|
}
|
2014-03-11 17:45:39 +00:00
|
|
|
|
2012-02-10 15:27:14 +00:00
|
|
|
g_signal_emit (display, display_signals[GRAB_OP_BEGIN], 0,
|
2017-08-26 19:43:17 +00:00
|
|
|
display, display->grab_window, display->grab_op);
|
2014-04-28 21:11:47 +00:00
|
|
|
|
2014-08-15 17:12:22 +00:00
|
|
|
if (display->event_route == META_EVENT_ROUTE_WINDOW_OP)
|
|
|
|
meta_window_grab_op_began (display->grab_window, display->grab_op);
|
2014-04-29 19:30:21 +00:00
|
|
|
|
2001-07-11 06:22:00 +00:00
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_end_grab_op (MetaDisplay *display,
|
Fix issues on 64-bit machines with timestamps by using guint32 (like gtk+
2006-09-13 Elijah Newren <newren gmail com>
* src/common.h (MetaWindowMenuFunc):
* src/core.[ch] (meta_core_user_lower_and_unfocus,
meta_core_user_focus, meta_core_show_window_menu,
meta_core_begin_grab_op, meta_core_end_grab_op):
* src/delete.c (delete_ping_reply_func, delete_ping_timeout_func,
meta_window_delete):
* src/display.[ch] (struct MetaDisplay, struct MetaPingData,
sanity_check_timestamps, meta_display_open, event_callback,
meta_spew_event, meta_display_set_grab_op_cursor,
meta_display_begin_grab_op, meta_display_end_grab_op,
meta_display_ping_timeout, meta_display_ping_window,
process_pong_message, timestamp_too_old,
meta_display_set_input_focus_window):
* src/keybindings.[ch] (grab_keyboard, ungrab_keyboard,
meta_screen_grab_all_keys, meta_window_grab_all_keys,
meta_window_ungrab_all_keys, error_on_generic_command,
error_on_command, error_on_terminal_command):
* src/metacity-dialog.c (on_realize, warn_about_no_sm_support,
error_about_command, main):
* src/screen.[ch] (struct _MetaScreen, meta_screen_new,
meta_screen_show_desktop, meta_screen_apply_startup_properties):
* src/session.c (warn_about_lame_clients_and_finish_interact):
* src/window.[ch] (struct _MetaWindow,
intervening_user_event_occurred, window_activate,
meta_window_delete, meta_window_focus,
meta_window_send_icccm_message, meta_window_client_message,
menu_callback, meta_window_show_menu, struct EventScannerData,
check_use_this_motion_notify, meta_window_begin_grab_op,
meta_window_set_user_time):
* src/workspace.[ch] (focus_ancestor_or_mru_window,
meta_workspace_activate_with_focus, meta_workspace_activate,
meta_workspace_focus_default_window,
focus_ancestor_or_mru_window):
Fix issues on 64-bit machines with timestamps by using guint32
(like gtk+ does) instead of Time. #348305
2006-09-13 16:32:33 +00:00
|
|
|
guint32 timestamp)
|
2001-07-11 06:22:00 +00:00
|
|
|
{
|
2014-07-17 19:51:42 +00:00
|
|
|
MetaWindow *grab_window = display->grab_window;
|
|
|
|
MetaGrabOp grab_op = display->grab_op;
|
|
|
|
|
2003-01-21 22:40:25 +00:00
|
|
|
meta_topic (META_DEBUG_WINDOW_OPS,
|
2014-07-17 19:51:42 +00:00
|
|
|
"Ending grab op %u at time %u\n", grab_op, timestamp);
|
2014-04-22 15:27:52 +00:00
|
|
|
|
2015-10-07 01:10:13 +00:00
|
|
|
if (display->event_route == META_EVENT_ROUTE_NORMAL ||
|
|
|
|
display->event_route == META_EVENT_ROUTE_COMPOSITOR_GRAB)
|
2001-07-11 06:22:00 +00:00
|
|
|
return;
|
2001-08-19 18:09:10 +00:00
|
|
|
|
2015-10-07 01:10:13 +00:00
|
|
|
g_assert (grab_window != NULL);
|
|
|
|
|
2012-02-10 15:27:14 +00:00
|
|
|
g_signal_emit (display, display_signals[GRAB_OP_END], 0,
|
2017-08-26 19:43:17 +00:00
|
|
|
display, grab_window, grab_op);
|
2014-04-29 19:30:21 +00:00
|
|
|
|
2014-11-26 23:39:12 +00:00
|
|
|
/* We need to reset this early, since the
|
|
|
|
* meta_window_grab_op_ended callback relies on this being
|
|
|
|
* up to date. */
|
|
|
|
display->grab_op = META_GRAB_OP_NONE;
|
|
|
|
|
2014-08-15 17:12:22 +00:00
|
|
|
if (display->event_route == META_EVENT_ROUTE_WINDOW_OP)
|
Add a raise on click option, basically only because all the major distros
2006-01-10 Elijah Newren <newren@gmail.com>
Add a raise on click option, basically only because all the major
distros are patching it in anyway. See #326156.
* src/metacity.schemas.in: add the new gconf key and explanation
* src/prefs.[ch] (#define KEY_RAISE_ON_CLICK, static gboolean
raise_on_click, update_raise_on_click, meta_prefs_init,
change_notify, meta_prefs_get_raise_on_click,
meta_preference_to_string):
Add all the normal preference handling stuff for this new
raise-on-click option.
* src/core.c (meta_core_show_window_menu):
* src/display.c (event_callback, meta_display_begin_grab_op):
* src/window.c (window_activate, meta_window_configure_request, ):
Only raise the window if in raise_on_click mode.
* src/display.c (meta_display_begin_grab_op,
meta_display_end_grab_op, meta_display_check_threshold_reached):
* src/display.h (struct MetaDisplay):
* src/window.c (meta_window_handle_mouse_grab_op_event):
if not in raise-on-click mode only raise on button release if the
click didn't start a move or resize operation; needs a few extra
MetaDisplay fields to handle this
* src/core.c (meta_core_user_lower_and_unfocus):
no need to do the MRU shuffling if not maintaining the stacking
order == MRU order invariant
* src/frames.c (meta_frames_button_press_event):
* src/window.c (meta_window_begin_grab_op):
remove an unneeded window raising that is already handled elsewhere
2006-01-10 19:35:03 +00:00
|
|
|
{
|
2014-04-20 17:04:32 +00:00
|
|
|
/* Clear out the edge cache */
|
|
|
|
meta_display_cleanup_edges (display);
|
|
|
|
|
Add a raise on click option, basically only because all the major distros
2006-01-10 Elijah Newren <newren@gmail.com>
Add a raise on click option, basically only because all the major
distros are patching it in anyway. See #326156.
* src/metacity.schemas.in: add the new gconf key and explanation
* src/prefs.[ch] (#define KEY_RAISE_ON_CLICK, static gboolean
raise_on_click, update_raise_on_click, meta_prefs_init,
change_notify, meta_prefs_get_raise_on_click,
meta_preference_to_string):
Add all the normal preference handling stuff for this new
raise-on-click option.
* src/core.c (meta_core_show_window_menu):
* src/display.c (event_callback, meta_display_begin_grab_op):
* src/window.c (window_activate, meta_window_configure_request, ):
Only raise the window if in raise_on_click mode.
* src/display.c (meta_display_begin_grab_op,
meta_display_end_grab_op, meta_display_check_threshold_reached):
* src/display.h (struct MetaDisplay):
* src/window.c (meta_window_handle_mouse_grab_op_event):
if not in raise-on-click mode only raise on button release if the
click didn't start a move or resize operation; needs a few extra
MetaDisplay fields to handle this
* src/core.c (meta_core_user_lower_and_unfocus):
no need to do the MRU shuffling if not maintaining the stacking
order == MRU order invariant
* src/frames.c (meta_frames_button_press_event):
* src/window.c (meta_window_begin_grab_op):
remove an unneeded window raising that is already handled elsewhere
2006-01-10 19:35:03 +00:00
|
|
|
/* Only raise the window in orthogonal raise
|
|
|
|
* ('do-not-raise-on-click') mode if the user didn't try to move
|
|
|
|
* or resize the given window by at least a threshold amount.
|
|
|
|
* For raise on click mode, the window was raised at the
|
|
|
|
* beginning of the grab_op.
|
|
|
|
*/
|
2014-04-20 17:04:32 +00:00
|
|
|
if (!meta_prefs_get_raise_on_click () &&
|
2014-10-15 05:19:57 +00:00
|
|
|
!display->grab_threshold_movement_reached)
|
Add a raise on click option, basically only because all the major distros
2006-01-10 Elijah Newren <newren@gmail.com>
Add a raise on click option, basically only because all the major
distros are patching it in anyway. See #326156.
* src/metacity.schemas.in: add the new gconf key and explanation
* src/prefs.[ch] (#define KEY_RAISE_ON_CLICK, static gboolean
raise_on_click, update_raise_on_click, meta_prefs_init,
change_notify, meta_prefs_get_raise_on_click,
meta_preference_to_string):
Add all the normal preference handling stuff for this new
raise-on-click option.
* src/core.c (meta_core_show_window_menu):
* src/display.c (event_callback, meta_display_begin_grab_op):
* src/window.c (window_activate, meta_window_configure_request, ):
Only raise the window if in raise_on_click mode.
* src/display.c (meta_display_begin_grab_op,
meta_display_end_grab_op, meta_display_check_threshold_reached):
* src/display.h (struct MetaDisplay):
* src/window.c (meta_window_handle_mouse_grab_op_event):
if not in raise-on-click mode only raise on button release if the
click didn't start a move or resize operation; needs a few extra
MetaDisplay fields to handle this
* src/core.c (meta_core_user_lower_and_unfocus):
no need to do the MRU shuffling if not maintaining the stacking
order == MRU order invariant
* src/frames.c (meta_frames_button_press_event):
* src/window.c (meta_window_begin_grab_op):
remove an unneeded window raising that is already handled elsewhere
2006-01-10 19:35:03 +00:00
|
|
|
meta_window_raise (display->grab_window);
|
2014-08-15 17:12:22 +00:00
|
|
|
|
|
|
|
meta_window_grab_op_ended (grab_window, grab_op);
|
Add a raise on click option, basically only because all the major distros
2006-01-10 Elijah Newren <newren@gmail.com>
Add a raise on click option, basically only because all the major
distros are patching it in anyway. See #326156.
* src/metacity.schemas.in: add the new gconf key and explanation
* src/prefs.[ch] (#define KEY_RAISE_ON_CLICK, static gboolean
raise_on_click, update_raise_on_click, meta_prefs_init,
change_notify, meta_prefs_get_raise_on_click,
meta_preference_to_string):
Add all the normal preference handling stuff for this new
raise-on-click option.
* src/core.c (meta_core_show_window_menu):
* src/display.c (event_callback, meta_display_begin_grab_op):
* src/window.c (window_activate, meta_window_configure_request, ):
Only raise the window if in raise_on_click mode.
* src/display.c (meta_display_begin_grab_op,
meta_display_end_grab_op, meta_display_check_threshold_reached):
* src/display.h (struct MetaDisplay):
* src/window.c (meta_window_handle_mouse_grab_op_event):
if not in raise-on-click mode only raise on button release if the
click didn't start a move or resize operation; needs a few extra
MetaDisplay fields to handle this
* src/core.c (meta_core_user_lower_and_unfocus):
no need to do the MRU shuffling if not maintaining the stacking
order == MRU order invariant
* src/frames.c (meta_frames_button_press_event):
* src/window.c (meta_window_begin_grab_op):
remove an unneeded window raising that is already handled elsewhere
2006-01-10 19:35:03 +00:00
|
|
|
}
|
2014-04-20 17:00:33 +00:00
|
|
|
|
2001-07-11 06:22:00 +00:00
|
|
|
if (display->grab_have_pointer)
|
2002-03-02 15:26:07 +00:00
|
|
|
{
|
2014-04-23 14:50:07 +00:00
|
|
|
MetaBackend *backend = meta_get_backend ();
|
|
|
|
meta_backend_ungrab_device (backend, META_VIRTUAL_CORE_POINTER_ID, timestamp);
|
2002-03-02 15:26:07 +00:00
|
|
|
}
|
2001-07-11 06:22:00 +00:00
|
|
|
|
|
|
|
if (display->grab_have_keyboard)
|
2002-03-02 15:26:07 +00:00
|
|
|
{
|
|
|
|
meta_topic (META_DEBUG_WINDOW_OPS,
|
Fix issues on 64-bit machines with timestamps by using guint32 (like gtk+
2006-09-13 Elijah Newren <newren gmail com>
* src/common.h (MetaWindowMenuFunc):
* src/core.[ch] (meta_core_user_lower_and_unfocus,
meta_core_user_focus, meta_core_show_window_menu,
meta_core_begin_grab_op, meta_core_end_grab_op):
* src/delete.c (delete_ping_reply_func, delete_ping_timeout_func,
meta_window_delete):
* src/display.[ch] (struct MetaDisplay, struct MetaPingData,
sanity_check_timestamps, meta_display_open, event_callback,
meta_spew_event, meta_display_set_grab_op_cursor,
meta_display_begin_grab_op, meta_display_end_grab_op,
meta_display_ping_timeout, meta_display_ping_window,
process_pong_message, timestamp_too_old,
meta_display_set_input_focus_window):
* src/keybindings.[ch] (grab_keyboard, ungrab_keyboard,
meta_screen_grab_all_keys, meta_window_grab_all_keys,
meta_window_ungrab_all_keys, error_on_generic_command,
error_on_command, error_on_terminal_command):
* src/metacity-dialog.c (on_realize, warn_about_no_sm_support,
error_about_command, main):
* src/screen.[ch] (struct _MetaScreen, meta_screen_new,
meta_screen_show_desktop, meta_screen_apply_startup_properties):
* src/session.c (warn_about_lame_clients_and_finish_interact):
* src/window.[ch] (struct _MetaWindow,
intervening_user_event_occurred, window_activate,
meta_window_delete, meta_window_focus,
meta_window_send_icccm_message, meta_window_client_message,
menu_callback, meta_window_show_menu, struct EventScannerData,
check_use_this_motion_notify, meta_window_begin_grab_op,
meta_window_set_user_time):
* src/workspace.[ch] (focus_ancestor_or_mru_window,
meta_workspace_activate_with_focus, meta_workspace_activate,
meta_workspace_focus_default_window,
focus_ancestor_or_mru_window):
Fix issues on 64-bit machines with timestamps by using guint32
(like gtk+ does) instead of Time. #348305
2006-09-13 16:32:33 +00:00
|
|
|
"Ungrabbing all keys timestamp %u\n", timestamp);
|
2014-07-17 19:51:42 +00:00
|
|
|
meta_window_ungrab_all_keys (grab_window, timestamp);
|
2002-03-02 15:26:07 +00:00
|
|
|
}
|
2002-12-10 03:23:04 +00:00
|
|
|
|
2014-08-15 17:12:22 +00:00
|
|
|
display->event_route = META_EVENT_ROUTE_NORMAL;
|
2001-07-11 06:22:00 +00:00
|
|
|
display->grab_window = NULL;
|
2016-01-10 14:16:09 +00:00
|
|
|
display->grab_tile_mode = META_TILE_NONE;
|
|
|
|
display->grab_tile_monitor_number = -1;
|
2002-03-17 17:22:23 +00:00
|
|
|
|
2014-05-14 13:16:20 +00:00
|
|
|
meta_display_update_cursor (display);
|
|
|
|
|
Fix bug 143333, support for update counter spec, and 109362, schedule
Sat Jun 19 02:21:08 2004 Soeren Sandmann <sandmann@daimi.au.dk>
Fix bug 143333, support for update counter spec, and 109362,
schedule compensation events when events are ignored.
* src/display.c (meta_display_open): Add _NET_WM_SYNC_REQUEST and
_NET_WM_SYNC_REQUEST_COUNTER atoms. Remove the old
METACITY_SYNC_COUNTER stuff.
(meta_display_begin_op): Setup the sync counter
* src/xprops.c, src/xprops.h, src/window-props.c, src/display.h:
Add new atoms.
* src/window.c (send_sync_request): new function.
(meta_window_move_resize_internal): send a sync request before
resizing.
(check_move_resize_frequence): Rework logic to also check the SYNC
case. If an event is ignored return the remaining time.
(update_resize_timeout): Timeout that gets called when a
compensation event is scheduled.
(uddate_resize): schedule compensation events when an event is
ignored.
(meta_window_handle_mouse_grap_op_event): When an alarm is
received and sync was turned off, turn it back on.
* src/window.h (struct MetaWindow) Add some variables
2004-06-19 00:45:24 +00:00
|
|
|
if (display->grab_resize_timeout_id)
|
|
|
|
{
|
|
|
|
g_source_remove (display->grab_resize_timeout_id);
|
|
|
|
display->grab_resize_timeout_id = 0;
|
|
|
|
}
|
2014-03-11 17:45:39 +00:00
|
|
|
|
|
|
|
if (meta_is_wayland_compositor ())
|
|
|
|
meta_display_sync_wayland_input_focus (display);
|
2001-07-26 03:14:45 +00:00
|
|
|
}
|
|
|
|
|
2009-08-28 15:25:51 +00:00
|
|
|
/**
|
|
|
|
* meta_display_get_grab_op:
|
2013-02-15 18:42:08 +00:00
|
|
|
* @display: The #MetaDisplay that the window is on
|
|
|
|
|
2009-08-28 15:25:51 +00:00
|
|
|
* Gets the current grab operation, if any.
|
|
|
|
*
|
|
|
|
* Return value: the current grab operation, or %META_GRAB_OP_NONE if
|
|
|
|
* Mutter doesn't currently have a grab. %META_GRAB_OP_COMPOSITOR will
|
|
|
|
* be returned if a compositor-plugin modal operation is in effect
|
|
|
|
* (See mutter_begin_modal_for_plugin())
|
|
|
|
*/
|
|
|
|
MetaGrabOp
|
|
|
|
meta_display_get_grab_op (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
return display->grab_op;
|
|
|
|
}
|
|
|
|
|
Add a raise on click option, basically only because all the major distros
2006-01-10 Elijah Newren <newren@gmail.com>
Add a raise on click option, basically only because all the major
distros are patching it in anyway. See #326156.
* src/metacity.schemas.in: add the new gconf key and explanation
* src/prefs.[ch] (#define KEY_RAISE_ON_CLICK, static gboolean
raise_on_click, update_raise_on_click, meta_prefs_init,
change_notify, meta_prefs_get_raise_on_click,
meta_preference_to_string):
Add all the normal preference handling stuff for this new
raise-on-click option.
* src/core.c (meta_core_show_window_menu):
* src/display.c (event_callback, meta_display_begin_grab_op):
* src/window.c (window_activate, meta_window_configure_request, ):
Only raise the window if in raise_on_click mode.
* src/display.c (meta_display_begin_grab_op,
meta_display_end_grab_op, meta_display_check_threshold_reached):
* src/display.h (struct MetaDisplay):
* src/window.c (meta_window_handle_mouse_grab_op_event):
if not in raise-on-click mode only raise on button release if the
click didn't start a move or resize operation; needs a few extra
MetaDisplay fields to handle this
* src/core.c (meta_core_user_lower_and_unfocus):
no need to do the MRU shuffling if not maintaining the stacking
order == MRU order invariant
* src/frames.c (meta_frames_button_press_event):
* src/window.c (meta_window_begin_grab_op):
remove an unneeded window raising that is already handled elsewhere
2006-01-10 19:35:03 +00:00
|
|
|
void
|
|
|
|
meta_display_check_threshold_reached (MetaDisplay *display,
|
|
|
|
int x,
|
|
|
|
int y)
|
|
|
|
{
|
|
|
|
/* Don't bother doing the check again if we've already reached the threshold */
|
2006-01-24 01:07:41 +00:00
|
|
|
if (meta_prefs_get_raise_on_click () ||
|
|
|
|
display->grab_threshold_movement_reached)
|
Add a raise on click option, basically only because all the major distros
2006-01-10 Elijah Newren <newren@gmail.com>
Add a raise on click option, basically only because all the major
distros are patching it in anyway. See #326156.
* src/metacity.schemas.in: add the new gconf key and explanation
* src/prefs.[ch] (#define KEY_RAISE_ON_CLICK, static gboolean
raise_on_click, update_raise_on_click, meta_prefs_init,
change_notify, meta_prefs_get_raise_on_click,
meta_preference_to_string):
Add all the normal preference handling stuff for this new
raise-on-click option.
* src/core.c (meta_core_show_window_menu):
* src/display.c (event_callback, meta_display_begin_grab_op):
* src/window.c (window_activate, meta_window_configure_request, ):
Only raise the window if in raise_on_click mode.
* src/display.c (meta_display_begin_grab_op,
meta_display_end_grab_op, meta_display_check_threshold_reached):
* src/display.h (struct MetaDisplay):
* src/window.c (meta_window_handle_mouse_grab_op_event):
if not in raise-on-click mode only raise on button release if the
click didn't start a move or resize operation; needs a few extra
MetaDisplay fields to handle this
* src/core.c (meta_core_user_lower_and_unfocus):
no need to do the MRU shuffling if not maintaining the stacking
order == MRU order invariant
* src/frames.c (meta_frames_button_press_event):
* src/window.c (meta_window_begin_grab_op):
remove an unneeded window raising that is already handled elsewhere
2006-01-10 19:35:03 +00:00
|
|
|
return;
|
|
|
|
|
|
|
|
if (ABS (display->grab_initial_x - x) >= 8 ||
|
|
|
|
ABS (display->grab_initial_y - y) >= 8)
|
|
|
|
display->grab_threshold_movement_reached = TRUE;
|
|
|
|
}
|
|
|
|
|
2002-02-07 03:25:34 +00:00
|
|
|
void
|
|
|
|
meta_display_queue_retheme_all_windows (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
GSList* windows;
|
|
|
|
GSList *tmp;
|
|
|
|
|
2009-06-15 19:32:23 +00:00
|
|
|
windows = meta_display_list_windows (display, META_LIST_DEFAULT);
|
2002-02-07 03:25:34 +00:00
|
|
|
tmp = windows;
|
|
|
|
while (tmp != NULL)
|
|
|
|
{
|
|
|
|
MetaWindow *window = tmp->data;
|
2014-05-02 13:34:02 +00:00
|
|
|
|
Refactor thrice-duplicated queue code in window.c. Closes #376760.
2007-06-10 Thomas Thurman <thomas@thurman.org.uk>
Refactor thrice-duplicated queue code in window.c. Closes #376760.
* src/window.c (meta_window_queue, meta_window_unqueue):
New functions.
* src/window.[ch] (meta_window_unqueue_*, meta_window_queue_*):
Removed functions.
* src/window.c (meta_window_new_with_attrs, meta_window_free,
meta_window_flush_calc_showing, queue_calc_showing_func,
meta_window_minimize, meta_window_unminimize, meta_window_maximize,
meta_window_make_fullscreen, meta_window_shade,
meta_window_unshade, meta_window_move_resize_internal,
window_stick_impl, window_unstick_impl,
meta_window_client_message, process_property_notify): Modified to
use new queueing functions.
* src/window.c (idle_move_resize, idle_update_icon,
idle_calc_showing): update to receive queue number from pointer.
* src/window.h (MetaQueueType): new enum.
* src/window.h (MetaWindow): *_queued replaced with is_in_queue
bitfield.
* src/core.c (meta_core_queue_frame_resize):
* src/display.c (event_callback,
meta_display_queue_retheme_all_windows): Using new queueing functions.
* src/frame.c (meta_window_destroy_frame): Using new queueing functions.
* src/screen.c (queue_resize, meta_screen_resize_func,
queue_windows_showing): Using new queueing functions.
* src/window-props.c (reload_mwm_hints, reload_wm_hints,
reload_transient_for): Using new queueing functions.
* src/workspace.c (meta_workspace_add_window,
meta_workspace_remove_window, meta_workspace_queue_calc_showing,
meta_workspace_invalidate_work_area): Using new queueing functions.
svn path=/trunk/; revision=3236
2007-06-11 01:15:33 +00:00
|
|
|
meta_window_queue (window, META_QUEUE_MOVE_RESIZE);
|
2013-11-15 22:37:50 +00:00
|
|
|
meta_window_frame_size_changed (window);
|
2002-02-07 03:25:34 +00:00
|
|
|
if (window->frame)
|
2002-05-31 00:02:54 +00:00
|
|
|
{
|
|
|
|
meta_frame_queue_draw (window->frame);
|
2003-01-05 07:51:02 +00:00
|
|
|
}
|
2014-05-02 13:34:02 +00:00
|
|
|
|
2002-02-07 03:25:34 +00:00
|
|
|
tmp = tmp->next;
|
|
|
|
}
|
|
|
|
|
|
|
|
g_slist_free (windows);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_retheme_all (void)
|
|
|
|
{
|
MetaDisplay becomes a singleton. The static variable which holds this
2008-03-25 Thomas Thurman <tthurman@gnome.org>
* src/core/display.c (meta_display_queue_retheme_all_windows,
meta_set_syncing, meta_display_set_cursor_theme, disable_compositor,
meta_display_for_x_display, meta_display_open, meta_display_close,
meta_display_ungrab): MetaDisplay becomes a singleton. The static
variable which holds this singleton is renamed "the_display" so as
not to mask the this parameter in the methods.
* src/core/main.c (main):
* src/core/session.c (warn_about_lame_clients_and_finish_inte,
save_state, io_from_warning_dialog):
* src/core/core.c (meta_core_increment_event_serial):
* src/core/delete.c (release_window_with_fd, search_and_destroy_window):
sympathy changes for this, and consequent simplification.
Closes #499301.
svn path=/trunk/; revision=3663
2008-03-25 03:39:13 +00:00
|
|
|
meta_display_queue_retheme_all_windows (meta_get_display ());
|
2002-02-07 03:25:34 +00:00
|
|
|
}
|
|
|
|
|
2011-11-02 15:34:45 +00:00
|
|
|
/*
|
2008-01-13 01:01:21 +00:00
|
|
|
* Stores whether syncing is currently enabled.
|
2008-01-06 21:23:33 +00:00
|
|
|
*/
|
2002-01-28 02:09:12 +00:00
|
|
|
static gboolean is_syncing = FALSE;
|
|
|
|
|
2008-01-13 01:01:21 +00:00
|
|
|
/**
|
2011-11-02 15:34:45 +00:00
|
|
|
* meta_is_syncing:
|
2008-01-06 21:23:33 +00:00
|
|
|
*
|
2011-11-02 15:34:45 +00:00
|
|
|
* Returns whether X synchronisation is currently enabled.
|
2008-01-06 21:23:33 +00:00
|
|
|
*
|
2011-11-02 15:34:45 +00:00
|
|
|
* FIXME: This is *only* called by meta_display_open(), but by that time
|
2008-01-06 21:23:33 +00:00
|
|
|
* we have already turned syncing on or off on startup, and we don't
|
Comprehensively rename to Mutter
Code:
All references in the code not related to themes, keybindings, or
GConf were changed from 'metacity' to 'mutter'. This includes, among other
things, strings, comments, the atoms used in the message protocol, and
the envvars used for debugging. The GConf schema file was reduced to
the 3 settings new to mutter.
The overall version was brought up to 2.27 to match current gnome.
Structure:
All files named '*metacity*' were renamed '*mutter*' with appropriate
changes in the automake system. Files removed are
doc/creating_themes, src/themes, doc/metacity-theme.dtd,
metacity.doap. These files will eventually end up in an external
gnome-wm-data module.
Installation location:
On the filesystem the mutter-plugindir was change from
$(libdir)/metacity/plugins/clutter to just $(libdir)/mutter/plugins.
The mutter-plugins.pc.in reflects these changes.
Note:
mutter.desktop.in and mutter-wm.desktop both continue to have
X-GNOME-WMSettingsModule=metacity set. This allows
gnome-control-center to continue using libmetacity.so for
configuration. This is fine since most the general keybindings and wm
settings are being read from /apps/metacity/* in gconf.
2009-06-10 10:29:20 +00:00
|
|
|
* have any way to do so while Mutter is running, so it's rather
|
2008-01-06 21:23:33 +00:00
|
|
|
* pointless.
|
2011-11-02 15:34:45 +00:00
|
|
|
*
|
|
|
|
* Returns: %TRUE if we must wait for events whenever we send X requests;
|
|
|
|
* %FALSE otherwise.
|
2008-01-06 21:23:33 +00:00
|
|
|
*/
|
2002-01-28 02:09:12 +00:00
|
|
|
gboolean
|
|
|
|
meta_is_syncing (void)
|
|
|
|
{
|
|
|
|
return is_syncing;
|
|
|
|
}
|
|
|
|
|
2008-01-13 01:01:21 +00:00
|
|
|
/**
|
2011-11-02 15:34:45 +00:00
|
|
|
* meta_set_syncing:
|
2013-02-15 18:42:08 +00:00
|
|
|
* @setting: whether to turn syncing on or off
|
2008-01-06 21:23:33 +00:00
|
|
|
*
|
2011-11-02 15:34:45 +00:00
|
|
|
* A handy way to turn on synchronisation on or off for every display.
|
2008-01-06 21:23:33 +00:00
|
|
|
*/
|
2002-01-28 02:09:12 +00:00
|
|
|
void
|
|
|
|
meta_set_syncing (gboolean setting)
|
|
|
|
{
|
|
|
|
if (setting != is_syncing)
|
|
|
|
{
|
|
|
|
is_syncing = setting;
|
2010-05-25 17:24:42 +00:00
|
|
|
if (meta_get_display ())
|
2017-08-26 16:26:30 +00:00
|
|
|
XSynchronize (meta_get_display ()->x11_display->xdisplay, is_syncing);
|
2002-01-28 02:09:12 +00:00
|
|
|
}
|
|
|
|
}
|
Screw around with Anders's ping patch so he'll get plenty of CVS
2002-02-26 Havoc Pennington <hp@pobox.com>
Screw around with Anders's ping patch so he'll get plenty of CVS
conflicts. ;-)
* src/display.c (meta_display_ping_window): spew warnings
if we try to call this with CurrentTime
(meta_display_ping_timeout): remove ping from the pending pings
after it times out.
* src/util.h: added PING debug category
* src/display.c (remove_pending_pings_for_window): don't remove
"tmp" just before "tmp->next", don't break out of loop after
finding the first match
(meta_display_open): no trailing comma in array init
(event_callback): move the processing of ping replies into a
separate function
* src/screen.c (set_supported_hint): add _NET_WM_PING to supported
list
* src/display.h: change gpointer to void*
2002-02-26 Anders Carlsson <andersca@gnu.org>
* src/display.c: (ping_data_free),
(remove_pending_pings_for_window), (meta_display_open),
(event_callback), (meta_display_unregister_x_window),
(meta_display_ping_timeout), (meta_display_ping_window),
(meta_display_window_has_pending_pings):
Implement meta_display_ping_window, and filter out scroll wheel
events.
* src/display.h:
Add MetaWindowPingFunc, meta_display_ping_window and
meta_display_window_has_pending_pings.
2002-02-27 02:05:39 +00:00
|
|
|
|
2014-02-15 16:33:12 +00:00
|
|
|
/*
|
|
|
|
* How long, in milliseconds, we should wait after pinging a window
|
|
|
|
* before deciding it's not going to get back to us.
|
|
|
|
*/
|
|
|
|
#define PING_TIMEOUT_DELAY 5000
|
|
|
|
|
|
|
|
/**
|
|
|
|
* meta_display_ping_timeout:
|
|
|
|
* @data: All the information about this ping. It is a #MetaPingData
|
|
|
|
* cast to a #gpointer in order to be passable to a timeout function.
|
|
|
|
* This function will also free this parameter.
|
|
|
|
*
|
|
|
|
* Does whatever it is we decided to do when a window didn't respond
|
|
|
|
* to a ping. We also remove the ping from the display's list of
|
|
|
|
* pending pings. This function is called by the event loop when the timeout
|
|
|
|
* times out which we created at the start of the ping.
|
|
|
|
*
|
|
|
|
* Returns: Always returns %FALSE, because this function is called as a
|
|
|
|
* timeout and we don't want to run the timer again.
|
|
|
|
*/
|
|
|
|
static gboolean
|
|
|
|
meta_display_ping_timeout (gpointer data)
|
|
|
|
{
|
|
|
|
MetaPingData *ping_data = data;
|
2014-05-20 18:48:08 +00:00
|
|
|
MetaWindow *window = ping_data->window;
|
|
|
|
MetaDisplay *display = window->display;
|
|
|
|
|
|
|
|
meta_window_set_alive (window, FALSE);
|
2014-02-15 16:33:12 +00:00
|
|
|
|
|
|
|
ping_data->ping_timeout_id = 0;
|
|
|
|
|
|
|
|
meta_topic (META_DEBUG_PING,
|
|
|
|
"Ping %u on window %s timed out\n",
|
2014-05-20 18:48:08 +00:00
|
|
|
ping_data->serial, ping_data->window->desc);
|
2014-02-15 16:33:12 +00:00
|
|
|
|
|
|
|
display->pending_pings = g_slist_remove (display->pending_pings, ping_data);
|
|
|
|
ping_data_free (ping_data);
|
|
|
|
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* meta_display_ping_window:
|
|
|
|
* @display: The #MetaDisplay that the window is on
|
|
|
|
* @window: The #MetaWindow to send the ping to
|
|
|
|
* @timestamp: The timestamp of the ping. Used for uniqueness.
|
|
|
|
* Cannot be CurrentTime; use a real timestamp!
|
|
|
|
*
|
|
|
|
* Sends a ping request to a window. The window must respond to
|
|
|
|
* the request within a certain amount of time. If it does, we
|
|
|
|
* will call one callback; if the time passes and we haven't had
|
|
|
|
* a response, we call a different callback. The window must have
|
|
|
|
* the hint showing that it can respond to a ping; if it doesn't,
|
|
|
|
* we call the "got a response" callback immediately and return.
|
|
|
|
* This function returns straight away after setting things up;
|
|
|
|
* the callbacks will be called from the event loop.
|
|
|
|
*/
|
|
|
|
void
|
2014-05-20 18:48:08 +00:00
|
|
|
meta_display_ping_window (MetaWindow *window,
|
|
|
|
guint32 serial)
|
2014-02-15 16:33:12 +00:00
|
|
|
{
|
|
|
|
MetaDisplay *display = window->display;
|
|
|
|
MetaPingData *ping_data;
|
|
|
|
|
2014-05-20 18:48:08 +00:00
|
|
|
if (serial == 0)
|
2014-02-15 16:33:12 +00:00
|
|
|
{
|
2014-05-20 18:48:08 +00:00
|
|
|
meta_warning ("Tried to ping a window with a bad serial! Not allowed.\n");
|
2014-02-15 16:33:12 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-02-19 01:28:23 +00:00
|
|
|
if (!window->can_ping)
|
2014-05-20 18:48:08 +00:00
|
|
|
return;
|
2014-02-15 16:33:12 +00:00
|
|
|
|
|
|
|
ping_data = g_new (MetaPingData, 1);
|
|
|
|
ping_data->window = window;
|
2014-05-20 18:48:08 +00:00
|
|
|
ping_data->serial = serial;
|
2014-02-15 16:33:12 +00:00
|
|
|
ping_data->ping_timeout_id = g_timeout_add (PING_TIMEOUT_DELAY,
|
|
|
|
meta_display_ping_timeout,
|
|
|
|
ping_data);
|
2014-04-10 16:58:58 +00:00
|
|
|
g_source_set_name_by_id (ping_data->ping_timeout_id, "[mutter] meta_display_ping_timeout");
|
2014-02-15 16:33:12 +00:00
|
|
|
|
|
|
|
display->pending_pings = g_slist_prepend (display->pending_pings, ping_data);
|
|
|
|
|
|
|
|
meta_topic (META_DEBUG_PING,
|
2014-05-20 18:48:08 +00:00
|
|
|
"Sending ping with serial %u to window %s\n",
|
|
|
|
serial, window->desc);
|
2014-02-15 16:33:12 +00:00
|
|
|
|
2014-05-20 18:48:08 +00:00
|
|
|
META_WINDOW_GET_CLASS (window)->ping (window, serial);
|
2014-02-15 16:33:12 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* meta_display_pong_for_serial:
|
|
|
|
* @display: the display we got the pong from
|
|
|
|
* @serial: the serial in the pong repsonse
|
|
|
|
*
|
|
|
|
* Process the pong (the response message) from the ping we sent
|
|
|
|
* to the window. This involves removing the timeout, calling the
|
|
|
|
* reply handler function, and freeing memory.
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
meta_display_pong_for_serial (MetaDisplay *display,
|
|
|
|
guint32 serial)
|
|
|
|
{
|
|
|
|
GSList *tmp;
|
|
|
|
|
|
|
|
meta_topic (META_DEBUG_PING, "Received a pong with serial %u\n", serial);
|
|
|
|
|
|
|
|
for (tmp = display->pending_pings; tmp; tmp = tmp->next)
|
|
|
|
{
|
|
|
|
MetaPingData *ping_data = tmp->data;
|
|
|
|
|
2014-05-20 18:48:08 +00:00
|
|
|
if (serial == ping_data->serial)
|
2014-02-15 16:33:12 +00:00
|
|
|
{
|
|
|
|
meta_topic (META_DEBUG_PING,
|
|
|
|
"Matching ping found for pong %u\n",
|
2014-05-20 18:48:08 +00:00
|
|
|
ping_data->serial);
|
2014-02-15 16:33:12 +00:00
|
|
|
|
|
|
|
/* Remove the ping data from the list */
|
|
|
|
display->pending_pings = g_slist_remove (display->pending_pings,
|
|
|
|
ping_data);
|
|
|
|
|
|
|
|
/* Remove the timeout */
|
|
|
|
if (ping_data->ping_timeout_id != 0)
|
|
|
|
{
|
|
|
|
g_source_remove (ping_data->ping_timeout_id);
|
|
|
|
ping_data->ping_timeout_id = 0;
|
|
|
|
}
|
|
|
|
|
2014-05-20 18:48:08 +00:00
|
|
|
meta_window_set_alive (ping_data->window, TRUE);
|
2014-02-15 16:33:12 +00:00
|
|
|
ping_data_free (ping_data);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-03-19 00:57:32 +00:00
|
|
|
static MetaGroup *
|
|
|
|
get_focused_group (MetaDisplay *display)
|
2006-04-15 02:05:44 +00:00
|
|
|
{
|
|
|
|
if (display->focus_window)
|
|
|
|
return display->focus_window->group;
|
|
|
|
else
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
#define IN_TAB_CHAIN(w,t) (((t) == META_TAB_LIST_NORMAL && META_WINDOW_IN_NORMAL_TAB_CHAIN (w)) \
|
|
|
|
|| ((t) == META_TAB_LIST_DOCKS && META_WINDOW_IN_DOCK_TAB_CHAIN (w)) \
|
2014-03-19 00:57:32 +00:00
|
|
|
|| ((t) == META_TAB_LIST_GROUP && META_WINDOW_IN_GROUP_TAB_CHAIN (w, get_focused_group (w->display))) \
|
2012-03-12 22:00:12 +00:00
|
|
|
|| ((t) == META_TAB_LIST_NORMAL_ALL && META_WINDOW_IN_NORMAL_TAB_CHAIN_TYPE (w)))
|
2002-04-05 15:52:49 +00:00
|
|
|
|
2002-03-12 04:34:17 +00:00
|
|
|
static MetaWindow*
|
|
|
|
find_tab_forward (MetaDisplay *display,
|
2002-04-05 15:52:49 +00:00
|
|
|
MetaTabList type,
|
2002-03-12 04:34:17 +00:00
|
|
|
MetaWorkspace *workspace,
|
2004-10-25 16:17:19 +00:00
|
|
|
GList *start,
|
|
|
|
gboolean skip_first)
|
2002-03-12 04:34:17 +00:00
|
|
|
{
|
|
|
|
GList *tmp;
|
|
|
|
|
|
|
|
g_return_val_if_fail (start != NULL, NULL);
|
2003-08-15 22:09:55 +00:00
|
|
|
g_return_val_if_fail (workspace != NULL, NULL);
|
2002-05-11 06:59:54 +00:00
|
|
|
|
2004-10-25 16:17:19 +00:00
|
|
|
tmp = start;
|
|
|
|
if (skip_first)
|
|
|
|
tmp = tmp->next;
|
|
|
|
|
2002-03-12 04:34:17 +00:00
|
|
|
while (tmp != NULL)
|
|
|
|
{
|
|
|
|
MetaWindow *window = tmp->data;
|
|
|
|
|
2013-10-03 22:31:09 +00:00
|
|
|
if (IN_TAB_CHAIN (window, type))
|
2002-03-12 04:34:17 +00:00
|
|
|
return window;
|
|
|
|
|
|
|
|
tmp = tmp->next;
|
|
|
|
}
|
|
|
|
|
2003-08-15 22:09:55 +00:00
|
|
|
tmp = workspace->mru_list;
|
2002-03-12 04:34:17 +00:00
|
|
|
while (tmp != start)
|
|
|
|
{
|
|
|
|
MetaWindow *window = tmp->data;
|
|
|
|
|
2003-08-15 22:09:55 +00:00
|
|
|
if (IN_TAB_CHAIN (window, type))
|
2002-03-12 04:34:17 +00:00
|
|
|
return window;
|
|
|
|
|
|
|
|
tmp = tmp->next;
|
2014-05-02 13:34:02 +00:00
|
|
|
}
|
2002-03-12 04:34:17 +00:00
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
static MetaWindow*
|
|
|
|
find_tab_backward (MetaDisplay *display,
|
2002-04-05 15:52:49 +00:00
|
|
|
MetaTabList type,
|
2002-03-12 04:34:17 +00:00
|
|
|
MetaWorkspace *workspace,
|
2004-10-25 16:17:19 +00:00
|
|
|
GList *start,
|
|
|
|
gboolean skip_last)
|
2002-03-12 04:34:17 +00:00
|
|
|
{
|
|
|
|
GList *tmp;
|
|
|
|
|
|
|
|
g_return_val_if_fail (start != NULL, NULL);
|
2003-08-15 22:09:55 +00:00
|
|
|
g_return_val_if_fail (workspace != NULL, NULL);
|
2004-10-25 16:17:19 +00:00
|
|
|
|
|
|
|
tmp = start;
|
2014-05-02 13:34:02 +00:00
|
|
|
if (skip_last)
|
2004-10-25 16:17:19 +00:00
|
|
|
tmp = tmp->prev;
|
2002-03-12 04:34:17 +00:00
|
|
|
while (tmp != NULL)
|
|
|
|
{
|
|
|
|
MetaWindow *window = tmp->data;
|
|
|
|
|
2013-10-03 22:31:09 +00:00
|
|
|
if (IN_TAB_CHAIN (window, type))
|
2002-03-12 04:34:17 +00:00
|
|
|
return window;
|
|
|
|
|
|
|
|
tmp = tmp->prev;
|
|
|
|
}
|
|
|
|
|
2003-08-15 22:09:55 +00:00
|
|
|
tmp = g_list_last (workspace->mru_list);
|
2002-03-12 04:34:17 +00:00
|
|
|
while (tmp != start)
|
|
|
|
{
|
|
|
|
MetaWindow *window = tmp->data;
|
|
|
|
|
2003-08-15 22:09:55 +00:00
|
|
|
if (IN_TAB_CHAIN (window, type))
|
2002-03-12 04:34:17 +00:00
|
|
|
return window;
|
|
|
|
|
|
|
|
tmp = tmp->prev;
|
|
|
|
}
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2012-12-03 16:59:11 +00:00
|
|
|
static int
|
|
|
|
mru_cmp (gconstpointer a,
|
|
|
|
gconstpointer b)
|
|
|
|
{
|
|
|
|
guint32 time_a, time_b;
|
|
|
|
|
|
|
|
time_a = meta_window_get_user_time ((MetaWindow *)a);
|
|
|
|
time_b = meta_window_get_user_time ((MetaWindow *)b);
|
|
|
|
|
|
|
|
if (time_a > time_b)
|
|
|
|
return -1;
|
|
|
|
else if (time_a < time_b)
|
|
|
|
return 1;
|
|
|
|
else
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2010-09-01 19:39:53 +00:00
|
|
|
/**
|
|
|
|
* meta_display_get_tab_list:
|
|
|
|
* @display: a #MetaDisplay
|
|
|
|
* @type: type of tab list
|
2014-05-28 19:44:23 +00:00
|
|
|
* @workspace: (nullable): origin workspace
|
2010-09-01 19:39:53 +00:00
|
|
|
*
|
|
|
|
* Determine the list of windows that should be displayed for Alt-TAB
|
|
|
|
* functionality. The windows are returned in most recently used order.
|
2012-12-03 16:59:11 +00:00
|
|
|
* If @workspace is not %NULL, the list only conains windows that are on
|
|
|
|
* @workspace or have the demands-attention hint set; otherwise it contains
|
2014-06-03 12:40:15 +00:00
|
|
|
* all windows.
|
2010-09-01 19:39:53 +00:00
|
|
|
*
|
|
|
|
* Returns: (transfer container) (element-type Meta.Window): List of windows
|
|
|
|
*/
|
2003-03-15 02:16:21 +00:00
|
|
|
GList*
|
2002-03-12 04:34:17 +00:00
|
|
|
meta_display_get_tab_list (MetaDisplay *display,
|
2002-04-05 15:52:49 +00:00
|
|
|
MetaTabList type,
|
2002-03-12 04:34:17 +00:00
|
|
|
MetaWorkspace *workspace)
|
|
|
|
{
|
2012-12-03 23:05:22 +00:00
|
|
|
GList *tab_list = NULL;
|
2012-12-03 16:59:11 +00:00
|
|
|
GList *global_mru_list = NULL;
|
|
|
|
GList *mru_list, *tmp;
|
2012-12-03 23:05:22 +00:00
|
|
|
GSList *windows = meta_display_list_windows (display, META_LIST_DEFAULT);
|
|
|
|
GSList *w;
|
2002-03-12 04:34:17 +00:00
|
|
|
|
2012-12-03 16:59:11 +00:00
|
|
|
if (workspace == NULL)
|
|
|
|
{
|
|
|
|
/* Yay for mixing GList and GSList in the API */
|
|
|
|
for (w = windows; w; w = w->next)
|
|
|
|
global_mru_list = g_list_prepend (global_mru_list, w->data);
|
|
|
|
global_mru_list = g_list_sort (global_mru_list, mru_cmp);
|
|
|
|
}
|
|
|
|
|
|
|
|
mru_list = workspace ? workspace->mru_list : global_mru_list;
|
2002-04-05 15:52:49 +00:00
|
|
|
|
2014-10-01 23:28:45 +00:00
|
|
|
/* Windows sellout mode - MRU order. Collect unminimized windows
|
|
|
|
* then minimized so minimized windows aren't in the way so much.
|
2002-10-24 05:15:28 +00:00
|
|
|
*/
|
2012-12-03 16:59:11 +00:00
|
|
|
for (tmp = mru_list; tmp; tmp = tmp->next)
|
2012-12-03 23:05:22 +00:00
|
|
|
{
|
|
|
|
MetaWindow *window = tmp->data;
|
2002-10-24 05:15:28 +00:00
|
|
|
|
2014-10-01 23:28:45 +00:00
|
|
|
if (!window->minimized && IN_TAB_CHAIN (window, type))
|
|
|
|
tab_list = g_list_prepend (tab_list, window);
|
|
|
|
}
|
|
|
|
|
|
|
|
for (tmp = mru_list; tmp; tmp = tmp->next)
|
|
|
|
{
|
|
|
|
MetaWindow *window = tmp->data;
|
|
|
|
|
|
|
|
if (window->minimized && IN_TAB_CHAIN (window, type))
|
2012-12-03 23:05:22 +00:00
|
|
|
tab_list = g_list_prepend (tab_list, window);
|
|
|
|
}
|
2008-02-02 04:05:16 +00:00
|
|
|
|
2012-12-03 23:05:22 +00:00
|
|
|
tab_list = g_list_reverse (tab_list);
|
2008-02-02 04:05:16 +00:00
|
|
|
|
2012-12-03 16:59:11 +00:00
|
|
|
/* If filtering by workspace, include windows from
|
|
|
|
* other workspaces that demand attention
|
|
|
|
*/
|
|
|
|
if (workspace)
|
|
|
|
for (w = windows; w; w = w->next)
|
|
|
|
{
|
|
|
|
MetaWindow *l_window = w->data;
|
2008-02-02 04:05:16 +00:00
|
|
|
|
2012-12-03 16:59:11 +00:00
|
|
|
if (l_window->wm_state_demands_attention &&
|
|
|
|
l_window->workspace != workspace &&
|
|
|
|
IN_TAB_CHAIN (l_window, type))
|
2012-12-03 23:05:22 +00:00
|
|
|
tab_list = g_list_prepend (tab_list, l_window);
|
2012-12-03 16:59:11 +00:00
|
|
|
}
|
2012-03-23 08:45:50 +00:00
|
|
|
|
2012-12-03 16:59:11 +00:00
|
|
|
g_list_free (global_mru_list);
|
2012-12-03 23:05:22 +00:00
|
|
|
g_slist_free (windows);
|
2014-05-02 13:34:02 +00:00
|
|
|
|
2002-03-12 04:34:17 +00:00
|
|
|
return tab_list;
|
|
|
|
}
|
|
|
|
|
2010-09-01 19:39:53 +00:00
|
|
|
/**
|
|
|
|
* meta_display_get_tab_next:
|
|
|
|
* @display: a #MetaDisplay
|
|
|
|
* @type: type of tab list
|
|
|
|
* @workspace: origin workspace
|
2014-05-28 19:44:23 +00:00
|
|
|
* @window: (nullable): starting window
|
2014-05-02 13:34:02 +00:00
|
|
|
* @backward: If %TRUE, look for the previous window.
|
2010-09-01 19:39:53 +00:00
|
|
|
*
|
|
|
|
* Determine the next window that should be displayed for Alt-TAB
|
|
|
|
* functionality.
|
|
|
|
*
|
|
|
|
* Returns: (transfer none): Next window
|
|
|
|
*
|
|
|
|
*/
|
2002-03-12 04:34:17 +00:00
|
|
|
MetaWindow*
|
|
|
|
meta_display_get_tab_next (MetaDisplay *display,
|
2002-04-05 15:52:49 +00:00
|
|
|
MetaTabList type,
|
2002-03-12 04:34:17 +00:00
|
|
|
MetaWorkspace *workspace,
|
|
|
|
MetaWindow *window,
|
|
|
|
gboolean backward)
|
|
|
|
{
|
2004-10-25 16:17:19 +00:00
|
|
|
gboolean skip;
|
2003-03-15 02:16:21 +00:00
|
|
|
GList *tab_list;
|
2006-01-20 22:03:56 +00:00
|
|
|
MetaWindow *ret;
|
2014-06-03 12:40:15 +00:00
|
|
|
tab_list = meta_display_get_tab_list (display, type, workspace);
|
2003-03-15 02:16:21 +00:00
|
|
|
|
|
|
|
if (tab_list == NULL)
|
2002-03-12 04:34:17 +00:00
|
|
|
return NULL;
|
2014-05-02 13:34:02 +00:00
|
|
|
|
2002-03-12 04:34:17 +00:00
|
|
|
if (window != NULL)
|
|
|
|
{
|
|
|
|
g_assert (window->display == display);
|
2014-05-02 13:34:02 +00:00
|
|
|
|
2002-03-12 04:34:17 +00:00
|
|
|
if (backward)
|
2013-10-03 22:31:09 +00:00
|
|
|
ret = find_tab_backward (display, type, workspace, g_list_find (tab_list, window), TRUE);
|
2006-01-20 22:03:56 +00:00
|
|
|
else
|
2013-10-03 22:31:09 +00:00
|
|
|
ret = find_tab_forward (display, type, workspace, g_list_find (tab_list, window), TRUE);
|
2002-03-12 04:34:17 +00:00
|
|
|
}
|
|
|
|
else
|
2006-01-20 22:03:56 +00:00
|
|
|
{
|
2014-05-02 13:34:02 +00:00
|
|
|
skip = display->focus_window != NULL &&
|
2009-02-07 23:05:42 +00:00
|
|
|
tab_list->data == display->focus_window;
|
2006-01-20 22:03:56 +00:00
|
|
|
if (backward)
|
2013-10-03 22:31:09 +00:00
|
|
|
ret = find_tab_backward (display, type, workspace, tab_list, skip);
|
2006-01-20 22:03:56 +00:00
|
|
|
else
|
2013-10-03 22:31:09 +00:00
|
|
|
ret = find_tab_forward (display, type, workspace, tab_list, skip);
|
2006-01-20 22:03:56 +00:00
|
|
|
}
|
2003-03-15 02:16:21 +00:00
|
|
|
|
|
|
|
g_list_free (tab_list);
|
2006-01-20 22:03:56 +00:00
|
|
|
return ret;
|
2002-03-12 04:34:17 +00:00
|
|
|
}
|
2002-03-17 17:22:23 +00:00
|
|
|
|
2010-09-01 19:39:53 +00:00
|
|
|
/**
|
|
|
|
* meta_display_get_tab_current:
|
|
|
|
* @display: a #MetaDisplay
|
|
|
|
* @type: type of tab list
|
|
|
|
* @workspace: origin workspace
|
|
|
|
*
|
|
|
|
* Determine the active window that should be displayed for Alt-TAB.
|
|
|
|
*
|
|
|
|
* Returns: (transfer none): Current window
|
|
|
|
*
|
|
|
|
*/
|
2002-09-04 04:15:46 +00:00
|
|
|
MetaWindow*
|
|
|
|
meta_display_get_tab_current (MetaDisplay *display,
|
|
|
|
MetaTabList type,
|
|
|
|
MetaWorkspace *workspace)
|
|
|
|
{
|
|
|
|
MetaWindow *window;
|
|
|
|
|
|
|
|
window = display->focus_window;
|
2014-05-02 13:34:02 +00:00
|
|
|
|
2002-09-04 04:15:46 +00:00
|
|
|
if (window != NULL &&
|
|
|
|
IN_TAB_CHAIN (window, type) &&
|
|
|
|
(workspace == NULL ||
|
2004-12-23 00:20:33 +00:00
|
|
|
meta_window_located_on_workspace (window, workspace)))
|
2002-09-04 04:15:46 +00:00
|
|
|
return window;
|
|
|
|
else
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2002-03-17 17:22:23 +00:00
|
|
|
int
|
|
|
|
meta_resize_gravity_from_grab_op (MetaGrabOp op)
|
|
|
|
{
|
|
|
|
int gravity;
|
2014-05-02 13:34:02 +00:00
|
|
|
|
2002-03-17 17:22:23 +00:00
|
|
|
gravity = -1;
|
|
|
|
switch (op)
|
|
|
|
{
|
|
|
|
case META_GRAB_OP_RESIZING_SE:
|
|
|
|
case META_GRAB_OP_KEYBOARD_RESIZING_SE:
|
|
|
|
gravity = NorthWestGravity;
|
|
|
|
break;
|
|
|
|
case META_GRAB_OP_KEYBOARD_RESIZING_S:
|
|
|
|
case META_GRAB_OP_RESIZING_S:
|
|
|
|
gravity = NorthGravity;
|
|
|
|
break;
|
|
|
|
case META_GRAB_OP_KEYBOARD_RESIZING_SW:
|
|
|
|
case META_GRAB_OP_RESIZING_SW:
|
|
|
|
gravity = NorthEastGravity;
|
|
|
|
break;
|
|
|
|
case META_GRAB_OP_KEYBOARD_RESIZING_N:
|
|
|
|
case META_GRAB_OP_RESIZING_N:
|
|
|
|
gravity = SouthGravity;
|
|
|
|
break;
|
|
|
|
case META_GRAB_OP_KEYBOARD_RESIZING_NE:
|
|
|
|
case META_GRAB_OP_RESIZING_NE:
|
|
|
|
gravity = SouthWestGravity;
|
|
|
|
break;
|
|
|
|
case META_GRAB_OP_KEYBOARD_RESIZING_NW:
|
|
|
|
case META_GRAB_OP_RESIZING_NW:
|
|
|
|
gravity = SouthEastGravity;
|
|
|
|
break;
|
|
|
|
case META_GRAB_OP_KEYBOARD_RESIZING_E:
|
|
|
|
case META_GRAB_OP_RESIZING_E:
|
|
|
|
gravity = WestGravity;
|
|
|
|
break;
|
|
|
|
case META_GRAB_OP_KEYBOARD_RESIZING_W:
|
|
|
|
case META_GRAB_OP_RESIZING_W:
|
|
|
|
gravity = EastGravity;
|
|
|
|
break;
|
2002-06-19 04:12:49 +00:00
|
|
|
case META_GRAB_OP_KEYBOARD_RESIZING_UNKNOWN:
|
|
|
|
gravity = CenterGravity;
|
|
|
|
break;
|
2002-03-17 17:22:23 +00:00
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return gravity;
|
|
|
|
}
|
2002-05-24 02:23:46 +00:00
|
|
|
|
2017-08-26 17:03:51 +00:00
|
|
|
void
|
|
|
|
meta_display_manage_all_windows (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
guint64 *_children;
|
|
|
|
guint64 *children;
|
|
|
|
int n_children, i;
|
|
|
|
|
|
|
|
meta_stack_freeze (display->stack);
|
|
|
|
meta_stack_tracker_get_stack (display->stack_tracker, &_children, &n_children);
|
|
|
|
|
|
|
|
/* Copy the stack as it will be modified as part of the loop */
|
|
|
|
children = g_memdup (_children, sizeof (guint64) * n_children);
|
|
|
|
|
|
|
|
for (i = 0; i < n_children; ++i)
|
|
|
|
{
|
|
|
|
g_assert (META_STACK_ID_IS_X11 (children[i]));
|
|
|
|
meta_window_x11_new (display, children[i], TRUE,
|
|
|
|
META_COMP_EFFECT_NONE);
|
|
|
|
}
|
|
|
|
|
|
|
|
g_free (children);
|
|
|
|
meta_stack_thaw (display->stack);
|
|
|
|
}
|
|
|
|
|
2002-06-08 23:55:27 +00:00
|
|
|
void
|
2018-06-29 10:44:17 +00:00
|
|
|
meta_display_unmanage_windows (MetaDisplay *display,
|
|
|
|
guint32 timestamp)
|
2002-06-08 23:55:27 +00:00
|
|
|
{
|
|
|
|
GSList *tmp;
|
|
|
|
GSList *winlist;
|
|
|
|
|
2009-06-15 19:32:23 +00:00
|
|
|
winlist = meta_display_list_windows (display,
|
|
|
|
META_LIST_INCLUDE_OVERRIDE_REDIRECT);
|
2007-04-16 04:57:32 +00:00
|
|
|
winlist = g_slist_sort (winlist, meta_display_stack_cmp);
|
2012-01-19 19:06:57 +00:00
|
|
|
g_slist_foreach (winlist, (GFunc)g_object_ref, NULL);
|
2002-06-08 23:55:27 +00:00
|
|
|
|
|
|
|
/* Unmanage all windows */
|
|
|
|
tmp = winlist;
|
|
|
|
while (tmp != NULL)
|
Partial audit to fix timestamp usage. One step towards fixing #355180; see
2006-09-18 Elijah Newren <newren gmail com>
Partial audit to fix timestamp usage. One step towards fixing
#355180; see important comments in that bug.
* src/core.[ch] (meta_core_unshade, meta_core_shade):
* src/delete.c (meta_window_present_delete_dialog,
delete_ping_timeout_func):
* src/display.[ch] (meta_display_open, meta_display_close,
event_callback, meta_display_begin_grab_op,
process_selection_clear, meta_display_unmanage_screen,
meta_display_unmanage_windows_for_screen):
* src/frames.c (meta_frames_button_press_event):
* src/keybindings.c (handle_toggle_shade):
* src/main.c (main):
* src/screen.[ch] (update_num_workspaces, meta_screen_new,
meta_screen_free, prefs_changed_callback):
* src/window.[ch] (meta_window_free, finish_minimize,
implement_showing, meta_window_show, meta_window_maximize,
meta_window_make_fullscreen_internal,
meta_window_unmake_fullscreen, meta_window_shade,
meta_window_unshade, window_activate, send_sync_request,
meta_window_client_message, menu_callback,
meta_window_update_keyboard_resize):
Remove usage of CurrentTime, meta_display_get_current_time() and
meta_display_get_current_time_roundtrip() where possible, or
document why it isn't possible, or at very least add a FIXME with
some explanation of my laziness and what needs to be done.
2006-09-18 17:27:24 +00:00
|
|
|
{
|
2012-01-19 19:06:57 +00:00
|
|
|
MetaWindow *window = tmp->data;
|
|
|
|
|
|
|
|
/* Check if already unmanaged for safety - in particular, catch
|
|
|
|
* the case where unmanaging a parent window can cause attached
|
|
|
|
* dialogs to be (temporarily) unmanaged.
|
|
|
|
*/
|
|
|
|
if (!window->unmanaging)
|
|
|
|
meta_window_unmanage (window, timestamp);
|
|
|
|
g_object_unref (window);
|
2014-05-02 13:34:02 +00:00
|
|
|
|
2002-06-08 23:55:27 +00:00
|
|
|
tmp = tmp->next;
|
|
|
|
}
|
|
|
|
g_slist_free (winlist);
|
|
|
|
}
|
2002-10-07 23:14:40 +00:00
|
|
|
|
2007-04-16 04:57:32 +00:00
|
|
|
int
|
|
|
|
meta_display_stack_cmp (const void *a,
|
|
|
|
const void *b)
|
|
|
|
{
|
|
|
|
MetaWindow *aw = (void*) a;
|
|
|
|
MetaWindow *bw = (void*) b;
|
|
|
|
|
2017-08-26 17:03:51 +00:00
|
|
|
return meta_stack_windows_cmp (aw->display->stack, aw, bw);
|
2007-04-16 04:57:32 +00:00
|
|
|
}
|
|
|
|
|
2010-04-24 21:18:01 +00:00
|
|
|
/**
|
|
|
|
* meta_display_sort_windows_by_stacking:
|
|
|
|
* @display: a #MetaDisplay
|
|
|
|
* @windows: (element-type MetaWindow): Set of windows
|
|
|
|
*
|
|
|
|
* Sorts a set of windows according to their current stacking order. If windows
|
|
|
|
* from multiple screens are present in the set of input windows, then all the
|
|
|
|
* windows on screen 0 are sorted below all the windows on screen 1, and so forth.
|
|
|
|
* Since the stacking order of override-redirect windows isn't controlled by
|
|
|
|
* Metacity, if override-redirect windows are in the input, the result may not
|
|
|
|
* correspond to the actual stacking order in the X server.
|
|
|
|
*
|
|
|
|
* An example of using this would be to sort the list of transient dialogs for a
|
|
|
|
* window into their current stacking order.
|
|
|
|
*
|
2011-08-30 16:54:49 +00:00
|
|
|
* Returns: (transfer container) (element-type MetaWindow): Input windows sorted by stacking order, from lowest to highest
|
2010-04-24 21:18:01 +00:00
|
|
|
*/
|
|
|
|
GSList *
|
|
|
|
meta_display_sort_windows_by_stacking (MetaDisplay *display,
|
|
|
|
GSList *windows)
|
|
|
|
{
|
|
|
|
GSList *copy = g_slist_copy (windows);
|
|
|
|
|
|
|
|
copy = g_slist_sort (copy, meta_display_stack_cmp);
|
|
|
|
|
|
|
|
return copy;
|
|
|
|
}
|
|
|
|
|
2002-10-07 23:14:40 +00:00
|
|
|
static void
|
|
|
|
prefs_changed_callback (MetaPreference pref,
|
|
|
|
void *data)
|
|
|
|
{
|
2006-02-16 20:26:05 +00:00
|
|
|
MetaDisplay *display = data;
|
2014-05-02 13:34:02 +00:00
|
|
|
|
2017-08-26 20:35:18 +00:00
|
|
|
if (pref == META_PREF_CURSOR_THEME ||
|
|
|
|
pref == META_PREF_CURSOR_SIZE)
|
2014-04-24 14:48:47 +00:00
|
|
|
{
|
2017-08-26 16:37:29 +00:00
|
|
|
meta_display_reload_cursor (display);
|
2014-04-24 14:48:47 +00:00
|
|
|
}
|
2017-08-26 19:39:46 +00:00
|
|
|
else if ((pref == META_PREF_NUM_WORKSPACES ||
|
|
|
|
pref == META_PREF_DYNAMIC_WORKSPACES) &&
|
|
|
|
!meta_prefs_get_dynamic_workspaces ())
|
|
|
|
{
|
|
|
|
/* GSettings doesn't provide timestamps, but luckily update_num_workspaces
|
|
|
|
* often doesn't need it...
|
|
|
|
*/
|
|
|
|
guint32 timestamp =
|
|
|
|
meta_display_get_current_time_roundtrip (display);
|
2017-08-26 20:29:10 +00:00
|
|
|
int new_num = meta_prefs_get_num_workspaces ();
|
|
|
|
meta_display_update_num_workspaces (display, timestamp, new_num);
|
2017-08-26 19:39:46 +00:00
|
|
|
}
|
2002-10-07 23:14:40 +00:00
|
|
|
}
|
2003-05-30 20:24:00 +00:00
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_increment_focus_sentinel (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
unsigned long data[1];
|
|
|
|
|
|
|
|
data[0] = meta_display_get_current_time (display);
|
2014-05-02 13:34:02 +00:00
|
|
|
|
2017-08-26 16:26:30 +00:00
|
|
|
XChangeProperty (display->x11_display->xdisplay,
|
|
|
|
display->x11_display->xroot,
|
|
|
|
display->x11_display->atom__MUTTER_SENTINEL,
|
2003-05-30 20:24:00 +00:00
|
|
|
XA_CARDINAL,
|
|
|
|
32, PropModeReplace, (guchar*) data, 1);
|
2014-05-02 13:34:02 +00:00
|
|
|
|
2003-05-30 20:24:00 +00:00
|
|
|
display->sentinel_counter += 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_decrement_focus_sentinel (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
display->sentinel_counter -= 1;
|
|
|
|
|
|
|
|
if (display->sentinel_counter < 0)
|
|
|
|
display->sentinel_counter = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
gboolean
|
|
|
|
meta_display_focus_sentinel_clear (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
return (display->sentinel_counter == 0);
|
|
|
|
}
|
2004-10-04 21:09:08 +00:00
|
|
|
|
2014-03-20 19:29:30 +00:00
|
|
|
void
|
|
|
|
meta_display_sanity_check_timestamps (MetaDisplay *display,
|
|
|
|
guint32 timestamp)
|
Big patch to cover about 6 different issues in order to correct rare
2005-02-20 Elijah Newren <newren@gmail.com>
Big patch to cover about 6 different issues in order to correct
rare problems with timestamps (make sure window selected in
tasklist actually gets focus, sanity check timestamps to avoid
rogue apps hosing the system, correct the updating of
net_wm_user_time, correctly handle timestamps of 0 when comparing
xserver timestamps for those who have had their systems up for
over 25 days or so, add some debugging information to verbose
logs, some code cleanups). Fixes all issues listed in #167358.
* src/display.h: (struct _MetaDisplay): clarify comment on
last_focus_time, introduce a new variable--last_user_time,
(XSERVER_TIME_IS_BEFORE macro): put this functionality into a
separate macro and then introduce a new macro with this name that
uses the old one but adds additional special-case checks for
timestamps that are 0, (comment to
meta_display_set_input_focus_window): add information about how
last_user_time should be used in this function
* src/display.c (santiy_check_timestamps): new function,
(meta_display_open): intialize display->last_user_time,
(meta_display_get_current_time_roundtrip): use the timestamp,
which is known to be good, in order to sanity_check_timestamps,
(event_callback): use the new meta_window_ste_user_time() function
in order to correct problems, use the timestamp of KeyPress and
ButtonPress events, which are known to be good, in order to
sanity_check_timestamps, (timestamp_too_old): new function for
common behavior of meta_display_focus_the_no_focus_window and
meta_display_set_input_focus_window, with added checking for
display->last_user_time in addition to display->last_focus_time,
(meta_display_set_input_focus_window): replace some of the code
with a call to timestamp_too_old(),
(meta_display_focus_the_no_focus_window): replace some of th ecode
with a call to timestamp_too_old()
* src/window.h: (meta_window_set_user_time): new function to
abstract the many things that need to be done when updating the
net_wm_user_time of any window
* src/window.c: (meta_window_activate): add debugging spew, make
sure the comparison is made with last_user_time NOT
last_focus_time, use meta_window_set_user_time() function in order
to correct problems, (meta_window_client_message): add a newline
to a debugging message to make them easier to read,
(meta_window_set_user_time): new function
* src/window-props.c (reload_net_wm_user_time): use the new
meta_window_ste_user_time() function in order to correct problems
2005-02-20 17:14:16 +00:00
|
|
|
{
|
|
|
|
if (XSERVER_TIME_IS_BEFORE (timestamp, display->last_focus_time))
|
|
|
|
{
|
Fix issues on 64-bit machines with timestamps by using guint32 (like gtk+
2006-09-13 Elijah Newren <newren gmail com>
* src/common.h (MetaWindowMenuFunc):
* src/core.[ch] (meta_core_user_lower_and_unfocus,
meta_core_user_focus, meta_core_show_window_menu,
meta_core_begin_grab_op, meta_core_end_grab_op):
* src/delete.c (delete_ping_reply_func, delete_ping_timeout_func,
meta_window_delete):
* src/display.[ch] (struct MetaDisplay, struct MetaPingData,
sanity_check_timestamps, meta_display_open, event_callback,
meta_spew_event, meta_display_set_grab_op_cursor,
meta_display_begin_grab_op, meta_display_end_grab_op,
meta_display_ping_timeout, meta_display_ping_window,
process_pong_message, timestamp_too_old,
meta_display_set_input_focus_window):
* src/keybindings.[ch] (grab_keyboard, ungrab_keyboard,
meta_screen_grab_all_keys, meta_window_grab_all_keys,
meta_window_ungrab_all_keys, error_on_generic_command,
error_on_command, error_on_terminal_command):
* src/metacity-dialog.c (on_realize, warn_about_no_sm_support,
error_about_command, main):
* src/screen.[ch] (struct _MetaScreen, meta_screen_new,
meta_screen_show_desktop, meta_screen_apply_startup_properties):
* src/session.c (warn_about_lame_clients_and_finish_interact):
* src/window.[ch] (struct _MetaWindow,
intervening_user_event_occurred, window_activate,
meta_window_delete, meta_window_focus,
meta_window_send_icccm_message, meta_window_client_message,
menu_callback, meta_window_show_menu, struct EventScannerData,
check_use_this_motion_notify, meta_window_begin_grab_op,
meta_window_set_user_time):
* src/workspace.[ch] (focus_ancestor_or_mru_window,
meta_workspace_activate_with_focus, meta_workspace_activate,
meta_workspace_focus_default_window,
focus_ancestor_or_mru_window):
Fix issues on 64-bit machines with timestamps by using guint32
(like gtk+ does) instead of Time. #348305
2006-09-13 16:32:33 +00:00
|
|
|
meta_warning ("last_focus_time (%u) is greater than comparison "
|
|
|
|
"timestamp (%u). This most likely represents a buggy "
|
Big patch to cover about 6 different issues in order to correct rare
2005-02-20 Elijah Newren <newren@gmail.com>
Big patch to cover about 6 different issues in order to correct
rare problems with timestamps (make sure window selected in
tasklist actually gets focus, sanity check timestamps to avoid
rogue apps hosing the system, correct the updating of
net_wm_user_time, correctly handle timestamps of 0 when comparing
xserver timestamps for those who have had their systems up for
over 25 days or so, add some debugging information to verbose
logs, some code cleanups). Fixes all issues listed in #167358.
* src/display.h: (struct _MetaDisplay): clarify comment on
last_focus_time, introduce a new variable--last_user_time,
(XSERVER_TIME_IS_BEFORE macro): put this functionality into a
separate macro and then introduce a new macro with this name that
uses the old one but adds additional special-case checks for
timestamps that are 0, (comment to
meta_display_set_input_focus_window): add information about how
last_user_time should be used in this function
* src/display.c (santiy_check_timestamps): new function,
(meta_display_open): intialize display->last_user_time,
(meta_display_get_current_time_roundtrip): use the timestamp,
which is known to be good, in order to sanity_check_timestamps,
(event_callback): use the new meta_window_ste_user_time() function
in order to correct problems, use the timestamp of KeyPress and
ButtonPress events, which are known to be good, in order to
sanity_check_timestamps, (timestamp_too_old): new function for
common behavior of meta_display_focus_the_no_focus_window and
meta_display_set_input_focus_window, with added checking for
display->last_user_time in addition to display->last_focus_time,
(meta_display_set_input_focus_window): replace some of the code
with a call to timestamp_too_old(),
(meta_display_focus_the_no_focus_window): replace some of th ecode
with a call to timestamp_too_old()
* src/window.h: (meta_window_set_user_time): new function to
abstract the many things that need to be done when updating the
net_wm_user_time of any window
* src/window.c: (meta_window_activate): add debugging spew, make
sure the comparison is made with last_user_time NOT
last_focus_time, use meta_window_set_user_time() function in order
to correct problems, (meta_window_client_message): add a newline
to a debugging message to make them easier to read,
(meta_window_set_user_time): new function
* src/window-props.c (reload_net_wm_user_time): use the new
meta_window_ste_user_time() function in order to correct problems
2005-02-20 17:14:16 +00:00
|
|
|
"client sending inaccurate timestamps in messages such as "
|
|
|
|
"_NET_ACTIVE_WINDOW. Trying to work around...\n",
|
Fix issues on 64-bit machines with timestamps by using guint32 (like gtk+
2006-09-13 Elijah Newren <newren gmail com>
* src/common.h (MetaWindowMenuFunc):
* src/core.[ch] (meta_core_user_lower_and_unfocus,
meta_core_user_focus, meta_core_show_window_menu,
meta_core_begin_grab_op, meta_core_end_grab_op):
* src/delete.c (delete_ping_reply_func, delete_ping_timeout_func,
meta_window_delete):
* src/display.[ch] (struct MetaDisplay, struct MetaPingData,
sanity_check_timestamps, meta_display_open, event_callback,
meta_spew_event, meta_display_set_grab_op_cursor,
meta_display_begin_grab_op, meta_display_end_grab_op,
meta_display_ping_timeout, meta_display_ping_window,
process_pong_message, timestamp_too_old,
meta_display_set_input_focus_window):
* src/keybindings.[ch] (grab_keyboard, ungrab_keyboard,
meta_screen_grab_all_keys, meta_window_grab_all_keys,
meta_window_ungrab_all_keys, error_on_generic_command,
error_on_command, error_on_terminal_command):
* src/metacity-dialog.c (on_realize, warn_about_no_sm_support,
error_about_command, main):
* src/screen.[ch] (struct _MetaScreen, meta_screen_new,
meta_screen_show_desktop, meta_screen_apply_startup_properties):
* src/session.c (warn_about_lame_clients_and_finish_interact):
* src/window.[ch] (struct _MetaWindow,
intervening_user_event_occurred, window_activate,
meta_window_delete, meta_window_focus,
meta_window_send_icccm_message, meta_window_client_message,
menu_callback, meta_window_show_menu, struct EventScannerData,
check_use_this_motion_notify, meta_window_begin_grab_op,
meta_window_set_user_time):
* src/workspace.[ch] (focus_ancestor_or_mru_window,
meta_workspace_activate_with_focus, meta_workspace_activate,
meta_workspace_focus_default_window,
focus_ancestor_or_mru_window):
Fix issues on 64-bit machines with timestamps by using guint32
(like gtk+ does) instead of Time. #348305
2006-09-13 16:32:33 +00:00
|
|
|
display->last_focus_time, timestamp);
|
Big patch to cover about 6 different issues in order to correct rare
2005-02-20 Elijah Newren <newren@gmail.com>
Big patch to cover about 6 different issues in order to correct
rare problems with timestamps (make sure window selected in
tasklist actually gets focus, sanity check timestamps to avoid
rogue apps hosing the system, correct the updating of
net_wm_user_time, correctly handle timestamps of 0 when comparing
xserver timestamps for those who have had their systems up for
over 25 days or so, add some debugging information to verbose
logs, some code cleanups). Fixes all issues listed in #167358.
* src/display.h: (struct _MetaDisplay): clarify comment on
last_focus_time, introduce a new variable--last_user_time,
(XSERVER_TIME_IS_BEFORE macro): put this functionality into a
separate macro and then introduce a new macro with this name that
uses the old one but adds additional special-case checks for
timestamps that are 0, (comment to
meta_display_set_input_focus_window): add information about how
last_user_time should be used in this function
* src/display.c (santiy_check_timestamps): new function,
(meta_display_open): intialize display->last_user_time,
(meta_display_get_current_time_roundtrip): use the timestamp,
which is known to be good, in order to sanity_check_timestamps,
(event_callback): use the new meta_window_ste_user_time() function
in order to correct problems, use the timestamp of KeyPress and
ButtonPress events, which are known to be good, in order to
sanity_check_timestamps, (timestamp_too_old): new function for
common behavior of meta_display_focus_the_no_focus_window and
meta_display_set_input_focus_window, with added checking for
display->last_user_time in addition to display->last_focus_time,
(meta_display_set_input_focus_window): replace some of the code
with a call to timestamp_too_old(),
(meta_display_focus_the_no_focus_window): replace some of th ecode
with a call to timestamp_too_old()
* src/window.h: (meta_window_set_user_time): new function to
abstract the many things that need to be done when updating the
net_wm_user_time of any window
* src/window.c: (meta_window_activate): add debugging spew, make
sure the comparison is made with last_user_time NOT
last_focus_time, use meta_window_set_user_time() function in order
to correct problems, (meta_window_client_message): add a newline
to a debugging message to make them easier to read,
(meta_window_set_user_time): new function
* src/window-props.c (reload_net_wm_user_time): use the new
meta_window_ste_user_time() function in order to correct problems
2005-02-20 17:14:16 +00:00
|
|
|
display->last_focus_time = timestamp;
|
|
|
|
}
|
|
|
|
if (XSERVER_TIME_IS_BEFORE (timestamp, display->last_user_time))
|
|
|
|
{
|
|
|
|
GSList *windows;
|
|
|
|
GSList *tmp;
|
|
|
|
|
Fix issues on 64-bit machines with timestamps by using guint32 (like gtk+
2006-09-13 Elijah Newren <newren gmail com>
* src/common.h (MetaWindowMenuFunc):
* src/core.[ch] (meta_core_user_lower_and_unfocus,
meta_core_user_focus, meta_core_show_window_menu,
meta_core_begin_grab_op, meta_core_end_grab_op):
* src/delete.c (delete_ping_reply_func, delete_ping_timeout_func,
meta_window_delete):
* src/display.[ch] (struct MetaDisplay, struct MetaPingData,
sanity_check_timestamps, meta_display_open, event_callback,
meta_spew_event, meta_display_set_grab_op_cursor,
meta_display_begin_grab_op, meta_display_end_grab_op,
meta_display_ping_timeout, meta_display_ping_window,
process_pong_message, timestamp_too_old,
meta_display_set_input_focus_window):
* src/keybindings.[ch] (grab_keyboard, ungrab_keyboard,
meta_screen_grab_all_keys, meta_window_grab_all_keys,
meta_window_ungrab_all_keys, error_on_generic_command,
error_on_command, error_on_terminal_command):
* src/metacity-dialog.c (on_realize, warn_about_no_sm_support,
error_about_command, main):
* src/screen.[ch] (struct _MetaScreen, meta_screen_new,
meta_screen_show_desktop, meta_screen_apply_startup_properties):
* src/session.c (warn_about_lame_clients_and_finish_interact):
* src/window.[ch] (struct _MetaWindow,
intervening_user_event_occurred, window_activate,
meta_window_delete, meta_window_focus,
meta_window_send_icccm_message, meta_window_client_message,
menu_callback, meta_window_show_menu, struct EventScannerData,
check_use_this_motion_notify, meta_window_begin_grab_op,
meta_window_set_user_time):
* src/workspace.[ch] (focus_ancestor_or_mru_window,
meta_workspace_activate_with_focus, meta_workspace_activate,
meta_workspace_focus_default_window,
focus_ancestor_or_mru_window):
Fix issues on 64-bit machines with timestamps by using guint32
(like gtk+ does) instead of Time. #348305
2006-09-13 16:32:33 +00:00
|
|
|
meta_warning ("last_user_time (%u) is greater than comparison "
|
|
|
|
"timestamp (%u). This most likely represents a buggy "
|
Big patch to cover about 6 different issues in order to correct rare
2005-02-20 Elijah Newren <newren@gmail.com>
Big patch to cover about 6 different issues in order to correct
rare problems with timestamps (make sure window selected in
tasklist actually gets focus, sanity check timestamps to avoid
rogue apps hosing the system, correct the updating of
net_wm_user_time, correctly handle timestamps of 0 when comparing
xserver timestamps for those who have had their systems up for
over 25 days or so, add some debugging information to verbose
logs, some code cleanups). Fixes all issues listed in #167358.
* src/display.h: (struct _MetaDisplay): clarify comment on
last_focus_time, introduce a new variable--last_user_time,
(XSERVER_TIME_IS_BEFORE macro): put this functionality into a
separate macro and then introduce a new macro with this name that
uses the old one but adds additional special-case checks for
timestamps that are 0, (comment to
meta_display_set_input_focus_window): add information about how
last_user_time should be used in this function
* src/display.c (santiy_check_timestamps): new function,
(meta_display_open): intialize display->last_user_time,
(meta_display_get_current_time_roundtrip): use the timestamp,
which is known to be good, in order to sanity_check_timestamps,
(event_callback): use the new meta_window_ste_user_time() function
in order to correct problems, use the timestamp of KeyPress and
ButtonPress events, which are known to be good, in order to
sanity_check_timestamps, (timestamp_too_old): new function for
common behavior of meta_display_focus_the_no_focus_window and
meta_display_set_input_focus_window, with added checking for
display->last_user_time in addition to display->last_focus_time,
(meta_display_set_input_focus_window): replace some of the code
with a call to timestamp_too_old(),
(meta_display_focus_the_no_focus_window): replace some of th ecode
with a call to timestamp_too_old()
* src/window.h: (meta_window_set_user_time): new function to
abstract the many things that need to be done when updating the
net_wm_user_time of any window
* src/window.c: (meta_window_activate): add debugging spew, make
sure the comparison is made with last_user_time NOT
last_focus_time, use meta_window_set_user_time() function in order
to correct problems, (meta_window_client_message): add a newline
to a debugging message to make them easier to read,
(meta_window_set_user_time): new function
* src/window-props.c (reload_net_wm_user_time): use the new
meta_window_ste_user_time() function in order to correct problems
2005-02-20 17:14:16 +00:00
|
|
|
"client sending inaccurate timestamps in messages such as "
|
|
|
|
"_NET_ACTIVE_WINDOW. Trying to work around...\n",
|
Fix issues on 64-bit machines with timestamps by using guint32 (like gtk+
2006-09-13 Elijah Newren <newren gmail com>
* src/common.h (MetaWindowMenuFunc):
* src/core.[ch] (meta_core_user_lower_and_unfocus,
meta_core_user_focus, meta_core_show_window_menu,
meta_core_begin_grab_op, meta_core_end_grab_op):
* src/delete.c (delete_ping_reply_func, delete_ping_timeout_func,
meta_window_delete):
* src/display.[ch] (struct MetaDisplay, struct MetaPingData,
sanity_check_timestamps, meta_display_open, event_callback,
meta_spew_event, meta_display_set_grab_op_cursor,
meta_display_begin_grab_op, meta_display_end_grab_op,
meta_display_ping_timeout, meta_display_ping_window,
process_pong_message, timestamp_too_old,
meta_display_set_input_focus_window):
* src/keybindings.[ch] (grab_keyboard, ungrab_keyboard,
meta_screen_grab_all_keys, meta_window_grab_all_keys,
meta_window_ungrab_all_keys, error_on_generic_command,
error_on_command, error_on_terminal_command):
* src/metacity-dialog.c (on_realize, warn_about_no_sm_support,
error_about_command, main):
* src/screen.[ch] (struct _MetaScreen, meta_screen_new,
meta_screen_show_desktop, meta_screen_apply_startup_properties):
* src/session.c (warn_about_lame_clients_and_finish_interact):
* src/window.[ch] (struct _MetaWindow,
intervening_user_event_occurred, window_activate,
meta_window_delete, meta_window_focus,
meta_window_send_icccm_message, meta_window_client_message,
menu_callback, meta_window_show_menu, struct EventScannerData,
check_use_this_motion_notify, meta_window_begin_grab_op,
meta_window_set_user_time):
* src/workspace.[ch] (focus_ancestor_or_mru_window,
meta_workspace_activate_with_focus, meta_workspace_activate,
meta_workspace_focus_default_window,
focus_ancestor_or_mru_window):
Fix issues on 64-bit machines with timestamps by using guint32
(like gtk+ does) instead of Time. #348305
2006-09-13 16:32:33 +00:00
|
|
|
display->last_user_time, timestamp);
|
Big patch to cover about 6 different issues in order to correct rare
2005-02-20 Elijah Newren <newren@gmail.com>
Big patch to cover about 6 different issues in order to correct
rare problems with timestamps (make sure window selected in
tasklist actually gets focus, sanity check timestamps to avoid
rogue apps hosing the system, correct the updating of
net_wm_user_time, correctly handle timestamps of 0 when comparing
xserver timestamps for those who have had their systems up for
over 25 days or so, add some debugging information to verbose
logs, some code cleanups). Fixes all issues listed in #167358.
* src/display.h: (struct _MetaDisplay): clarify comment on
last_focus_time, introduce a new variable--last_user_time,
(XSERVER_TIME_IS_BEFORE macro): put this functionality into a
separate macro and then introduce a new macro with this name that
uses the old one but adds additional special-case checks for
timestamps that are 0, (comment to
meta_display_set_input_focus_window): add information about how
last_user_time should be used in this function
* src/display.c (santiy_check_timestamps): new function,
(meta_display_open): intialize display->last_user_time,
(meta_display_get_current_time_roundtrip): use the timestamp,
which is known to be good, in order to sanity_check_timestamps,
(event_callback): use the new meta_window_ste_user_time() function
in order to correct problems, use the timestamp of KeyPress and
ButtonPress events, which are known to be good, in order to
sanity_check_timestamps, (timestamp_too_old): new function for
common behavior of meta_display_focus_the_no_focus_window and
meta_display_set_input_focus_window, with added checking for
display->last_user_time in addition to display->last_focus_time,
(meta_display_set_input_focus_window): replace some of the code
with a call to timestamp_too_old(),
(meta_display_focus_the_no_focus_window): replace some of th ecode
with a call to timestamp_too_old()
* src/window.h: (meta_window_set_user_time): new function to
abstract the many things that need to be done when updating the
net_wm_user_time of any window
* src/window.c: (meta_window_activate): add debugging spew, make
sure the comparison is made with last_user_time NOT
last_focus_time, use meta_window_set_user_time() function in order
to correct problems, (meta_window_client_message): add a newline
to a debugging message to make them easier to read,
(meta_window_set_user_time): new function
* src/window-props.c (reload_net_wm_user_time): use the new
meta_window_ste_user_time() function in order to correct problems
2005-02-20 17:14:16 +00:00
|
|
|
display->last_user_time = timestamp;
|
|
|
|
|
2009-06-15 19:32:23 +00:00
|
|
|
windows = meta_display_list_windows (display, META_LIST_DEFAULT);
|
Big patch to cover about 6 different issues in order to correct rare
2005-02-20 Elijah Newren <newren@gmail.com>
Big patch to cover about 6 different issues in order to correct
rare problems with timestamps (make sure window selected in
tasklist actually gets focus, sanity check timestamps to avoid
rogue apps hosing the system, correct the updating of
net_wm_user_time, correctly handle timestamps of 0 when comparing
xserver timestamps for those who have had their systems up for
over 25 days or so, add some debugging information to verbose
logs, some code cleanups). Fixes all issues listed in #167358.
* src/display.h: (struct _MetaDisplay): clarify comment on
last_focus_time, introduce a new variable--last_user_time,
(XSERVER_TIME_IS_BEFORE macro): put this functionality into a
separate macro and then introduce a new macro with this name that
uses the old one but adds additional special-case checks for
timestamps that are 0, (comment to
meta_display_set_input_focus_window): add information about how
last_user_time should be used in this function
* src/display.c (santiy_check_timestamps): new function,
(meta_display_open): intialize display->last_user_time,
(meta_display_get_current_time_roundtrip): use the timestamp,
which is known to be good, in order to sanity_check_timestamps,
(event_callback): use the new meta_window_ste_user_time() function
in order to correct problems, use the timestamp of KeyPress and
ButtonPress events, which are known to be good, in order to
sanity_check_timestamps, (timestamp_too_old): new function for
common behavior of meta_display_focus_the_no_focus_window and
meta_display_set_input_focus_window, with added checking for
display->last_user_time in addition to display->last_focus_time,
(meta_display_set_input_focus_window): replace some of the code
with a call to timestamp_too_old(),
(meta_display_focus_the_no_focus_window): replace some of th ecode
with a call to timestamp_too_old()
* src/window.h: (meta_window_set_user_time): new function to
abstract the many things that need to be done when updating the
net_wm_user_time of any window
* src/window.c: (meta_window_activate): add debugging spew, make
sure the comparison is made with last_user_time NOT
last_focus_time, use meta_window_set_user_time() function in order
to correct problems, (meta_window_client_message): add a newline
to a debugging message to make them easier to read,
(meta_window_set_user_time): new function
* src/window-props.c (reload_net_wm_user_time): use the new
meta_window_ste_user_time() function in order to correct problems
2005-02-20 17:14:16 +00:00
|
|
|
tmp = windows;
|
|
|
|
while (tmp != NULL)
|
|
|
|
{
|
|
|
|
MetaWindow *window = tmp->data;
|
2014-05-02 13:34:02 +00:00
|
|
|
|
Big patch to cover about 6 different issues in order to correct rare
2005-02-20 Elijah Newren <newren@gmail.com>
Big patch to cover about 6 different issues in order to correct
rare problems with timestamps (make sure window selected in
tasklist actually gets focus, sanity check timestamps to avoid
rogue apps hosing the system, correct the updating of
net_wm_user_time, correctly handle timestamps of 0 when comparing
xserver timestamps for those who have had their systems up for
over 25 days or so, add some debugging information to verbose
logs, some code cleanups). Fixes all issues listed in #167358.
* src/display.h: (struct _MetaDisplay): clarify comment on
last_focus_time, introduce a new variable--last_user_time,
(XSERVER_TIME_IS_BEFORE macro): put this functionality into a
separate macro and then introduce a new macro with this name that
uses the old one but adds additional special-case checks for
timestamps that are 0, (comment to
meta_display_set_input_focus_window): add information about how
last_user_time should be used in this function
* src/display.c (santiy_check_timestamps): new function,
(meta_display_open): intialize display->last_user_time,
(meta_display_get_current_time_roundtrip): use the timestamp,
which is known to be good, in order to sanity_check_timestamps,
(event_callback): use the new meta_window_ste_user_time() function
in order to correct problems, use the timestamp of KeyPress and
ButtonPress events, which are known to be good, in order to
sanity_check_timestamps, (timestamp_too_old): new function for
common behavior of meta_display_focus_the_no_focus_window and
meta_display_set_input_focus_window, with added checking for
display->last_user_time in addition to display->last_focus_time,
(meta_display_set_input_focus_window): replace some of the code
with a call to timestamp_too_old(),
(meta_display_focus_the_no_focus_window): replace some of th ecode
with a call to timestamp_too_old()
* src/window.h: (meta_window_set_user_time): new function to
abstract the many things that need to be done when updating the
net_wm_user_time of any window
* src/window.c: (meta_window_activate): add debugging spew, make
sure the comparison is made with last_user_time NOT
last_focus_time, use meta_window_set_user_time() function in order
to correct problems, (meta_window_client_message): add a newline
to a debugging message to make them easier to read,
(meta_window_set_user_time): new function
* src/window-props.c (reload_net_wm_user_time): use the new
meta_window_ste_user_time() function in order to correct problems
2005-02-20 17:14:16 +00:00
|
|
|
if (XSERVER_TIME_IS_BEFORE (timestamp, window->net_wm_user_time))
|
|
|
|
{
|
|
|
|
meta_warning ("%s appears to be one of the offending windows "
|
Fix issues on 64-bit machines with timestamps by using guint32 (like gtk+
2006-09-13 Elijah Newren <newren gmail com>
* src/common.h (MetaWindowMenuFunc):
* src/core.[ch] (meta_core_user_lower_and_unfocus,
meta_core_user_focus, meta_core_show_window_menu,
meta_core_begin_grab_op, meta_core_end_grab_op):
* src/delete.c (delete_ping_reply_func, delete_ping_timeout_func,
meta_window_delete):
* src/display.[ch] (struct MetaDisplay, struct MetaPingData,
sanity_check_timestamps, meta_display_open, event_callback,
meta_spew_event, meta_display_set_grab_op_cursor,
meta_display_begin_grab_op, meta_display_end_grab_op,
meta_display_ping_timeout, meta_display_ping_window,
process_pong_message, timestamp_too_old,
meta_display_set_input_focus_window):
* src/keybindings.[ch] (grab_keyboard, ungrab_keyboard,
meta_screen_grab_all_keys, meta_window_grab_all_keys,
meta_window_ungrab_all_keys, error_on_generic_command,
error_on_command, error_on_terminal_command):
* src/metacity-dialog.c (on_realize, warn_about_no_sm_support,
error_about_command, main):
* src/screen.[ch] (struct _MetaScreen, meta_screen_new,
meta_screen_show_desktop, meta_screen_apply_startup_properties):
* src/session.c (warn_about_lame_clients_and_finish_interact):
* src/window.[ch] (struct _MetaWindow,
intervening_user_event_occurred, window_activate,
meta_window_delete, meta_window_focus,
meta_window_send_icccm_message, meta_window_client_message,
menu_callback, meta_window_show_menu, struct EventScannerData,
check_use_this_motion_notify, meta_window_begin_grab_op,
meta_window_set_user_time):
* src/workspace.[ch] (focus_ancestor_or_mru_window,
meta_workspace_activate_with_focus, meta_workspace_activate,
meta_workspace_focus_default_window,
focus_ancestor_or_mru_window):
Fix issues on 64-bit machines with timestamps by using guint32
(like gtk+ does) instead of Time. #348305
2006-09-13 16:32:33 +00:00
|
|
|
"with a timestamp of %u. Working around...\n",
|
Big patch to cover about 6 different issues in order to correct rare
2005-02-20 Elijah Newren <newren@gmail.com>
Big patch to cover about 6 different issues in order to correct
rare problems with timestamps (make sure window selected in
tasklist actually gets focus, sanity check timestamps to avoid
rogue apps hosing the system, correct the updating of
net_wm_user_time, correctly handle timestamps of 0 when comparing
xserver timestamps for those who have had their systems up for
over 25 days or so, add some debugging information to verbose
logs, some code cleanups). Fixes all issues listed in #167358.
* src/display.h: (struct _MetaDisplay): clarify comment on
last_focus_time, introduce a new variable--last_user_time,
(XSERVER_TIME_IS_BEFORE macro): put this functionality into a
separate macro and then introduce a new macro with this name that
uses the old one but adds additional special-case checks for
timestamps that are 0, (comment to
meta_display_set_input_focus_window): add information about how
last_user_time should be used in this function
* src/display.c (santiy_check_timestamps): new function,
(meta_display_open): intialize display->last_user_time,
(meta_display_get_current_time_roundtrip): use the timestamp,
which is known to be good, in order to sanity_check_timestamps,
(event_callback): use the new meta_window_ste_user_time() function
in order to correct problems, use the timestamp of KeyPress and
ButtonPress events, which are known to be good, in order to
sanity_check_timestamps, (timestamp_too_old): new function for
common behavior of meta_display_focus_the_no_focus_window and
meta_display_set_input_focus_window, with added checking for
display->last_user_time in addition to display->last_focus_time,
(meta_display_set_input_focus_window): replace some of the code
with a call to timestamp_too_old(),
(meta_display_focus_the_no_focus_window): replace some of th ecode
with a call to timestamp_too_old()
* src/window.h: (meta_window_set_user_time): new function to
abstract the many things that need to be done when updating the
net_wm_user_time of any window
* src/window.c: (meta_window_activate): add debugging spew, make
sure the comparison is made with last_user_time NOT
last_focus_time, use meta_window_set_user_time() function in order
to correct problems, (meta_window_client_message): add a newline
to a debugging message to make them easier to read,
(meta_window_set_user_time): new function
* src/window-props.c (reload_net_wm_user_time): use the new
meta_window_ste_user_time() function in order to correct problems
2005-02-20 17:14:16 +00:00
|
|
|
window->desc, window->net_wm_user_time);
|
2009-09-04 00:58:19 +00:00
|
|
|
meta_window_set_user_time (window, timestamp);
|
Big patch to cover about 6 different issues in order to correct rare
2005-02-20 Elijah Newren <newren@gmail.com>
Big patch to cover about 6 different issues in order to correct
rare problems with timestamps (make sure window selected in
tasklist actually gets focus, sanity check timestamps to avoid
rogue apps hosing the system, correct the updating of
net_wm_user_time, correctly handle timestamps of 0 when comparing
xserver timestamps for those who have had their systems up for
over 25 days or so, add some debugging information to verbose
logs, some code cleanups). Fixes all issues listed in #167358.
* src/display.h: (struct _MetaDisplay): clarify comment on
last_focus_time, introduce a new variable--last_user_time,
(XSERVER_TIME_IS_BEFORE macro): put this functionality into a
separate macro and then introduce a new macro with this name that
uses the old one but adds additional special-case checks for
timestamps that are 0, (comment to
meta_display_set_input_focus_window): add information about how
last_user_time should be used in this function
* src/display.c (santiy_check_timestamps): new function,
(meta_display_open): intialize display->last_user_time,
(meta_display_get_current_time_roundtrip): use the timestamp,
which is known to be good, in order to sanity_check_timestamps,
(event_callback): use the new meta_window_ste_user_time() function
in order to correct problems, use the timestamp of KeyPress and
ButtonPress events, which are known to be good, in order to
sanity_check_timestamps, (timestamp_too_old): new function for
common behavior of meta_display_focus_the_no_focus_window and
meta_display_set_input_focus_window, with added checking for
display->last_user_time in addition to display->last_focus_time,
(meta_display_set_input_focus_window): replace some of the code
with a call to timestamp_too_old(),
(meta_display_focus_the_no_focus_window): replace some of th ecode
with a call to timestamp_too_old()
* src/window.h: (meta_window_set_user_time): new function to
abstract the many things that need to be done when updating the
net_wm_user_time of any window
* src/window.c: (meta_window_activate): add debugging spew, make
sure the comparison is made with last_user_time NOT
last_focus_time, use meta_window_set_user_time() function in order
to correct problems, (meta_window_client_message): add a newline
to a debugging message to make them easier to read,
(meta_window_set_user_time): new function
* src/window-props.c (reload_net_wm_user_time): use the new
meta_window_ste_user_time() function in order to correct problems
2005-02-20 17:14:16 +00:00
|
|
|
}
|
2009-09-04 00:58:19 +00:00
|
|
|
|
Big patch to cover about 6 different issues in order to correct rare
2005-02-20 Elijah Newren <newren@gmail.com>
Big patch to cover about 6 different issues in order to correct
rare problems with timestamps (make sure window selected in
tasklist actually gets focus, sanity check timestamps to avoid
rogue apps hosing the system, correct the updating of
net_wm_user_time, correctly handle timestamps of 0 when comparing
xserver timestamps for those who have had their systems up for
over 25 days or so, add some debugging information to verbose
logs, some code cleanups). Fixes all issues listed in #167358.
* src/display.h: (struct _MetaDisplay): clarify comment on
last_focus_time, introduce a new variable--last_user_time,
(XSERVER_TIME_IS_BEFORE macro): put this functionality into a
separate macro and then introduce a new macro with this name that
uses the old one but adds additional special-case checks for
timestamps that are 0, (comment to
meta_display_set_input_focus_window): add information about how
last_user_time should be used in this function
* src/display.c (santiy_check_timestamps): new function,
(meta_display_open): intialize display->last_user_time,
(meta_display_get_current_time_roundtrip): use the timestamp,
which is known to be good, in order to sanity_check_timestamps,
(event_callback): use the new meta_window_ste_user_time() function
in order to correct problems, use the timestamp of KeyPress and
ButtonPress events, which are known to be good, in order to
sanity_check_timestamps, (timestamp_too_old): new function for
common behavior of meta_display_focus_the_no_focus_window and
meta_display_set_input_focus_window, with added checking for
display->last_user_time in addition to display->last_focus_time,
(meta_display_set_input_focus_window): replace some of the code
with a call to timestamp_too_old(),
(meta_display_focus_the_no_focus_window): replace some of th ecode
with a call to timestamp_too_old()
* src/window.h: (meta_window_set_user_time): new function to
abstract the many things that need to be done when updating the
net_wm_user_time of any window
* src/window.c: (meta_window_activate): add debugging spew, make
sure the comparison is made with last_user_time NOT
last_focus_time, use meta_window_set_user_time() function in order
to correct problems, (meta_window_client_message): add a newline
to a debugging message to make them easier to read,
(meta_window_set_user_time): new function
* src/window-props.c (reload_net_wm_user_time): use the new
meta_window_ste_user_time() function in order to correct problems
2005-02-20 17:14:16 +00:00
|
|
|
tmp = tmp->next;
|
|
|
|
}
|
|
|
|
|
|
|
|
g_slist_free (windows);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2004-10-04 21:09:08 +00:00
|
|
|
void
|
|
|
|
meta_display_remove_autoraise_callback (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
if (display->autoraise_timeout_id != 0)
|
|
|
|
{
|
|
|
|
g_source_remove (display->autoraise_timeout_id);
|
|
|
|
display->autoraise_timeout_id = 0;
|
|
|
|
display->autoraise_window = NULL;
|
|
|
|
}
|
|
|
|
}
|
2008-05-19 00:00:09 +00:00
|
|
|
|
2008-12-02 23:13:11 +00:00
|
|
|
void
|
|
|
|
meta_display_overlay_key_activate (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
g_signal_emit (display, display_signals[OVERLAY_KEY], 0);
|
|
|
|
}
|
|
|
|
|
2012-08-28 13:28:11 +00:00
|
|
|
void
|
2013-10-03 22:03:53 +00:00
|
|
|
meta_display_accelerator_activate (MetaDisplay *display,
|
|
|
|
guint action,
|
|
|
|
ClutterKeyEvent *event)
|
2012-08-28 13:28:11 +00:00
|
|
|
{
|
|
|
|
g_signal_emit (display, display_signals[ACCELERATOR_ACTIVATED],
|
2013-10-03 22:03:53 +00:00
|
|
|
0, action,
|
|
|
|
clutter_input_device_get_device_id (event->device),
|
|
|
|
event->time);
|
2012-08-28 13:28:11 +00:00
|
|
|
}
|
|
|
|
|
2013-04-10 11:34:26 +00:00
|
|
|
gboolean
|
|
|
|
meta_display_modifiers_accelerator_activate (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
gboolean freeze;
|
|
|
|
|
|
|
|
g_signal_emit (display, display_signals[MODIFIERS_ACCELERATOR_ACTIVATED], 0, &freeze);
|
|
|
|
|
|
|
|
return freeze;
|
|
|
|
}
|
|
|
|
|
2012-07-30 18:57:53 +00:00
|
|
|
/**
|
|
|
|
* meta_display_supports_extended_barriers:
|
|
|
|
* @display: a #MetaDisplay
|
|
|
|
*
|
2015-01-16 08:50:51 +00:00
|
|
|
* Returns: whether pointer barriers can be supported.
|
|
|
|
*
|
|
|
|
* When running as an X compositor the X server needs XInput 2
|
|
|
|
* version 2.3. When running as a display server it is supported
|
|
|
|
* when running on the native backend.
|
2012-07-30 18:57:53 +00:00
|
|
|
*
|
|
|
|
* Clients should use this method to determine whether their
|
|
|
|
* interfaces should depend on new barrier features.
|
|
|
|
*/
|
|
|
|
gboolean
|
|
|
|
meta_display_supports_extended_barriers (MetaDisplay *display)
|
|
|
|
{
|
2015-01-16 08:50:51 +00:00
|
|
|
#ifdef HAVE_NATIVE_BACKEND
|
|
|
|
if (META_IS_BACKEND_NATIVE (meta_get_backend ()))
|
|
|
|
return TRUE;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
if (META_IS_BACKEND_X11 (meta_get_backend ()))
|
|
|
|
{
|
2017-08-26 16:28:53 +00:00
|
|
|
return (META_X11_DISPLAY_HAS_XINPUT_23 (display->x11_display) &&
|
2015-01-16 08:50:51 +00:00
|
|
|
!meta_is_wayland_compositor());
|
|
|
|
}
|
|
|
|
|
|
|
|
g_assert_not_reached ();
|
2012-07-30 18:57:53 +00:00
|
|
|
}
|
|
|
|
|
2010-09-01 19:39:53 +00:00
|
|
|
/**
|
|
|
|
* meta_display_get_compositor: (skip)
|
2013-02-15 18:42:08 +00:00
|
|
|
* @display: a #MetaDisplay
|
2010-09-01 19:39:53 +00:00
|
|
|
*
|
|
|
|
*/
|
2008-05-19 00:00:09 +00:00
|
|
|
MetaCompositor *
|
|
|
|
meta_display_get_compositor (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
return display->compositor;
|
|
|
|
}
|
|
|
|
|
2017-08-26 16:24:46 +00:00
|
|
|
/**
|
|
|
|
* meta_display_get_x11_display: (skip)
|
|
|
|
* @display: a #MetaDisplay
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
MetaX11Display *
|
|
|
|
meta_display_get_x11_display (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
return display->x11_display;
|
|
|
|
}
|
|
|
|
|
2017-08-26 16:37:29 +00:00
|
|
|
/**
|
|
|
|
* meta_display_get_size:
|
|
|
|
* @display: A #MetaDisplay
|
|
|
|
* @width: (out): The width of the screen
|
|
|
|
* @height: (out): The height of the screen
|
|
|
|
*
|
|
|
|
* Retrieve the size of the display.
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
meta_display_get_size (MetaDisplay *display,
|
|
|
|
int *width,
|
|
|
|
int *height)
|
|
|
|
{
|
2017-08-27 18:44:38 +00:00
|
|
|
MetaBackend *backend = meta_get_backend ();
|
|
|
|
MetaMonitorManager *monitor_manager =
|
|
|
|
meta_backend_get_monitor_manager (backend);
|
|
|
|
int display_width, display_height;
|
|
|
|
|
|
|
|
meta_monitor_manager_get_screen_size (monitor_manager,
|
|
|
|
&display_width,
|
|
|
|
&display_height);
|
|
|
|
|
2017-08-26 16:37:29 +00:00
|
|
|
if (width != NULL)
|
2017-08-27 18:44:38 +00:00
|
|
|
*width = display_width;
|
2017-08-26 16:37:29 +00:00
|
|
|
|
|
|
|
if (height != NULL)
|
2017-08-27 18:44:38 +00:00
|
|
|
*height = display_height;
|
2017-08-26 16:37:29 +00:00
|
|
|
}
|
|
|
|
|
2008-11-17 21:34:28 +00:00
|
|
|
/**
|
|
|
|
* meta_display_get_focus_window:
|
|
|
|
* @display: a #MetaDisplay
|
|
|
|
*
|
2011-04-26 12:12:04 +00:00
|
|
|
* Get our best guess as to the "currently" focused window (that is,
|
|
|
|
* the window that we expect will be focused at the point when the X
|
|
|
|
* server processes our next request).
|
2008-11-17 21:34:28 +00:00
|
|
|
*
|
|
|
|
* Return Value: (transfer none): The current focus window
|
|
|
|
*/
|
2008-05-19 00:00:09 +00:00
|
|
|
MetaWindow *
|
|
|
|
meta_display_get_focus_window (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
return display->focus_window;
|
|
|
|
}
|
|
|
|
|
2012-04-14 13:12:48 +00:00
|
|
|
/**
|
|
|
|
* meta_display_clear_mouse_mode:
|
|
|
|
* @display: a #MetaDisplay
|
|
|
|
*
|
|
|
|
* Sets the mouse-mode flag to %FALSE, which means that motion events are
|
|
|
|
* no longer ignored in mouse or sloppy focus.
|
|
|
|
* This is an internal function. It should be used only for reimplementing
|
|
|
|
* keybindings, and only in a manner compatible with core code.
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
meta_display_clear_mouse_mode (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
display->mouse_mode = FALSE;
|
|
|
|
}
|
2014-04-23 14:41:09 +00:00
|
|
|
|
2014-06-19 20:28:48 +00:00
|
|
|
MetaGestureTracker *
|
|
|
|
meta_display_get_gesture_tracker (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
return display->gesture_tracker;
|
|
|
|
}
|
2014-05-08 22:35:49 +00:00
|
|
|
|
|
|
|
gboolean
|
|
|
|
meta_display_show_restart_message (MetaDisplay *display,
|
|
|
|
const char *message)
|
|
|
|
{
|
|
|
|
gboolean result = FALSE;
|
|
|
|
|
|
|
|
g_signal_emit (display,
|
|
|
|
display_signals[SHOW_RESTART_MESSAGE], 0,
|
|
|
|
message, &result);
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
|
|
|
gboolean
|
|
|
|
meta_display_request_restart (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
gboolean result = FALSE;
|
|
|
|
|
|
|
|
g_signal_emit (display,
|
|
|
|
display_signals[RESTART], 0,
|
|
|
|
&result);
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
2014-07-21 23:14:14 +00:00
|
|
|
|
2014-12-30 01:20:07 +00:00
|
|
|
gboolean
|
|
|
|
meta_display_show_resize_popup (MetaDisplay *display,
|
|
|
|
gboolean show,
|
|
|
|
MetaRectangle *rect,
|
|
|
|
int display_w,
|
|
|
|
int display_h)
|
|
|
|
{
|
|
|
|
gboolean result = FALSE;
|
|
|
|
|
|
|
|
g_signal_emit (display,
|
|
|
|
display_signals[SHOW_RESIZE_POPUP], 0,
|
|
|
|
show, rect, display_w, display_h, &result);
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
|
2014-07-21 23:14:14 +00:00
|
|
|
/**
|
|
|
|
* meta_display_is_pointer_emulating_sequence:
|
|
|
|
* @display: the display
|
|
|
|
* @sequence: (nullable): a #ClutterEventSequence
|
|
|
|
*
|
|
|
|
* Tells whether the event sequence is the used for pointer emulation
|
|
|
|
* and single-touch interaction.
|
|
|
|
*
|
|
|
|
* Returns: #TRUE if the sequence emulates pointer behavior
|
|
|
|
**/
|
|
|
|
gboolean
|
|
|
|
meta_display_is_pointer_emulating_sequence (MetaDisplay *display,
|
|
|
|
ClutterEventSequence *sequence)
|
|
|
|
{
|
|
|
|
if (!sequence)
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
return display->pointer_emulating_sequence == sequence;
|
|
|
|
}
|
2014-09-11 14:09:43 +00:00
|
|
|
|
2016-06-22 17:17:40 +00:00
|
|
|
void
|
|
|
|
meta_display_request_pad_osd (MetaDisplay *display,
|
|
|
|
ClutterInputDevice *pad,
|
|
|
|
gboolean edition_mode)
|
|
|
|
{
|
2016-12-01 04:59:47 +00:00
|
|
|
MetaBackend *backend = meta_get_backend ();
|
2016-06-22 17:17:40 +00:00
|
|
|
MetaInputSettings *input_settings;
|
|
|
|
const gchar *layout_path = NULL;
|
|
|
|
ClutterActor *osd;
|
2016-11-25 06:31:38 +00:00
|
|
|
MetaLogicalMonitor *logical_monitor;
|
2016-06-22 17:17:40 +00:00
|
|
|
GSettings *settings;
|
|
|
|
#ifdef HAVE_LIBWACOM
|
|
|
|
WacomDevice *wacom_device;
|
|
|
|
#endif
|
|
|
|
|
2016-10-17 16:02:50 +00:00
|
|
|
/* Avoid emitting the signal while there is an OSD being currently
|
|
|
|
* displayed, the first OSD will have to be dismissed before showing
|
|
|
|
* any other one.
|
|
|
|
*/
|
2016-06-22 17:17:40 +00:00
|
|
|
if (display->current_pad_osd)
|
2016-10-17 16:02:50 +00:00
|
|
|
return;
|
|
|
|
|
|
|
|
input_settings = meta_backend_get_input_settings (meta_get_backend ());
|
2016-06-22 17:17:40 +00:00
|
|
|
|
|
|
|
if (input_settings)
|
|
|
|
{
|
|
|
|
settings = meta_input_settings_get_tablet_settings (input_settings, pad);
|
2016-11-25 06:31:38 +00:00
|
|
|
logical_monitor =
|
|
|
|
meta_input_settings_get_tablet_logical_monitor (input_settings, pad);
|
2016-06-22 17:17:40 +00:00
|
|
|
#ifdef HAVE_LIBWACOM
|
|
|
|
wacom_device = meta_input_settings_get_tablet_wacom_device (input_settings,
|
|
|
|
pad);
|
|
|
|
layout_path = libwacom_get_layout_filename (wacom_device);
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!layout_path || !settings)
|
|
|
|
return;
|
|
|
|
|
2016-12-01 04:55:21 +00:00
|
|
|
if (!logical_monitor)
|
2016-12-01 04:59:47 +00:00
|
|
|
logical_monitor = meta_backend_get_current_logical_monitor (backend);
|
2016-06-22 17:17:40 +00:00
|
|
|
|
|
|
|
g_signal_emit (display, display_signals[SHOW_PAD_OSD], 0,
|
|
|
|
pad, settings, layout_path,
|
2016-12-01 04:55:21 +00:00
|
|
|
edition_mode, logical_monitor->number, &osd);
|
2016-06-22 17:17:40 +00:00
|
|
|
|
|
|
|
if (osd)
|
|
|
|
{
|
|
|
|
display->current_pad_osd = osd;
|
|
|
|
g_object_add_weak_pointer (G_OBJECT (display->current_pad_osd),
|
|
|
|
(gpointer *) &display->current_pad_osd);
|
|
|
|
}
|
|
|
|
|
|
|
|
g_object_unref (settings);
|
|
|
|
}
|
|
|
|
|
2016-06-22 17:10:13 +00:00
|
|
|
gchar *
|
|
|
|
meta_display_get_pad_action_label (MetaDisplay *display,
|
|
|
|
ClutterInputDevice *pad,
|
|
|
|
MetaPadActionType action_type,
|
|
|
|
guint action_number)
|
|
|
|
{
|
2017-07-05 11:35:31 +00:00
|
|
|
MetaInputSettings *settings;
|
2016-06-22 17:10:13 +00:00
|
|
|
gchar *label;
|
|
|
|
|
|
|
|
/* First, lookup the action, as imposed by settings */
|
2017-07-05 11:35:31 +00:00
|
|
|
settings = meta_backend_get_input_settings (meta_get_backend ());
|
|
|
|
label = meta_input_settings_get_pad_action_label (settings, pad, action_type, action_number);
|
|
|
|
if (label)
|
|
|
|
return label;
|
2016-06-22 17:10:13 +00:00
|
|
|
|
|
|
|
#ifdef HAVE_WAYLAND
|
|
|
|
/* Second, if this wayland, lookup the actions set by the clients */
|
|
|
|
if (meta_is_wayland_compositor ())
|
|
|
|
{
|
|
|
|
MetaWaylandCompositor *compositor;
|
|
|
|
MetaWaylandTabletSeat *tablet_seat;
|
|
|
|
MetaWaylandTabletPad *tablet_pad = NULL;
|
|
|
|
|
|
|
|
compositor = meta_wayland_compositor_get_default ();
|
|
|
|
tablet_seat = meta_wayland_tablet_manager_ensure_seat (compositor->tablet_manager,
|
|
|
|
compositor->seat);
|
|
|
|
if (tablet_seat)
|
|
|
|
tablet_pad = meta_wayland_tablet_seat_lookup_pad (tablet_seat, pad);
|
|
|
|
|
|
|
|
if (tablet_pad)
|
|
|
|
{
|
|
|
|
label = meta_wayland_tablet_pad_get_label (tablet_pad, action_type,
|
|
|
|
action_number);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (label)
|
|
|
|
return label;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
2016-12-28 11:03:29 +00:00
|
|
|
|
|
|
|
static void
|
|
|
|
meta_display_show_osd (MetaDisplay *display,
|
|
|
|
gint monitor_idx,
|
|
|
|
const gchar *icon_name,
|
|
|
|
const gchar *message)
|
|
|
|
{
|
|
|
|
g_signal_emit (display, display_signals[SHOW_OSD], 0,
|
|
|
|
monitor_idx, icon_name, message);
|
|
|
|
}
|
|
|
|
|
|
|
|
static gint
|
|
|
|
lookup_tablet_monitor (MetaDisplay *display,
|
|
|
|
ClutterInputDevice *device)
|
|
|
|
{
|
|
|
|
MetaInputSettings *input_settings;
|
|
|
|
MetaLogicalMonitor *monitor;
|
|
|
|
gint monitor_idx = -1;
|
|
|
|
|
|
|
|
input_settings = meta_backend_get_input_settings (meta_get_backend ());
|
|
|
|
if (!input_settings)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
monitor = meta_input_settings_get_tablet_logical_monitor (input_settings, device);
|
|
|
|
|
|
|
|
if (monitor)
|
|
|
|
{
|
2017-08-26 19:22:34 +00:00
|
|
|
monitor_idx = meta_display_get_monitor_index_for_rect (display,
|
|
|
|
&monitor->rect);
|
2016-12-28 11:03:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return monitor_idx;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_show_tablet_mapping_notification (MetaDisplay *display,
|
|
|
|
ClutterInputDevice *pad,
|
|
|
|
const gchar *pretty_name)
|
|
|
|
{
|
|
|
|
if (!pretty_name)
|
|
|
|
pretty_name = clutter_input_device_get_device_name (pad);
|
|
|
|
meta_display_show_osd (display, lookup_tablet_monitor (display, pad),
|
|
|
|
"input-tablet-symbolic", pretty_name);
|
|
|
|
}
|
2016-12-28 11:10:23 +00:00
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_notify_pad_group_switch (MetaDisplay *display,
|
|
|
|
ClutterInputDevice *pad,
|
|
|
|
const gchar *pretty_name,
|
|
|
|
guint n_group,
|
|
|
|
guint n_mode,
|
|
|
|
guint n_modes)
|
|
|
|
{
|
|
|
|
GString *message;
|
|
|
|
guint i;
|
|
|
|
|
|
|
|
if (!pretty_name)
|
|
|
|
pretty_name = clutter_input_device_get_device_name (pad);
|
|
|
|
|
|
|
|
message = g_string_new (pretty_name);
|
|
|
|
g_string_append_c (message, '\n');
|
|
|
|
for (i = 0; i < n_modes; i++)
|
|
|
|
g_string_append (message, (i == n_mode) ? "⚫" : "⚪");
|
|
|
|
|
|
|
|
meta_display_show_osd (display, lookup_tablet_monitor (display, pad),
|
|
|
|
"input-tablet-symbolic", message->str);
|
|
|
|
|
2016-12-28 12:00:18 +00:00
|
|
|
g_signal_emit (display, display_signals[PAD_MODE_SWITCH], 0, pad,
|
|
|
|
n_group, n_mode);
|
|
|
|
|
2016-12-28 11:10:23 +00:00
|
|
|
g_string_free (message, TRUE);
|
|
|
|
}
|
2017-08-26 16:37:29 +00:00
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_foreach_window (MetaDisplay *display,
|
|
|
|
MetaListWindowsFlags flags,
|
|
|
|
MetaDisplayWindowFunc func,
|
|
|
|
gpointer data)
|
|
|
|
{
|
|
|
|
GSList *windows;
|
|
|
|
|
|
|
|
/* If we end up doing this often, just keeping a list
|
|
|
|
* of windows might be sensible.
|
|
|
|
*/
|
|
|
|
|
|
|
|
windows = meta_display_list_windows (display, flags);
|
|
|
|
|
|
|
|
g_slist_foreach (windows, (GFunc) func, data);
|
|
|
|
|
|
|
|
g_slist_free (windows);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
meta_display_resize_func (MetaWindow *window,
|
|
|
|
gpointer user_data)
|
|
|
|
{
|
|
|
|
if (window->struts)
|
|
|
|
{
|
|
|
|
meta_window_update_struts (window);
|
|
|
|
}
|
|
|
|
meta_window_queue (window, META_QUEUE_MOVE_RESIZE);
|
|
|
|
|
|
|
|
meta_window_recalc_features (window);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
on_monitors_changed_internal (MetaMonitorManager *monitor_manager,
|
|
|
|
MetaDisplay *display)
|
|
|
|
{
|
|
|
|
MetaBackend *backend;
|
|
|
|
MetaCursorRenderer *cursor_renderer;
|
|
|
|
|
2017-08-26 19:39:46 +00:00
|
|
|
reload_logical_monitors (display);
|
|
|
|
|
2017-08-26 16:37:29 +00:00
|
|
|
/* Fix up monitor for all windows on this display */
|
|
|
|
meta_display_foreach_window (display, META_LIST_INCLUDE_OVERRIDE_REDIRECT,
|
|
|
|
(MetaDisplayWindowFunc)
|
|
|
|
meta_window_update_for_monitors_changed, 0);
|
|
|
|
|
|
|
|
/* Queue a resize on all the windows */
|
|
|
|
meta_display_foreach_window (display, META_LIST_DEFAULT,
|
|
|
|
meta_display_resize_func, 0);
|
|
|
|
|
2017-08-26 19:10:38 +00:00
|
|
|
meta_display_queue_check_fullscreen (display);
|
|
|
|
|
2017-08-26 16:37:29 +00:00
|
|
|
backend = meta_get_backend ();
|
|
|
|
cursor_renderer = meta_backend_get_cursor_renderer (backend);
|
|
|
|
meta_cursor_renderer_force_update (cursor_renderer);
|
|
|
|
}
|
|
|
|
|
2017-08-26 17:03:51 +00:00
|
|
|
void
|
|
|
|
meta_display_restacked (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
g_signal_emit (display, display_signals[RESTACKED], 0);
|
|
|
|
}
|
2017-08-26 19:10:38 +00:00
|
|
|
|
|
|
|
static gboolean
|
|
|
|
meta_display_update_tile_preview_timeout (gpointer data)
|
|
|
|
{
|
|
|
|
MetaDisplay *display = data;
|
|
|
|
MetaWindow *window = display->grab_window;
|
|
|
|
gboolean needs_preview = FALSE;
|
|
|
|
|
|
|
|
display->tile_preview_timeout_id = 0;
|
|
|
|
|
|
|
|
if (window)
|
|
|
|
{
|
|
|
|
switch (display->preview_tile_mode)
|
|
|
|
{
|
|
|
|
case META_TILE_LEFT:
|
|
|
|
case META_TILE_RIGHT:
|
|
|
|
if (!META_WINDOW_TILED_SIDE_BY_SIDE (window))
|
|
|
|
needs_preview = TRUE;
|
|
|
|
break;
|
|
|
|
|
|
|
|
case META_TILE_MAXIMIZED:
|
|
|
|
if (!META_WINDOW_MAXIMIZED (window))
|
|
|
|
needs_preview = TRUE;
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
|
|
|
needs_preview = FALSE;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (needs_preview)
|
|
|
|
{
|
|
|
|
MetaRectangle tile_rect;
|
|
|
|
int monitor;
|
|
|
|
|
|
|
|
monitor = meta_window_get_current_tile_monitor_number (window);
|
|
|
|
meta_window_get_tile_area (window, display->preview_tile_mode,
|
|
|
|
&tile_rect);
|
|
|
|
meta_compositor_show_tile_preview (display->compositor,
|
|
|
|
window, &tile_rect, monitor);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
meta_compositor_hide_tile_preview (display->compositor);
|
|
|
|
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
#define TILE_PREVIEW_TIMEOUT_MS 200
|
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_update_tile_preview (MetaDisplay *display,
|
|
|
|
gboolean delay)
|
|
|
|
{
|
|
|
|
if (delay)
|
|
|
|
{
|
|
|
|
if (display->tile_preview_timeout_id > 0)
|
|
|
|
return;
|
|
|
|
|
|
|
|
display->tile_preview_timeout_id =
|
|
|
|
g_timeout_add (TILE_PREVIEW_TIMEOUT_MS,
|
|
|
|
meta_display_update_tile_preview_timeout,
|
|
|
|
display);
|
|
|
|
g_source_set_name_by_id (display->tile_preview_timeout_id,
|
|
|
|
"[mutter] meta_display_update_tile_preview_timeout");
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if (display->tile_preview_timeout_id > 0)
|
|
|
|
g_source_remove (display->tile_preview_timeout_id);
|
|
|
|
|
|
|
|
meta_display_update_tile_preview_timeout ((gpointer)display);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_hide_tile_preview (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
if (display->tile_preview_timeout_id > 0)
|
|
|
|
g_source_remove (display->tile_preview_timeout_id);
|
|
|
|
|
|
|
|
display->preview_tile_mode = META_TILE_NONE;
|
|
|
|
meta_compositor_hide_tile_preview (display->compositor);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* meta_display_get_startup_sequences: (skip)
|
|
|
|
* @display:
|
|
|
|
*
|
|
|
|
* Return value: (transfer none): Currently active #SnStartupSequence items
|
|
|
|
*/
|
|
|
|
GSList *
|
|
|
|
meta_display_get_startup_sequences (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
return display->startup_sequences;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Sets the initial_timestamp and initial_workspace properties
|
|
|
|
* of a window according to information given us by the
|
|
|
|
* startup-notification library.
|
|
|
|
*
|
|
|
|
* Returns TRUE if startup properties have been applied, and
|
|
|
|
* FALSE if they have not (for example, if they had already
|
|
|
|
* been applied.)
|
|
|
|
*/
|
|
|
|
gboolean
|
|
|
|
meta_display_apply_startup_properties (MetaDisplay *display,
|
|
|
|
MetaWindow *window)
|
|
|
|
{
|
|
|
|
#ifdef HAVE_STARTUP_NOTIFICATION
|
|
|
|
const char *startup_id;
|
|
|
|
GSList *l;
|
|
|
|
SnStartupSequence *sequence;
|
|
|
|
|
|
|
|
/* Does the window have a startup ID stored? */
|
|
|
|
startup_id = meta_window_get_startup_id (window);
|
|
|
|
|
|
|
|
meta_topic (META_DEBUG_STARTUP,
|
|
|
|
"Applying startup props to %s id \"%s\"\n",
|
|
|
|
window->desc,
|
|
|
|
startup_id ? startup_id : "(none)");
|
|
|
|
|
|
|
|
sequence = NULL;
|
|
|
|
if (!startup_id)
|
|
|
|
{
|
|
|
|
/* No startup ID stored for the window. Let's ask the
|
|
|
|
* startup-notification library whether there's anything
|
|
|
|
* stored for the resource name or resource class hints.
|
|
|
|
*/
|
|
|
|
for (l = display->startup_sequences; l; l = l->next)
|
|
|
|
{
|
|
|
|
const char *wmclass;
|
|
|
|
SnStartupSequence *seq = l->data;
|
|
|
|
|
|
|
|
wmclass = sn_startup_sequence_get_wmclass (seq);
|
|
|
|
|
|
|
|
if (wmclass != NULL &&
|
|
|
|
((window->res_class &&
|
|
|
|
strcmp (wmclass, window->res_class) == 0) ||
|
|
|
|
(window->res_name &&
|
|
|
|
strcmp (wmclass, window->res_name) == 0)))
|
|
|
|
{
|
|
|
|
sequence = seq;
|
|
|
|
|
|
|
|
g_assert (window->startup_id == NULL);
|
|
|
|
window->startup_id = g_strdup (sn_startup_sequence_get_id (sequence));
|
|
|
|
startup_id = window->startup_id;
|
|
|
|
|
|
|
|
meta_topic (META_DEBUG_STARTUP,
|
|
|
|
"Ending legacy sequence %s due to window %s\n",
|
|
|
|
sn_startup_sequence_get_id (sequence),
|
|
|
|
window->desc);
|
|
|
|
|
|
|
|
sn_startup_sequence_complete (sequence);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Still no startup ID? Bail. */
|
|
|
|
if (!startup_id)
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
/* We might get this far and not know the sequence ID (if the window
|
|
|
|
* already had a startup ID stored), so let's look for one if we don't
|
|
|
|
* already know it.
|
|
|
|
*/
|
|
|
|
if (sequence == NULL)
|
|
|
|
{
|
|
|
|
for (l = display->startup_sequences; l != NULL; l = l->next)
|
|
|
|
{
|
|
|
|
SnStartupSequence *seq = l->data;
|
|
|
|
const char *id;
|
|
|
|
|
|
|
|
id = sn_startup_sequence_get_id (seq);
|
|
|
|
|
|
|
|
if (strcmp (id, startup_id) == 0)
|
|
|
|
{
|
|
|
|
sequence = seq;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (sequence != NULL)
|
|
|
|
{
|
|
|
|
gboolean changed_something = FALSE;
|
|
|
|
|
|
|
|
meta_topic (META_DEBUG_STARTUP,
|
|
|
|
"Found startup sequence for window %s ID \"%s\"\n",
|
|
|
|
window->desc, startup_id);
|
|
|
|
|
|
|
|
if (!window->initial_workspace_set)
|
|
|
|
{
|
|
|
|
int space = sn_startup_sequence_get_workspace (sequence);
|
|
|
|
if (space >= 0)
|
|
|
|
{
|
|
|
|
meta_topic (META_DEBUG_STARTUP,
|
|
|
|
"Setting initial window workspace to %d based on startup info\n",
|
|
|
|
space);
|
|
|
|
|
|
|
|
window->initial_workspace_set = TRUE;
|
|
|
|
window->initial_workspace = space;
|
|
|
|
changed_something = TRUE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!window->initial_timestamp_set)
|
|
|
|
{
|
|
|
|
guint32 timestamp = sn_startup_sequence_get_timestamp (sequence);
|
|
|
|
meta_topic (META_DEBUG_STARTUP,
|
|
|
|
"Setting initial window timestamp to %u based on startup info\n",
|
|
|
|
timestamp);
|
|
|
|
|
|
|
|
window->initial_timestamp_set = TRUE;
|
|
|
|
window->initial_timestamp = timestamp;
|
|
|
|
changed_something = TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
return changed_something;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
meta_topic (META_DEBUG_STARTUP,
|
|
|
|
"Did not find startup sequence for window %s ID \"%s\"\n",
|
|
|
|
window->desc, startup_id);
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* HAVE_STARTUP_NOTIFICATION */
|
|
|
|
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static gboolean
|
|
|
|
set_work_area_later_func (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
meta_topic (META_DEBUG_WORKAREA,
|
|
|
|
"Running work area hint computation function\n");
|
|
|
|
|
|
|
|
display->work_area_later = 0;
|
|
|
|
|
2017-08-26 20:41:16 +00:00
|
|
|
g_signal_emit (display, display_signals[WORKAREAS_CHANGED], 0);
|
2017-08-26 19:10:38 +00:00
|
|
|
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_queue_workarea_recalc (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
/* Recompute work area later before redrawing */
|
|
|
|
if (display->work_area_later == 0)
|
|
|
|
{
|
|
|
|
meta_topic (META_DEBUG_WORKAREA,
|
|
|
|
"Adding work area hint computation function\n");
|
|
|
|
display->work_area_later =
|
|
|
|
meta_later_add (META_LATER_BEFORE_REDRAW,
|
|
|
|
(GSourceFunc) set_work_area_later_func,
|
|
|
|
display,
|
|
|
|
NULL);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static gboolean
|
|
|
|
check_fullscreen_func (gpointer data)
|
|
|
|
{
|
|
|
|
MetaDisplay *display = data;
|
|
|
|
MetaBackend *backend = meta_get_backend ();
|
|
|
|
MetaMonitorManager *monitor_manager =
|
|
|
|
meta_backend_get_monitor_manager (backend);
|
|
|
|
GList *logical_monitors, *l;
|
|
|
|
MetaWindow *window;
|
|
|
|
GSList *fullscreen_monitors = NULL;
|
|
|
|
GSList *obscured_monitors = NULL;
|
|
|
|
gboolean in_fullscreen_changed = FALSE;
|
|
|
|
|
|
|
|
display->check_fullscreen_later = 0;
|
|
|
|
|
|
|
|
logical_monitors =
|
|
|
|
meta_monitor_manager_get_logical_monitors (monitor_manager);
|
|
|
|
|
|
|
|
/* We consider a monitor in fullscreen if it contains a fullscreen window;
|
|
|
|
* however we make an exception for maximized windows above the fullscreen
|
|
|
|
* one, as in that case window+chrome fully obscure the fullscreen window.
|
|
|
|
*/
|
|
|
|
for (window = meta_stack_get_top (display->stack);
|
|
|
|
window;
|
|
|
|
window = meta_stack_get_below (display->stack, window, FALSE))
|
|
|
|
{
|
|
|
|
gboolean covers_monitors = FALSE;
|
|
|
|
|
|
|
|
if (window->hidden)
|
|
|
|
continue;
|
|
|
|
|
|
|
|
if (window->fullscreen)
|
|
|
|
{
|
|
|
|
covers_monitors = TRUE;
|
|
|
|
}
|
|
|
|
else if (window->override_redirect)
|
|
|
|
{
|
|
|
|
/* We want to handle the case where an application is creating an
|
|
|
|
* override-redirect window the size of the screen (monitor) and treat
|
|
|
|
* it similarly to a fullscreen window, though it doesn't have fullscreen
|
|
|
|
* window management behavior. (Being O-R, it's not managed at all.)
|
|
|
|
*/
|
|
|
|
if (meta_window_is_monitor_sized (window))
|
|
|
|
covers_monitors = TRUE;
|
|
|
|
}
|
|
|
|
else if (window->maximized_horizontally &&
|
|
|
|
window->maximized_vertically)
|
|
|
|
{
|
|
|
|
MetaLogicalMonitor *logical_monitor;
|
|
|
|
|
|
|
|
logical_monitor = meta_window_get_main_logical_monitor (window);
|
|
|
|
if (!g_slist_find (obscured_monitors, logical_monitor))
|
|
|
|
obscured_monitors = g_slist_prepend (obscured_monitors,
|
|
|
|
logical_monitor);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (covers_monitors)
|
|
|
|
{
|
|
|
|
MetaRectangle window_rect;
|
|
|
|
|
|
|
|
meta_window_get_frame_rect (window, &window_rect);
|
|
|
|
|
|
|
|
for (l = logical_monitors; l; l = l->next)
|
|
|
|
{
|
|
|
|
MetaLogicalMonitor *logical_monitor = l->data;
|
|
|
|
|
|
|
|
if (meta_rectangle_overlap (&window_rect,
|
|
|
|
&logical_monitor->rect) &&
|
|
|
|
!g_slist_find (fullscreen_monitors, logical_monitor) &&
|
|
|
|
!g_slist_find (obscured_monitors, logical_monitor))
|
|
|
|
fullscreen_monitors = g_slist_prepend (fullscreen_monitors,
|
|
|
|
logical_monitor);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
g_slist_free (obscured_monitors);
|
|
|
|
|
|
|
|
for (l = logical_monitors; l; l = l->next)
|
|
|
|
{
|
|
|
|
MetaLogicalMonitor *logical_monitor = l->data;
|
|
|
|
gboolean in_fullscreen;
|
|
|
|
|
|
|
|
in_fullscreen = g_slist_find (fullscreen_monitors,
|
|
|
|
logical_monitor) != NULL;
|
|
|
|
if (in_fullscreen != logical_monitor->in_fullscreen)
|
|
|
|
{
|
|
|
|
logical_monitor->in_fullscreen = in_fullscreen;
|
|
|
|
in_fullscreen_changed = TRUE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
g_slist_free (fullscreen_monitors);
|
|
|
|
|
|
|
|
if (in_fullscreen_changed)
|
|
|
|
{
|
|
|
|
/* DOCK window stacking depends on the monitor's fullscreen
|
|
|
|
status so we need to trigger a re-layering. */
|
|
|
|
MetaWindow *window = meta_stack_get_top (display->stack);
|
|
|
|
if (window)
|
|
|
|
meta_stack_update_layer (display->stack, window);
|
|
|
|
|
|
|
|
g_signal_emit (display, display_signals[IN_FULLSCREEN_CHANGED], 0, NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_queue_check_fullscreen (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
if (!display->check_fullscreen_later)
|
|
|
|
display->check_fullscreen_later = meta_later_add (META_LATER_CHECK_FULLSCREEN,
|
|
|
|
check_fullscreen_func,
|
|
|
|
display, NULL);
|
|
|
|
}
|
2017-08-26 19:22:34 +00:00
|
|
|
|
|
|
|
int
|
|
|
|
meta_display_get_monitor_index_for_rect (MetaDisplay *display,
|
|
|
|
MetaRectangle *rect)
|
|
|
|
{
|
|
|
|
MetaBackend *backend = meta_get_backend ();
|
|
|
|
MetaMonitorManager *monitor_manager =
|
|
|
|
meta_backend_get_monitor_manager (backend);
|
|
|
|
MetaLogicalMonitor *logical_monitor;
|
|
|
|
|
|
|
|
logical_monitor =
|
|
|
|
meta_monitor_manager_get_logical_monitor_from_rect (monitor_manager, rect);
|
|
|
|
if (!logical_monitor)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
return logical_monitor->number;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
meta_display_get_monitor_neighbor_index (MetaDisplay *display,
|
|
|
|
int which_monitor,
|
|
|
|
MetaDisplayDirection direction)
|
|
|
|
{
|
|
|
|
MetaBackend *backend = meta_get_backend ();
|
|
|
|
MetaMonitorManager *monitor_manager =
|
|
|
|
meta_backend_get_monitor_manager (backend);
|
|
|
|
MetaLogicalMonitor *logical_monitor;
|
|
|
|
MetaLogicalMonitor *neighbor;
|
|
|
|
|
|
|
|
logical_monitor =
|
|
|
|
meta_monitor_manager_get_logical_monitor_from_number (monitor_manager,
|
|
|
|
which_monitor);
|
|
|
|
neighbor = meta_monitor_manager_get_logical_monitor_neighbor (monitor_manager,
|
|
|
|
logical_monitor,
|
|
|
|
direction);
|
|
|
|
return neighbor ? neighbor->number : -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* meta_display_get_current_monitor:
|
|
|
|
* @display: a #MetaDisplay
|
|
|
|
*
|
|
|
|
* Gets the index of the monitor that currently has the mouse pointer.
|
|
|
|
*
|
|
|
|
* Return value: a monitor index
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
meta_display_get_current_monitor (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
MetaBackend *backend = meta_get_backend ();
|
|
|
|
MetaLogicalMonitor *logical_monitor;
|
|
|
|
|
|
|
|
logical_monitor = meta_backend_get_current_logical_monitor (backend);
|
|
|
|
|
|
|
|
/* Pretend its the first when there is no actual current monitor. */
|
|
|
|
if (!logical_monitor)
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
return logical_monitor->number;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* meta_display_get_n_monitors:
|
|
|
|
* @display: a #MetaDisplay
|
|
|
|
*
|
|
|
|
* Gets the number of monitors that are joined together to form @display.
|
|
|
|
*
|
|
|
|
* Return value: the number of monitors
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
meta_display_get_n_monitors (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
MetaBackend *backend = meta_get_backend ();
|
|
|
|
MetaMonitorManager *monitor_manager =
|
|
|
|
meta_backend_get_monitor_manager (backend);
|
|
|
|
|
|
|
|
g_return_val_if_fail (META_IS_DISPLAY (display), 0);
|
|
|
|
|
|
|
|
return meta_monitor_manager_get_num_logical_monitors (monitor_manager);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* meta_display_get_primary_monitor:
|
|
|
|
* @display: a #MetaDisplay
|
|
|
|
*
|
|
|
|
* Gets the index of the primary monitor on this @display.
|
|
|
|
*
|
|
|
|
* Return value: a monitor index
|
|
|
|
*/
|
|
|
|
int
|
|
|
|
meta_display_get_primary_monitor (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
MetaBackend *backend = meta_get_backend ();
|
|
|
|
MetaMonitorManager *monitor_manager =
|
|
|
|
meta_backend_get_monitor_manager (backend);
|
|
|
|
MetaLogicalMonitor *logical_monitor;
|
|
|
|
|
|
|
|
g_return_val_if_fail (META_IS_DISPLAY (display), 0);
|
|
|
|
|
|
|
|
logical_monitor =
|
|
|
|
meta_monitor_manager_get_primary_logical_monitor (monitor_manager);
|
|
|
|
if (logical_monitor)
|
|
|
|
return logical_monitor->number;
|
|
|
|
else
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* meta_display_get_monitor_geometry:
|
|
|
|
* @display: a #MetaDisplay
|
|
|
|
* @monitor: the monitor number
|
|
|
|
* @geometry: (out): location to store the monitor geometry
|
|
|
|
*
|
|
|
|
* Stores the location and size of the indicated monitor in @geometry.
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
meta_display_get_monitor_geometry (MetaDisplay *display,
|
|
|
|
int monitor,
|
|
|
|
MetaRectangle *geometry)
|
|
|
|
{
|
|
|
|
MetaBackend *backend = meta_get_backend ();
|
|
|
|
MetaMonitorManager *monitor_manager =
|
|
|
|
meta_backend_get_monitor_manager (backend);
|
|
|
|
MetaLogicalMonitor *logical_monitor;
|
|
|
|
#ifndef G_DISABLE_CHECKS
|
|
|
|
int n_logical_monitors =
|
|
|
|
meta_monitor_manager_get_num_logical_monitors (monitor_manager);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
g_return_if_fail (META_IS_DISPLAY (display));
|
|
|
|
g_return_if_fail (monitor >= 0 && monitor < n_logical_monitors);
|
|
|
|
g_return_if_fail (geometry != NULL);
|
|
|
|
|
|
|
|
logical_monitor =
|
|
|
|
meta_monitor_manager_get_logical_monitor_from_number (monitor_manager,
|
|
|
|
monitor);
|
|
|
|
*geometry = logical_monitor->rect;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* meta_display_get_monitor_in_fullscreen:
|
|
|
|
* @display: a #MetaDisplay
|
|
|
|
* @monitor: the monitor number
|
|
|
|
*
|
|
|
|
* Determines whether there is a fullscreen window obscuring the specified
|
|
|
|
* monitor. If there is a fullscreen window, the desktop environment will
|
|
|
|
* typically hide any controls that might obscure the fullscreen window.
|
|
|
|
*
|
|
|
|
* You can get notification when this changes by connecting to
|
|
|
|
* MetaDisplay::in-fullscreen-changed.
|
|
|
|
*
|
|
|
|
* Returns: %TRUE if there is a fullscreen window covering the specified monitor.
|
|
|
|
*/
|
|
|
|
gboolean
|
|
|
|
meta_display_get_monitor_in_fullscreen (MetaDisplay *display,
|
|
|
|
int monitor)
|
|
|
|
{
|
|
|
|
MetaBackend *backend = meta_get_backend ();
|
|
|
|
MetaMonitorManager *monitor_manager =
|
|
|
|
meta_backend_get_monitor_manager (backend);
|
|
|
|
MetaLogicalMonitor *logical_monitor;
|
|
|
|
#ifndef G_DISABLE_CHECKS
|
|
|
|
int n_logical_monitors =
|
|
|
|
meta_monitor_manager_get_num_logical_monitors (monitor_manager);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
g_return_val_if_fail (META_IS_DISPLAY (display), FALSE);
|
|
|
|
g_return_val_if_fail (monitor >= 0 &&
|
|
|
|
monitor < n_logical_monitors, FALSE);
|
|
|
|
|
|
|
|
logical_monitor =
|
|
|
|
meta_monitor_manager_get_logical_monitor_from_number (monitor_manager,
|
|
|
|
monitor);
|
|
|
|
|
|
|
|
/* We use -1 as a flag to mean "not known yet" for notification
|
|
|
|
purposes */ return logical_monitor->in_fullscreen == TRUE;
|
|
|
|
}
|
2017-08-26 19:35:28 +00:00
|
|
|
|
|
|
|
MetaWindow *
|
|
|
|
meta_display_get_pointer_window (MetaDisplay *display,
|
|
|
|
MetaWindow *not_this_one)
|
|
|
|
{
|
|
|
|
MetaBackend *backend = meta_get_backend ();
|
|
|
|
MetaCursorTracker *cursor_tracker = meta_backend_get_cursor_tracker (backend);
|
|
|
|
MetaWindow *window;
|
|
|
|
int x, y;
|
|
|
|
|
|
|
|
if (not_this_one)
|
|
|
|
meta_topic (META_DEBUG_FOCUS,
|
|
|
|
"Focusing mouse window excluding %s\n", not_this_one->desc);
|
|
|
|
|
|
|
|
meta_cursor_tracker_get_pointer (cursor_tracker, &x, &y, NULL);
|
|
|
|
|
|
|
|
window = meta_stack_get_default_focus_window_at_point (display->stack,
|
2017-08-26 19:39:46 +00:00
|
|
|
display->active_workspace,
|
2017-08-26 19:35:28 +00:00
|
|
|
not_this_one,
|
|
|
|
x, y);
|
|
|
|
|
|
|
|
return window;
|
|
|
|
}
|
2017-08-26 19:39:46 +00:00
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_init_workspaces (MetaDisplay *display)
|
|
|
|
{
|
2017-08-26 20:29:10 +00:00
|
|
|
int num;
|
2017-08-26 19:39:46 +00:00
|
|
|
|
|
|
|
g_return_if_fail (META_IS_DISPLAY (display));
|
|
|
|
|
2017-08-26 20:29:10 +00:00
|
|
|
if (meta_prefs_get_dynamic_workspaces ())
|
|
|
|
/* This will be properly updated using _NET_NUMBER_OF_DESKTOPS
|
|
|
|
* (if set) in meta_x11_display_new () */
|
|
|
|
num = 1;
|
2017-08-26 19:39:46 +00:00
|
|
|
else
|
2017-08-26 20:29:10 +00:00
|
|
|
num = meta_prefs_get_num_workspaces ();
|
2017-08-26 19:39:46 +00:00
|
|
|
|
2017-08-26 20:29:10 +00:00
|
|
|
meta_display_update_num_workspaces (display, META_CURRENT_TIME, num);
|
2017-08-26 19:39:46 +00:00
|
|
|
|
2017-08-26 20:29:10 +00:00
|
|
|
meta_workspace_activate (display->workspaces->data, META_CURRENT_TIME);
|
2017-08-26 19:39:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
meta_display_get_n_workspaces (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
return g_list_length (display->workspaces);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* meta_display_get_workspace_by_index:
|
|
|
|
* @display: a #MetaDisplay
|
|
|
|
* @index: index of one of the display's workspaces
|
|
|
|
*
|
|
|
|
* Gets the workspace object for one of a display's workspaces given the workspace
|
|
|
|
* index. It's valid to call this function with an out-of-range index and it
|
|
|
|
* will robustly return %NULL.
|
|
|
|
*
|
|
|
|
* Return value: (transfer none): the workspace object with specified index, or %NULL
|
|
|
|
* if the index is out of range.
|
|
|
|
*/
|
|
|
|
MetaWorkspace *
|
|
|
|
meta_display_get_workspace_by_index (MetaDisplay *display,
|
|
|
|
int idx)
|
|
|
|
{
|
|
|
|
return g_list_nth_data (display->workspaces, idx);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_remove_workspace (MetaDisplay *display,
|
|
|
|
MetaWorkspace *workspace,
|
|
|
|
guint32 timestamp)
|
|
|
|
{
|
|
|
|
GList *l;
|
|
|
|
GList *next;
|
|
|
|
MetaWorkspace *neighbour = NULL;
|
|
|
|
int index;
|
|
|
|
gboolean active_index_changed;
|
|
|
|
int new_num;
|
|
|
|
|
|
|
|
l = g_list_find (display->workspaces, workspace);
|
|
|
|
if (!l)
|
|
|
|
return;
|
|
|
|
|
|
|
|
next = l->next;
|
|
|
|
|
|
|
|
if (l->prev)
|
|
|
|
neighbour = l->prev->data;
|
|
|
|
else if (l->next)
|
|
|
|
neighbour = l->next->data;
|
|
|
|
else
|
|
|
|
{
|
|
|
|
/* Cannot remove the only workspace! */
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
meta_workspace_relocate_windows (workspace, neighbour);
|
|
|
|
|
|
|
|
if (workspace == display->active_workspace)
|
|
|
|
meta_workspace_activate (neighbour, timestamp);
|
|
|
|
|
|
|
|
/* To emit the signal after removing the workspace */
|
|
|
|
index = meta_workspace_index (workspace);
|
|
|
|
active_index_changed = index < meta_display_get_active_workspace_index (display);
|
|
|
|
|
|
|
|
/* This also removes the workspace from the displays list */
|
|
|
|
meta_workspace_remove (workspace);
|
|
|
|
|
|
|
|
new_num = g_list_length (display->workspaces);
|
|
|
|
|
|
|
|
if (!meta_prefs_get_dynamic_workspaces ())
|
|
|
|
meta_prefs_set_num_workspaces (new_num);
|
|
|
|
|
|
|
|
/* If deleting a workspace before the current workspace, the active
|
|
|
|
* workspace index changes, so we need to update that hint */
|
|
|
|
if (active_index_changed)
|
2017-08-26 20:29:10 +00:00
|
|
|
g_signal_emit (display, display_signals[ACTIVE_WORKSPACE_CHANGED], 0, NULL);
|
2017-08-26 19:39:46 +00:00
|
|
|
|
|
|
|
for (l = next; l; l = l->next)
|
|
|
|
{
|
|
|
|
MetaWorkspace *w = l->data;
|
|
|
|
|
|
|
|
meta_workspace_index_changed (w);
|
|
|
|
}
|
|
|
|
|
|
|
|
meta_display_queue_workarea_recalc (display);
|
|
|
|
|
|
|
|
g_signal_emit (display, display_signals[WORKSPACE_REMOVED], 0, index);
|
|
|
|
g_object_notify (G_OBJECT (display), "n-workspaces");
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* meta_display_append_new_workspace:
|
|
|
|
* @display: a #MetaDisplay
|
|
|
|
* @activate: %TRUE if the workspace should be switched to after creation
|
|
|
|
* @timestamp: if switching to a new workspace, timestamp to be used when
|
|
|
|
* focusing a window on the new workspace. (Doesn't hurt to pass a valid
|
|
|
|
* timestamp when available even if not switching workspaces.)
|
|
|
|
*
|
|
|
|
* Append a new workspace to the display and (optionally) switch to that
|
|
|
|
* display.
|
|
|
|
*
|
|
|
|
* Return value: (transfer none): the newly appended workspace.
|
|
|
|
*/
|
|
|
|
MetaWorkspace *
|
|
|
|
meta_display_append_new_workspace (MetaDisplay *display,
|
|
|
|
gboolean activate,
|
|
|
|
guint32 timestamp)
|
|
|
|
{
|
|
|
|
MetaWorkspace *w;
|
|
|
|
int new_num;
|
|
|
|
|
|
|
|
/* This also adds the workspace to the display list */
|
|
|
|
w = meta_workspace_new (display);
|
|
|
|
|
|
|
|
if (!w)
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
if (activate)
|
|
|
|
meta_workspace_activate (w, timestamp);
|
|
|
|
|
|
|
|
new_num = g_list_length (display->workspaces);
|
|
|
|
|
|
|
|
if (!meta_prefs_get_dynamic_workspaces ())
|
|
|
|
meta_prefs_set_num_workspaces (new_num);
|
|
|
|
|
|
|
|
meta_display_queue_workarea_recalc (display);
|
|
|
|
|
|
|
|
g_signal_emit (display, display_signals[WORKSPACE_ADDED],
|
|
|
|
0, meta_workspace_index (w));
|
|
|
|
g_object_notify (G_OBJECT (display), "n-workspaces");
|
|
|
|
|
|
|
|
return w;
|
|
|
|
}
|
|
|
|
|
2017-08-26 20:29:10 +00:00
|
|
|
void
|
|
|
|
meta_display_update_num_workspaces (MetaDisplay *display,
|
|
|
|
guint32 timestamp,
|
|
|
|
int new_num)
|
2017-08-26 19:39:46 +00:00
|
|
|
{
|
2017-08-26 20:29:10 +00:00
|
|
|
int old_num;
|
2017-08-26 19:39:46 +00:00
|
|
|
GList *l;
|
2017-08-26 20:29:10 +00:00
|
|
|
int i = 0;
|
|
|
|
GList *extras = NULL;
|
|
|
|
MetaWorkspace *last_remaining = NULL;
|
|
|
|
gboolean need_change_space = FALSE;
|
2017-08-26 19:39:46 +00:00
|
|
|
|
|
|
|
g_assert (new_num > 0);
|
|
|
|
|
|
|
|
if (g_list_length (display->workspaces) == (guint) new_num)
|
|
|
|
return;
|
|
|
|
|
|
|
|
for (l = display->workspaces; l != NULL; l = l->next)
|
|
|
|
{
|
|
|
|
MetaWorkspace *w = l->data;
|
|
|
|
|
|
|
|
if (i >= new_num)
|
|
|
|
extras = g_list_prepend (extras, w);
|
|
|
|
else
|
|
|
|
last_remaining = w;
|
|
|
|
|
|
|
|
++i;
|
|
|
|
}
|
|
|
|
old_num = i;
|
|
|
|
|
|
|
|
g_assert (last_remaining);
|
|
|
|
|
|
|
|
/* Get rid of the extra workspaces by moving all their windows
|
|
|
|
* to last_remaining, then activating last_remaining if
|
|
|
|
* one of the removed workspaces was active. This will be a bit
|
|
|
|
* wacky if the config tool for changing number of workspaces
|
|
|
|
* is on a removed workspace ;-)
|
|
|
|
*/
|
|
|
|
for (l = extras; l != NULL; l = l->next)
|
|
|
|
{
|
|
|
|
MetaWorkspace *w = l->data;
|
|
|
|
|
|
|
|
meta_workspace_relocate_windows (w, last_remaining);
|
|
|
|
|
|
|
|
if (w == display->active_workspace)
|
|
|
|
need_change_space = TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (need_change_space)
|
|
|
|
meta_workspace_activate (last_remaining, timestamp);
|
|
|
|
|
|
|
|
/* Should now be safe to free the workspaces */
|
|
|
|
for (l = extras; l != NULL; l = l->next)
|
|
|
|
{
|
|
|
|
MetaWorkspace *w = l->data;
|
|
|
|
|
|
|
|
meta_workspace_remove (w);
|
|
|
|
}
|
|
|
|
|
|
|
|
g_list_free (extras);
|
|
|
|
|
|
|
|
for (i = old_num; i < new_num; i++)
|
|
|
|
meta_workspace_new (display);
|
|
|
|
|
|
|
|
meta_display_queue_workarea_recalc (display);
|
|
|
|
|
|
|
|
for (i = old_num; i < new_num; i++)
|
|
|
|
g_signal_emit (display, display_signals[WORKSPACE_ADDED], 0, i);
|
|
|
|
|
|
|
|
g_object_notify (G_OBJECT (display), "n-workspaces");
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2017-08-26 20:29:10 +00:00
|
|
|
meta_display_update_workspace_layout (MetaDisplay *display,
|
|
|
|
MetaDisplayCorner starting_corner,
|
|
|
|
gboolean vertical_layout,
|
|
|
|
int n_rows,
|
|
|
|
int n_columns)
|
2017-08-26 19:39:46 +00:00
|
|
|
{
|
2017-08-26 20:29:10 +00:00
|
|
|
g_return_if_fail (META_IS_DISPLAY (display));
|
|
|
|
g_return_if_fail (n_rows > 0 || n_columns > 0);
|
|
|
|
g_return_if_fail (n_rows != 0 && n_columns != 0);
|
2017-08-26 19:39:46 +00:00
|
|
|
|
|
|
|
if (display->workspace_layout_overridden)
|
|
|
|
return;
|
|
|
|
|
2017-08-26 20:29:10 +00:00
|
|
|
display->vertical_workspaces = vertical_layout != FALSE;
|
|
|
|
display->starting_corner = starting_corner;
|
|
|
|
display->rows_of_workspaces = n_rows;
|
|
|
|
display->columns_of_workspaces = n_columns;
|
2017-08-26 19:39:46 +00:00
|
|
|
|
|
|
|
meta_verbose ("Workspace layout rows = %d cols = %d orientation = %d starting corner = %u\n",
|
|
|
|
display->rows_of_workspaces,
|
|
|
|
display->columns_of_workspaces,
|
|
|
|
display->vertical_workspaces,
|
|
|
|
display->starting_corner);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* meta_display_override_workspace_layout:
|
|
|
|
* @display: a #MetaDisplay
|
|
|
|
* @starting_corner: the corner at which the first workspace is found
|
|
|
|
* @vertical_layout: if %TRUE the workspaces are laid out in columns rather than rows
|
|
|
|
* @n_rows: number of rows of workspaces, or -1 to determine the number of rows from
|
|
|
|
* @n_columns and the total number of workspaces
|
|
|
|
* @n_columns: number of columns of workspaces, or -1 to determine the number of columns from
|
|
|
|
* @n_rows and the total number of workspaces
|
|
|
|
*
|
|
|
|
* Explicitly set the layout of workspaces. Once this has been called, the contents of the
|
|
|
|
* _NET_DESKTOP_LAYOUT property on the root window are completely ignored.
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
meta_display_override_workspace_layout (MetaDisplay *display,
|
|
|
|
MetaDisplayCorner starting_corner,
|
|
|
|
gboolean vertical_layout,
|
|
|
|
int n_rows,
|
|
|
|
int n_columns)
|
|
|
|
{
|
2017-08-26 20:29:10 +00:00
|
|
|
meta_display_update_workspace_layout (display,
|
|
|
|
starting_corner,
|
|
|
|
vertical_layout,
|
|
|
|
n_rows,
|
|
|
|
n_columns);
|
2017-08-26 19:39:46 +00:00
|
|
|
|
|
|
|
display->workspace_layout_overridden = TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef WITH_VERBOSE_MODE
|
|
|
|
static const char *
|
|
|
|
meta_display_corner_to_string (MetaDisplayCorner corner)
|
|
|
|
{
|
|
|
|
switch (corner)
|
|
|
|
{
|
|
|
|
case META_DISPLAY_TOPLEFT:
|
|
|
|
return "TopLeft";
|
|
|
|
case META_DISPLAY_TOPRIGHT:
|
|
|
|
return "TopRight";
|
|
|
|
case META_DISPLAY_BOTTOMLEFT:
|
|
|
|
return "BottomLeft";
|
|
|
|
case META_DISPLAY_BOTTOMRIGHT:
|
|
|
|
return "BottomRight";
|
|
|
|
}
|
|
|
|
|
|
|
|
return "Unknown";
|
|
|
|
}
|
|
|
|
#endif /* WITH_VERBOSE_MODE */
|
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_calc_workspace_layout (MetaDisplay *display,
|
|
|
|
int num_workspaces,
|
|
|
|
int current_space,
|
|
|
|
MetaWorkspaceLayout *layout)
|
|
|
|
{
|
|
|
|
int rows, cols;
|
|
|
|
int grid_area;
|
|
|
|
int *grid;
|
|
|
|
int i, r, c;
|
|
|
|
int current_row, current_col;
|
|
|
|
|
|
|
|
rows = display->rows_of_workspaces;
|
|
|
|
cols = display->columns_of_workspaces;
|
|
|
|
if (rows <= 0 && cols <= 0)
|
|
|
|
cols = num_workspaces;
|
|
|
|
|
|
|
|
if (rows <= 0)
|
|
|
|
rows = num_workspaces / cols + ((num_workspaces % cols) > 0 ? 1 : 0);
|
|
|
|
if (cols <= 0)
|
|
|
|
cols = num_workspaces / rows + ((num_workspaces % rows) > 0 ? 1 : 0);
|
|
|
|
|
|
|
|
/* paranoia */
|
|
|
|
if (rows < 1)
|
|
|
|
rows = 1;
|
|
|
|
if (cols < 1)
|
|
|
|
cols = 1;
|
|
|
|
|
|
|
|
g_assert (rows != 0 && cols != 0);
|
|
|
|
|
|
|
|
grid_area = rows * cols;
|
|
|
|
|
|
|
|
meta_verbose ("Getting layout rows = %d cols = %d current = %d "
|
|
|
|
"num_spaces = %d vertical = %s corner = %s\n",
|
|
|
|
rows, cols, current_space, num_workspaces,
|
|
|
|
display->vertical_workspaces ? "(true)" : "(false)",
|
|
|
|
meta_display_corner_to_string (display->starting_corner));
|
|
|
|
|
|
|
|
/* ok, we want to setup the distances in the workspace array to go
|
|
|
|
* in each direction. Remember, there are many ways that a workspace
|
|
|
|
* array can be setup.
|
|
|
|
* see http://www.freedesktop.org/standards/wm-spec/1.2/html/x109.html
|
|
|
|
* and look at the _NET_DESKTOP_LAYOUT section for details.
|
|
|
|
* For instance:
|
|
|
|
*/
|
|
|
|
/* starting_corner = META_DISPLAY_TOPLEFT
|
|
|
|
* vertical_workspaces = 0 vertical_workspaces=1
|
|
|
|
* 1234 1357
|
|
|
|
* 5678 2468
|
|
|
|
*
|
|
|
|
* starting_corner = META_DISPLAY_TOPRIGHT
|
|
|
|
* vertical_workspaces = 0 vertical_workspaces=1
|
|
|
|
* 4321 7531
|
|
|
|
* 8765 8642
|
|
|
|
*
|
|
|
|
* starting_corner = META_DISPLAY_BOTTOMLEFT
|
|
|
|
* vertical_workspaces = 0 vertical_workspaces=1
|
|
|
|
* 5678 2468
|
|
|
|
* 1234 1357
|
|
|
|
*
|
|
|
|
* starting_corner = META_DISPLAY_BOTTOMRIGHT
|
|
|
|
* vertical_workspaces = 0 vertical_workspaces=1
|
|
|
|
* 8765 8642
|
|
|
|
* 4321 7531
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
/* keep in mind that we could have a ragged layout, e.g. the "8"
|
|
|
|
* in the above grids could be missing
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
grid = g_new (int, grid_area);
|
|
|
|
|
|
|
|
current_row = -1;
|
|
|
|
current_col = -1;
|
|
|
|
i = 0;
|
|
|
|
|
|
|
|
switch (display->starting_corner)
|
|
|
|
{
|
|
|
|
case META_DISPLAY_TOPLEFT:
|
|
|
|
if (display->vertical_workspaces)
|
|
|
|
{
|
|
|
|
c = 0;
|
|
|
|
while (c < cols)
|
|
|
|
{
|
|
|
|
r = 0;
|
|
|
|
while (r < rows)
|
|
|
|
{
|
|
|
|
grid[r*cols+c] = i;
|
|
|
|
++i;
|
|
|
|
++r;
|
|
|
|
}
|
|
|
|
++c;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
r = 0;
|
|
|
|
while (r < rows)
|
|
|
|
{
|
|
|
|
c = 0;
|
|
|
|
while (c < cols)
|
|
|
|
{
|
|
|
|
grid[r*cols+c] = i;
|
|
|
|
++i;
|
|
|
|
++c;
|
|
|
|
}
|
|
|
|
++r;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case META_DISPLAY_TOPRIGHT:
|
|
|
|
if (display->vertical_workspaces)
|
|
|
|
{
|
|
|
|
c = cols - 1;
|
|
|
|
while (c >= 0)
|
|
|
|
{
|
|
|
|
r = 0;
|
|
|
|
while (r < rows)
|
|
|
|
{
|
|
|
|
grid[r*cols+c] = i;
|
|
|
|
++i;
|
|
|
|
++r;
|
|
|
|
}
|
|
|
|
--c;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
r = 0;
|
|
|
|
while (r < rows)
|
|
|
|
{
|
|
|
|
c = cols - 1;
|
|
|
|
while (c >= 0)
|
|
|
|
{
|
|
|
|
grid[r*cols+c] = i;
|
|
|
|
++i;
|
|
|
|
--c;
|
|
|
|
}
|
|
|
|
++r;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case META_DISPLAY_BOTTOMLEFT:
|
|
|
|
if (display->vertical_workspaces)
|
|
|
|
{
|
|
|
|
c = 0;
|
|
|
|
while (c < cols)
|
|
|
|
{
|
|
|
|
r = rows - 1;
|
|
|
|
while (r >= 0)
|
|
|
|
{
|
|
|
|
grid[r*cols+c] = i;
|
|
|
|
++i;
|
|
|
|
--r;
|
|
|
|
}
|
|
|
|
++c;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
r = rows - 1;
|
|
|
|
while (r >= 0)
|
|
|
|
{
|
|
|
|
c = 0;
|
|
|
|
while (c < cols)
|
|
|
|
{
|
|
|
|
grid[r*cols+c] = i;
|
|
|
|
++i;
|
|
|
|
++c;
|
|
|
|
}
|
|
|
|
--r;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case META_DISPLAY_BOTTOMRIGHT:
|
|
|
|
if (display->vertical_workspaces)
|
|
|
|
{
|
|
|
|
c = cols - 1;
|
|
|
|
while (c >= 0)
|
|
|
|
{
|
|
|
|
r = rows - 1;
|
|
|
|
while (r >= 0)
|
|
|
|
{
|
|
|
|
grid[r*cols+c] = i;
|
|
|
|
++i;
|
|
|
|
--r;
|
|
|
|
}
|
|
|
|
--c;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
r = rows - 1;
|
|
|
|
while (r >= 0)
|
|
|
|
{
|
|
|
|
c = cols - 1;
|
|
|
|
while (c >= 0)
|
|
|
|
{
|
|
|
|
grid[r*cols+c] = i;
|
|
|
|
++i;
|
|
|
|
--c;
|
|
|
|
}
|
|
|
|
--r;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (i != grid_area)
|
|
|
|
meta_bug ("did not fill in the whole workspace grid in %s (%d filled)\n",
|
|
|
|
G_STRFUNC, i);
|
|
|
|
|
|
|
|
current_row = 0;
|
|
|
|
current_col = 0;
|
|
|
|
r = 0;
|
|
|
|
while (r < rows)
|
|
|
|
{
|
|
|
|
c = 0;
|
|
|
|
while (c < cols)
|
|
|
|
{
|
|
|
|
if (grid[r*cols+c] == current_space)
|
|
|
|
{
|
|
|
|
current_row = r;
|
|
|
|
current_col = c;
|
|
|
|
}
|
|
|
|
else if (grid[r*cols+c] >= num_workspaces)
|
|
|
|
{
|
|
|
|
/* flag nonexistent spaces with -1 */
|
|
|
|
grid[r*cols+c] = -1;
|
|
|
|
}
|
|
|
|
++c;
|
|
|
|
}
|
|
|
|
++r;
|
|
|
|
}
|
|
|
|
|
|
|
|
layout->rows = rows;
|
|
|
|
layout->cols = cols;
|
|
|
|
layout->grid = grid;
|
|
|
|
layout->grid_area = grid_area;
|
|
|
|
layout->current_row = current_row;
|
|
|
|
layout->current_col = current_col;
|
|
|
|
|
|
|
|
#ifdef WITH_VERBOSE_MODE
|
|
|
|
if (meta_is_verbose ())
|
|
|
|
{
|
|
|
|
r = 0;
|
|
|
|
while (r < layout->rows)
|
|
|
|
{
|
|
|
|
meta_verbose (" ");
|
|
|
|
meta_push_no_msg_prefix ();
|
|
|
|
c = 0;
|
|
|
|
while (c < layout->cols)
|
|
|
|
{
|
|
|
|
if (r == layout->current_row &&
|
|
|
|
c == layout->current_col)
|
|
|
|
meta_verbose ("*%2d ", layout->grid[r*layout->cols+c]);
|
|
|
|
else
|
|
|
|
meta_verbose ("%3d ", layout->grid[r*layout->cols+c]);
|
|
|
|
++c;
|
|
|
|
}
|
|
|
|
meta_verbose ("\n");
|
|
|
|
meta_pop_no_msg_prefix ();
|
|
|
|
++r;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif /* WITH_VERBOSE_MODE */
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_free_workspace_layout (MetaWorkspaceLayout *layout)
|
|
|
|
{
|
|
|
|
g_free (layout->grid);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
queue_windows_showing (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
GSList *windows, *l;
|
|
|
|
|
|
|
|
/* Must operate on all windows on display instead of just on the
|
|
|
|
* active_workspace's window list, because the active_workspace's
|
|
|
|
* window list may not contain the on_all_workspace windows.
|
|
|
|
*/
|
|
|
|
windows = meta_display_list_windows (display, META_LIST_DEFAULT);
|
|
|
|
|
|
|
|
for (l = windows; l != NULL; l = l->next)
|
|
|
|
{
|
|
|
|
MetaWindow *w = l->data;
|
|
|
|
meta_window_queue (w, META_QUEUE_CALC_SHOWING);
|
|
|
|
}
|
|
|
|
|
|
|
|
g_slist_free (windows);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_minimize_all_on_active_workspace_except (MetaDisplay *display,
|
|
|
|
MetaWindow *keep)
|
|
|
|
{
|
|
|
|
GList *l;
|
|
|
|
|
|
|
|
for (l = display->active_workspace->windows; l != NULL; l = l->next)
|
|
|
|
{
|
|
|
|
MetaWindow *w = l->data;
|
|
|
|
|
|
|
|
if (w->has_minimize_func && w != keep)
|
|
|
|
meta_window_minimize (w);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_show_desktop (MetaDisplay *display,
|
|
|
|
guint32 timestamp)
|
|
|
|
{
|
|
|
|
GList *l;
|
|
|
|
|
|
|
|
if (display->active_workspace->showing_desktop)
|
|
|
|
return;
|
|
|
|
|
|
|
|
display->active_workspace->showing_desktop = TRUE;
|
|
|
|
|
|
|
|
queue_windows_showing (display);
|
|
|
|
|
|
|
|
/* Focus the most recently used META_WINDOW_DESKTOP window, if there is one;
|
|
|
|
* see bug 159257.
|
|
|
|
*/
|
|
|
|
for (l = display->active_workspace->mru_list; l != NULL; l = l->next)
|
|
|
|
{
|
|
|
|
MetaWindow *w = l->data;
|
|
|
|
|
|
|
|
if (w->type == META_WINDOW_DESKTOP)
|
|
|
|
{
|
|
|
|
meta_window_focus (w, timestamp);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-08-26 20:29:10 +00:00
|
|
|
g_signal_emit (display, display_signals[SHOWING_DESKTOP_CHANGED], 0, NULL);
|
2017-08-26 19:39:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_unshow_desktop (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
if (!display->active_workspace->showing_desktop)
|
|
|
|
return;
|
|
|
|
|
|
|
|
display->active_workspace->showing_desktop = FALSE;
|
|
|
|
|
|
|
|
queue_windows_showing (display);
|
|
|
|
|
2017-08-26 20:29:10 +00:00
|
|
|
g_signal_emit (display, display_signals[SHOWING_DESKTOP_CHANGED], 0, NULL);
|
2017-08-26 19:39:46 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* meta_display_get_workspaces: (skip)
|
|
|
|
* @display: a #MetaDisplay
|
|
|
|
*
|
|
|
|
* Returns: (transfer none) (element-type Meta.Workspace): The workspaces for @display
|
|
|
|
*/
|
|
|
|
GList *
|
|
|
|
meta_display_get_workspaces (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
return display->workspaces;
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
meta_display_get_active_workspace_index (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
MetaWorkspace *active = display->active_workspace;
|
|
|
|
|
|
|
|
if (!active)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
return meta_workspace_index (active);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* meta_display_get_active_workspace:
|
|
|
|
* @display: A #MetaDisplay
|
|
|
|
*
|
|
|
|
* Returns: (transfer none): The current workspace
|
|
|
|
*/
|
|
|
|
MetaWorkspace *
|
|
|
|
meta_display_get_active_workspace (MetaDisplay *display)
|
|
|
|
{
|
|
|
|
return display->active_workspace;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_focus_default_window (MetaDisplay *display,
|
|
|
|
guint32 timestamp)
|
|
|
|
{
|
|
|
|
meta_workspace_focus_default_window (display->active_workspace,
|
|
|
|
NULL,
|
|
|
|
timestamp);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
meta_display_workspace_switched (MetaDisplay *display,
|
|
|
|
int from,
|
|
|
|
int to,
|
|
|
|
MetaMotionDirection direction)
|
|
|
|
{
|
|
|
|
g_signal_emit (display, display_signals[WORKSPACE_SWITCHED], 0,
|
|
|
|
from, to, direction);
|
|
|
|
}
|