4fac1a4862
Since the PID of a window can't change as long as the window exists, we can safely cache it after we got a valid PID once, so do that by adding a new `window->client_pid` private property. https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/1180
875 lines
31 KiB
C
875 lines
31 KiB
C
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
|
|
|
/**
|
|
* \file window-private.h Windows which Mutter manages
|
|
*
|
|
* Managing X windows.
|
|
* This file contains methods on this class which are available to
|
|
* routines in core but not outside it. (See window.h for the routines
|
|
* which the rest of the world is allowed to use.)
|
|
*/
|
|
|
|
/*
|
|
* Copyright (C) 2001 Havoc Pennington
|
|
* Copyright (C) 2002 Red Hat, Inc.
|
|
* Copyright (C) 2003, 2004 Rob Adams
|
|
* Copyright (C) 2004-2006 Elijah Newren
|
|
*
|
|
* 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.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#ifndef META_WINDOW_PRIVATE_H
|
|
#define META_WINDOW_PRIVATE_H
|
|
|
|
#include <X11/Xutil.h>
|
|
#include <cairo.h>
|
|
#include <gdk-pixbuf/gdk-pixbuf.h>
|
|
|
|
#include "backends/meta-logical-monitor.h"
|
|
#include "clutter/clutter.h"
|
|
#include "core/stack.h"
|
|
#include "meta/compositor.h"
|
|
#include "meta/meta-close-dialog.h"
|
|
#include "meta/util.h"
|
|
#include "meta/window.h"
|
|
#include "wayland/meta-wayland-types.h"
|
|
#include "x11/group-private.h"
|
|
|
|
typedef struct _MetaWindowQueue MetaWindowQueue;
|
|
|
|
typedef enum
|
|
{
|
|
META_CLIENT_TYPE_UNKNOWN = 0,
|
|
META_CLIENT_TYPE_APPLICATION = 1,
|
|
META_CLIENT_TYPE_PAGER = 2,
|
|
META_CLIENT_TYPE_MAX_RECOGNIZED = 2
|
|
} MetaClientType;
|
|
|
|
typedef enum
|
|
{
|
|
META_QUEUE_CALC_SHOWING = 1 << 0,
|
|
META_QUEUE_MOVE_RESIZE = 1 << 1,
|
|
META_QUEUE_UPDATE_ICON = 1 << 2,
|
|
} MetaQueueType;
|
|
|
|
#define NUMBER_OF_QUEUES 3
|
|
|
|
typedef enum
|
|
{
|
|
META_MOVE_RESIZE_CONFIGURE_REQUEST = 1 << 0,
|
|
META_MOVE_RESIZE_USER_ACTION = 1 << 1,
|
|
META_MOVE_RESIZE_MOVE_ACTION = 1 << 2,
|
|
META_MOVE_RESIZE_RESIZE_ACTION = 1 << 3,
|
|
META_MOVE_RESIZE_WAYLAND_FINISH_MOVE_RESIZE = 1 << 4,
|
|
META_MOVE_RESIZE_STATE_CHANGED = 1 << 5,
|
|
META_MOVE_RESIZE_UNMAXIMIZE = 1 << 6,
|
|
META_MOVE_RESIZE_UNFULLSCREEN = 1 << 7,
|
|
META_MOVE_RESIZE_FORCE_MOVE = 1 << 8,
|
|
META_MOVE_RESIZE_WAYLAND_STATE_CHANGED = 1 << 9,
|
|
META_MOVE_RESIZE_FORCE_UPDATE_MONITOR = 1 << 10,
|
|
META_MOVE_RESIZE_PLACEMENT_CHANGED = 1 << 11,
|
|
} MetaMoveResizeFlags;
|
|
|
|
typedef enum
|
|
{
|
|
META_MOVE_RESIZE_RESULT_MOVED = 1 << 0,
|
|
META_MOVE_RESIZE_RESULT_RESIZED = 1 << 1,
|
|
META_MOVE_RESIZE_RESULT_FRAME_SHAPE_CHANGED = 1 << 2,
|
|
META_MOVE_RESIZE_RESULT_STATE_CHANGED = 1 << 3,
|
|
} MetaMoveResizeResultFlags;
|
|
|
|
typedef enum
|
|
{
|
|
META_PLACEMENT_GRAVITY_NONE = 0,
|
|
META_PLACEMENT_GRAVITY_TOP = 1 << 0,
|
|
META_PLACEMENT_GRAVITY_BOTTOM = 1 << 1,
|
|
META_PLACEMENT_GRAVITY_LEFT = 1 << 2,
|
|
META_PLACEMENT_GRAVITY_RIGHT = 1 << 3,
|
|
} MetaPlacementGravity;
|
|
|
|
typedef enum
|
|
{
|
|
META_PLACEMENT_ANCHOR_NONE = 0,
|
|
META_PLACEMENT_ANCHOR_TOP = 1 << 0,
|
|
META_PLACEMENT_ANCHOR_BOTTOM = 1 << 1,
|
|
META_PLACEMENT_ANCHOR_LEFT = 1 << 2,
|
|
META_PLACEMENT_ANCHOR_RIGHT = 1 << 3,
|
|
} MetaPlacementAnchor;
|
|
|
|
typedef enum
|
|
{
|
|
META_PLACEMENT_CONSTRAINT_ADJUSTMENT_NONE = 0,
|
|
META_PLACEMENT_CONSTRAINT_ADJUSTMENT_SLIDE_X = 1 << 0,
|
|
META_PLACEMENT_CONSTRAINT_ADJUSTMENT_SLIDE_Y = 1 << 1,
|
|
META_PLACEMENT_CONSTRAINT_ADJUSTMENT_FLIP_X = 1 << 2,
|
|
META_PLACEMENT_CONSTRAINT_ADJUSTMENT_FLIP_Y = 1 << 3,
|
|
META_PLACEMENT_CONSTRAINT_ADJUSTMENT_RESIZE_X = 1 << 4,
|
|
META_PLACEMENT_CONSTRAINT_ADJUSTMENT_RESIZE_Y = 1 << 5,
|
|
} MetaPlacementConstraintAdjustment;
|
|
|
|
typedef enum _MetaWindowUpdateMonitorFlags
|
|
{
|
|
META_WINDOW_UPDATE_MONITOR_FLAGS_NONE = 0,
|
|
META_WINDOW_UPDATE_MONITOR_FLAGS_USER_OP = 1 << 0,
|
|
META_WINDOW_UPDATE_MONITOR_FLAGS_FORCE = 1 << 1,
|
|
} MetaWindowUpdateMonitorFlags;
|
|
|
|
typedef struct _MetaPlacementRule
|
|
{
|
|
MetaRectangle anchor_rect;
|
|
MetaPlacementGravity gravity;
|
|
MetaPlacementAnchor anchor;
|
|
MetaPlacementConstraintAdjustment constraint_adjustment;
|
|
int offset_x;
|
|
int offset_y;
|
|
int width;
|
|
int height;
|
|
|
|
gboolean is_reactive;
|
|
|
|
MetaRectangle parent_rect;
|
|
} MetaPlacementRule;
|
|
|
|
typedef enum _MetaPlacementState
|
|
{
|
|
META_PLACEMENT_STATE_UNCONSTRAINED,
|
|
META_PLACEMENT_STATE_CONSTRAINED_PENDING,
|
|
META_PLACEMENT_STATE_CONSTRAINED_CONFIGURED,
|
|
META_PLACEMENT_STATE_CONSTRAINED_FINISHED,
|
|
META_PLACEMENT_STATE_INVALIDATED,
|
|
} MetaPlacementState;
|
|
|
|
typedef enum
|
|
{
|
|
META_EDGE_CONSTRAINT_NONE = 0,
|
|
META_EDGE_CONSTRAINT_WINDOW = 1,
|
|
META_EDGE_CONSTRAINT_MONITOR = 2,
|
|
} MetaEdgeConstraint;
|
|
|
|
struct _MetaWindow
|
|
{
|
|
GObject parent_instance;
|
|
|
|
MetaDisplay *display;
|
|
uint64_t id;
|
|
guint64 stamp;
|
|
MetaLogicalMonitor *monitor;
|
|
MetaWorkspace *workspace;
|
|
MetaWindowClientType client_type;
|
|
MetaWaylandSurface *surface;
|
|
Window xwindow;
|
|
/* may be NULL! not all windows get decorated */
|
|
MetaFrame *frame;
|
|
int depth;
|
|
Visual *xvisual;
|
|
char *desc; /* used in debug spew */
|
|
char *title;
|
|
|
|
cairo_surface_t *icon;
|
|
cairo_surface_t *mini_icon;
|
|
|
|
MetaWindowType type;
|
|
|
|
/* NOTE these five are not in UTF-8, we just treat them as random
|
|
* binary data
|
|
*/
|
|
char *res_class;
|
|
char *res_name;
|
|
char *role;
|
|
char *sm_client_id;
|
|
char *wm_client_machine;
|
|
|
|
char *startup_id;
|
|
char *mutter_hints;
|
|
char *sandboxed_app_id;
|
|
char *gtk_theme_variant;
|
|
char *gtk_application_id;
|
|
char *gtk_unique_bus_name;
|
|
char *gtk_application_object_path;
|
|
char *gtk_window_object_path;
|
|
char *gtk_app_menu_object_path;
|
|
char *gtk_menubar_object_path;
|
|
|
|
Window xtransient_for;
|
|
Window xgroup_leader;
|
|
Window xclient_leader;
|
|
MetaWindow *transient_for;
|
|
|
|
/* Initial workspace property */
|
|
int initial_workspace;
|
|
|
|
/* Initial timestamp property */
|
|
guint32 initial_timestamp;
|
|
|
|
/* Whether this is an override redirect window or not */
|
|
guint override_redirect : 1;
|
|
|
|
/* Whether we're maximized */
|
|
guint maximized_horizontally : 1;
|
|
guint maximized_vertically : 1;
|
|
|
|
/* Whether we have to maximize/minimize after placement */
|
|
guint maximize_horizontally_after_placement : 1;
|
|
guint maximize_vertically_after_placement : 1;
|
|
guint minimize_after_placement : 1;
|
|
|
|
/* The current tile mode */
|
|
MetaTileMode tile_mode;
|
|
|
|
/* The last "full" maximized/unmaximized state. We need to keep track of
|
|
* that to toggle between normal/tiled or maximized/tiled states. */
|
|
guint saved_maximize : 1;
|
|
int tile_monitor_number;
|
|
|
|
struct {
|
|
MetaEdgeConstraint top;
|
|
MetaEdgeConstraint right;
|
|
MetaEdgeConstraint bottom;
|
|
MetaEdgeConstraint left;
|
|
} edge_constraints;
|
|
|
|
double tile_hfraction;
|
|
|
|
uint64_t preferred_output_winsys_id;
|
|
|
|
/* Whether we're shaded */
|
|
guint shaded : 1;
|
|
|
|
/* Whether we're fullscreen */
|
|
guint fullscreen : 1;
|
|
|
|
/* Whether the window is marked as urgent */
|
|
guint urgent : 1;
|
|
|
|
/* Area to cover when in fullscreen mode. If _NET_WM_FULLSCREEN_MONITORS has
|
|
* been overridden (via a client message), the window will cover the union of
|
|
* these monitors. If not, this is the single monitor which the window's
|
|
* origin is on. */
|
|
struct {
|
|
MetaLogicalMonitor *top;
|
|
MetaLogicalMonitor *bottom;
|
|
MetaLogicalMonitor *left;
|
|
MetaLogicalMonitor *right;
|
|
} fullscreen_monitors;
|
|
|
|
/* Whether we're trying to constrain the window to be fully onscreen */
|
|
guint require_fully_onscreen : 1;
|
|
|
|
/* Whether we're trying to constrain the window to be on a single monitor */
|
|
guint require_on_single_monitor : 1;
|
|
|
|
/* Whether we're trying to constrain the window's titlebar to be onscreen */
|
|
guint require_titlebar_visible : 1;
|
|
|
|
/* Whether we're sticky in the multi-workspace sense
|
|
* (vs. the not-scroll-with-viewport sense, we don't
|
|
* have no stupid viewports)
|
|
*/
|
|
guint on_all_workspaces : 1;
|
|
|
|
/* This is true if the client requested sticky, and implies on_all_workspaces == TRUE,
|
|
* however on_all_workspaces can be set TRUE for other internal reasons too, such as
|
|
* being override_redirect or being on the non-primary monitor. */
|
|
guint on_all_workspaces_requested : 1;
|
|
|
|
/* Minimize is the state controlled by the minimize button */
|
|
guint minimized : 1;
|
|
guint tab_unminimized : 1;
|
|
|
|
/* Whether the window is mapped; actual server-side state
|
|
* see also unmaps_pending
|
|
*/
|
|
guint mapped : 1;
|
|
|
|
/* Whether window has been hidden from view by lowering it to the bottom
|
|
* of window stack.
|
|
*/
|
|
guint hidden : 1;
|
|
|
|
/* Whether the compositor thinks the window is visible.
|
|
* This should match up with calls to meta_compositor_show_window /
|
|
* meta_compositor_hide_window.
|
|
*/
|
|
guint visible_to_compositor : 1;
|
|
|
|
/* Whether the compositor knows about the window.
|
|
* This should match up with calls to meta_compositor_add_window /
|
|
* meta_compositor_remove_window.
|
|
*/
|
|
guint known_to_compositor : 1;
|
|
|
|
/* When we next show or hide the window, what effect we should
|
|
* tell the compositor to perform.
|
|
*/
|
|
guint pending_compositor_effect : 4; /* MetaCompEffect */
|
|
|
|
/* Iconic is the state in WM_STATE; happens for workspaces/shading
|
|
* in addition to minimize
|
|
*/
|
|
guint iconic : 1;
|
|
/* initially_iconic is the WM_HINTS setting when we first manage
|
|
* the window. It's taken to mean initially minimized.
|
|
*/
|
|
guint initially_iconic : 1;
|
|
|
|
/* whether an initial workspace was explicitly set */
|
|
guint initial_workspace_set : 1;
|
|
|
|
/* whether an initial timestamp was explicitly set */
|
|
guint initial_timestamp_set : 1;
|
|
|
|
/* whether net_wm_user_time has been set yet */
|
|
guint net_wm_user_time_set : 1;
|
|
|
|
/* whether net_wm_icon_geometry has been set */
|
|
guint icon_geometry_set : 1;
|
|
|
|
/* Globally active / No input */
|
|
guint input : 1;
|
|
|
|
/* MWM hints about features of window */
|
|
guint mwm_decorated : 1;
|
|
guint mwm_border_only : 1;
|
|
guint mwm_has_close_func : 1;
|
|
guint mwm_has_minimize_func : 1;
|
|
guint mwm_has_maximize_func : 1;
|
|
guint mwm_has_move_func : 1;
|
|
guint mwm_has_resize_func : 1;
|
|
|
|
/* Computed features of window */
|
|
guint decorated : 1;
|
|
guint border_only : 1;
|
|
guint always_sticky : 1;
|
|
guint has_close_func : 1;
|
|
guint has_minimize_func : 1;
|
|
guint has_maximize_func : 1;
|
|
guint has_shade_func : 1;
|
|
guint has_move_func : 1;
|
|
guint has_resize_func : 1;
|
|
guint has_fullscreen_func : 1;
|
|
|
|
/* Computed whether to skip taskbar or not */
|
|
guint skip_taskbar : 1;
|
|
guint skip_pager : 1;
|
|
|
|
/* TRUE if client set these */
|
|
guint wm_state_above : 1;
|
|
guint wm_state_below : 1;
|
|
|
|
/* EWHH demands attention flag */
|
|
guint wm_state_demands_attention : 1;
|
|
|
|
/* TRUE iff window == window->display->focus_window */
|
|
guint has_focus : 1;
|
|
|
|
/* Have we placed this window? */
|
|
guint placed : 1;
|
|
|
|
/* Is this not a transient of the focus window which is being denied focus? */
|
|
guint denied_focus_and_not_transient : 1;
|
|
|
|
/* Has this window not ever been shown yet? */
|
|
guint showing_for_first_time : 1;
|
|
|
|
/* Are we in meta_window_unmanage()? */
|
|
guint unmanaging : 1;
|
|
|
|
/* Are we in meta_window_new()? */
|
|
guint constructing : 1;
|
|
|
|
/* Are we in the various queues? (Bitfield: see META_WINDOW_IS_IN_QUEUE) */
|
|
guint is_in_queues : NUMBER_OF_QUEUES;
|
|
|
|
/* Used by keybindings.c */
|
|
guint keys_grabbed : 1; /* normal keybindings grabbed */
|
|
guint grab_on_frame : 1; /* grabs are on the frame */
|
|
guint all_keys_grabbed : 1; /* AnyKey grabbed */
|
|
|
|
/* Set if the reason for unmanaging the window is that
|
|
* it was withdrawn
|
|
*/
|
|
guint withdrawn : 1;
|
|
|
|
/* TRUE if constrain_position should calc placement.
|
|
* only relevant if !window->placed
|
|
*/
|
|
guint calc_placement : 1;
|
|
|
|
/* if TRUE, window was maximized at start of current grab op */
|
|
guint shaken_loose : 1;
|
|
|
|
/* if TRUE we have a grab on the focus click buttons */
|
|
guint have_focus_click_grab : 1;
|
|
|
|
/* if TRUE, application is buggy and SYNC resizing is turned off */
|
|
guint disable_sync : 1;
|
|
|
|
/* if TRUE, window is attached to its parent */
|
|
guint attached : 1;
|
|
|
|
/* whether or not the window is from a program running on another machine */
|
|
guint is_remote : 1;
|
|
|
|
/* whether focus should be restored on map */
|
|
guint restore_focus_on_map : 1;
|
|
|
|
/* if non-NULL, the bounds of the window frame */
|
|
cairo_region_t *frame_bounds;
|
|
|
|
/* if non-NULL, the bounding shape region of the window. Relative to
|
|
* the server-side client window. */
|
|
cairo_region_t *shape_region;
|
|
|
|
/* if non-NULL, the opaque region _NET_WM_OPAQUE_REGION */
|
|
cairo_region_t *opaque_region;
|
|
|
|
/* the input shape region for picking */
|
|
cairo_region_t *input_region;
|
|
|
|
/* _NET_WM_WINDOW_OPACITY rescaled to 0xFF */
|
|
guint8 opacity;
|
|
|
|
/* if TRUE, the we have the new form of sync request counter which
|
|
* also handles application frames */
|
|
guint extended_sync_request_counter : 1;
|
|
|
|
/* Note: can be NULL */
|
|
GSList *struts;
|
|
|
|
/* XSync update counter */
|
|
XSyncCounter sync_request_counter;
|
|
gint64 sync_request_serial;
|
|
gint64 sync_request_wait_serial;
|
|
guint sync_request_timeout_id;
|
|
/* alarm monitoring client's _NET_WM_SYNC_REQUEST_COUNTER */
|
|
XSyncAlarm sync_request_alarm;
|
|
|
|
/* Number of UnmapNotify that are caused by us, if
|
|
* we get UnmapNotify with none pending then the client
|
|
* is withdrawing the window.
|
|
*/
|
|
int unmaps_pending;
|
|
|
|
/* Number of XReparentWindow requests that we have queued.
|
|
*/
|
|
int reparents_pending;
|
|
|
|
/* See docs for meta_window_get_stable_sequence() */
|
|
guint32 stable_sequence;
|
|
|
|
/* set to the most recent user-interaction event timestamp that we
|
|
know about for this window */
|
|
guint32 net_wm_user_time;
|
|
|
|
/* window that gets updated net_wm_user_time values */
|
|
Window user_time_window;
|
|
|
|
gboolean has_custom_frame_extents;
|
|
GtkBorder custom_frame_extents;
|
|
|
|
/* The rectangles here are in "frame rect" coordinates. See the
|
|
* comment at the top of meta_window_move_resize_internal() for more
|
|
* information. */
|
|
|
|
/* The current window geometry of the window. */
|
|
MetaRectangle rect;
|
|
|
|
/* The geometry to restore when we unmaximize. */
|
|
MetaRectangle saved_rect;
|
|
|
|
/* This is the geometry the window will have if no constraints have
|
|
* applied. We use this whenever we are moving implicitly (for example,
|
|
* if we move to avoid a panel, we can snap back to this position if
|
|
* the panel moves again).
|
|
*/
|
|
MetaRectangle unconstrained_rect;
|
|
|
|
/* The rectangle of the "server-side" geometry of the buffer,
|
|
* in root coordinates.
|
|
*
|
|
* For X11 windows, this matches XGetGeometry of the toplevel.
|
|
*
|
|
* For Wayland windows, the position matches the position of the
|
|
* surface associated with shell surface (wl_shell_surface, xdg_surface
|
|
* etc). The size matches the size surface size as displayed in the stage.
|
|
*/
|
|
MetaRectangle buffer_rect;
|
|
|
|
/* Cached net_wm_icon_geometry */
|
|
MetaRectangle icon_geometry;
|
|
|
|
/* x/y/w/h here get filled with ConfigureRequest values */
|
|
XSizeHints size_hints;
|
|
|
|
/* Managed by stack.c */
|
|
MetaStackLayer layer;
|
|
int stack_position; /* see comment in stack.h */
|
|
|
|
/* Managed by delete.c */
|
|
MetaCloseDialog *close_dialog;
|
|
|
|
/* maintained by group.c */
|
|
MetaGroup *group;
|
|
|
|
GObject *compositor_private;
|
|
|
|
/* Focused window that is (directly or indirectly) attached to this one */
|
|
MetaWindow *attached_focus_window;
|
|
|
|
/* The currently complementary tiled window, if any */
|
|
MetaWindow *tile_match;
|
|
|
|
struct {
|
|
MetaPlacementRule *rule;
|
|
MetaPlacementState state;
|
|
|
|
struct {
|
|
int x;
|
|
int y;
|
|
int rel_x;
|
|
int rel_y;
|
|
} pending;
|
|
|
|
struct {
|
|
int rel_x;
|
|
int rel_y;
|
|
} current;
|
|
} placement;
|
|
|
|
guint unmanage_idle_id;
|
|
|
|
pid_t client_pid;
|
|
};
|
|
|
|
struct _MetaWindowClass
|
|
{
|
|
GObjectClass parent_class;
|
|
|
|
void (*manage) (MetaWindow *window);
|
|
void (*unmanage) (MetaWindow *window);
|
|
void (*ping) (MetaWindow *window,
|
|
guint32 serial);
|
|
void (*delete) (MetaWindow *window,
|
|
guint32 timestamp);
|
|
void (*kill) (MetaWindow *window);
|
|
void (*focus) (MetaWindow *window,
|
|
guint32 timestamp);
|
|
void (*grab_op_began) (MetaWindow *window,
|
|
MetaGrabOp op);
|
|
void (*grab_op_ended) (MetaWindow *window,
|
|
MetaGrabOp op);
|
|
void (*current_workspace_changed) (MetaWindow *window);
|
|
void (*move_resize_internal) (MetaWindow *window,
|
|
MetaGravity gravity,
|
|
MetaRectangle unconstrained_rect,
|
|
MetaRectangle constrained_rect,
|
|
MetaRectangle temporary_rect,
|
|
int rel_x,
|
|
int rel_y,
|
|
MetaMoveResizeFlags flags,
|
|
MetaMoveResizeResultFlags *result);
|
|
gboolean (*update_struts) (MetaWindow *window);
|
|
void (*get_default_skip_hints) (MetaWindow *window,
|
|
gboolean *skip_taskbar_out,
|
|
gboolean *skip_pager_out);
|
|
gboolean (*update_icon) (MetaWindow *window,
|
|
cairo_surface_t **icon,
|
|
cairo_surface_t **mini_icon);
|
|
pid_t (*get_client_pid) (MetaWindow *window);
|
|
void (*update_main_monitor) (MetaWindow *window,
|
|
MetaWindowUpdateMonitorFlags flags);
|
|
void (*main_monitor_changed) (MetaWindow *window,
|
|
const MetaLogicalMonitor *old);
|
|
void (*adjust_fullscreen_monitor_rect) (MetaWindow *window,
|
|
MetaRectangle *monitor_rect);
|
|
void (*force_restore_shortcuts) (MetaWindow *window,
|
|
ClutterInputDevice *source);
|
|
gboolean (*shortcuts_inhibited) (MetaWindow *window,
|
|
ClutterInputDevice *source);
|
|
gboolean (*is_focusable) (MetaWindow *window);
|
|
gboolean (*is_stackable) (MetaWindow *window);
|
|
gboolean (*can_ping) (MetaWindow *window);
|
|
gboolean (*are_updates_frozen) (MetaWindow *window);
|
|
|
|
MetaStackLayer (*calculate_layer) (MetaWindow *window);
|
|
|
|
void (* map) (MetaWindow *window);
|
|
void (* unmap) (MetaWindow *window);
|
|
};
|
|
|
|
/* These differ from window->has_foo_func in that they consider
|
|
* the dynamic window state such as "maximized", not just the
|
|
* window's type
|
|
*/
|
|
#define META_WINDOW_MAXIMIZED(w) ((w)->maximized_horizontally && \
|
|
(w)->maximized_vertically)
|
|
#define META_WINDOW_MAXIMIZED_VERTICALLY(w) ((w)->maximized_vertically)
|
|
#define META_WINDOW_MAXIMIZED_HORIZONTALLY(w) ((w)->maximized_horizontally)
|
|
#define META_WINDOW_TILED_SIDE_BY_SIDE(w) ((w)->maximized_vertically && \
|
|
!(w)->maximized_horizontally && \
|
|
(w)->tile_mode != META_TILE_NONE)
|
|
#define META_WINDOW_TILED_LEFT(w) (META_WINDOW_TILED_SIDE_BY_SIDE(w) && \
|
|
(w)->tile_mode == META_TILE_LEFT)
|
|
#define META_WINDOW_TILED_RIGHT(w) (META_WINDOW_TILED_SIDE_BY_SIDE(w) && \
|
|
(w)->tile_mode == META_TILE_RIGHT)
|
|
#define META_WINDOW_TILED_MAXIMIZED(w)(META_WINDOW_MAXIMIZED(w) && \
|
|
(w)->tile_mode == META_TILE_MAXIMIZED)
|
|
#define META_WINDOW_ALLOWS_MOVE(w) ((w)->has_move_func && !(w)->fullscreen)
|
|
#define META_WINDOW_ALLOWS_RESIZE_EXCEPT_HINTS(w) ((w)->has_resize_func && !META_WINDOW_MAXIMIZED (w) && !(w)->fullscreen && !(w)->shaded)
|
|
#define META_WINDOW_ALLOWS_RESIZE(w) (META_WINDOW_ALLOWS_RESIZE_EXCEPT_HINTS (w) && \
|
|
(((w)->size_hints.min_width < (w)->size_hints.max_width) || \
|
|
((w)->size_hints.min_height < (w)->size_hints.max_height)))
|
|
#define META_WINDOW_ALLOWS_HORIZONTAL_RESIZE(w) (META_WINDOW_ALLOWS_RESIZE_EXCEPT_HINTS (w) && (w)->size_hints.min_width < (w)->size_hints.max_width)
|
|
#define META_WINDOW_ALLOWS_VERTICAL_RESIZE(w) (META_WINDOW_ALLOWS_RESIZE_EXCEPT_HINTS (w) && (w)->size_hints.min_height < (w)->size_hints.max_height)
|
|
|
|
MetaWindow * _meta_window_shared_new (MetaDisplay *display,
|
|
MetaWindowClientType client_type,
|
|
MetaWaylandSurface *surface,
|
|
Window xwindow,
|
|
gulong existing_wm_state,
|
|
MetaCompEffect effect,
|
|
XWindowAttributes *attrs);
|
|
|
|
void meta_window_unmanage (MetaWindow *window,
|
|
guint32 timestamp);
|
|
void meta_window_unmanage_on_idle (MetaWindow *window);
|
|
void meta_window_queue (MetaWindow *window,
|
|
guint queuebits);
|
|
META_EXPORT_TEST
|
|
void meta_window_untile (MetaWindow *window);
|
|
|
|
META_EXPORT_TEST
|
|
void meta_window_tile (MetaWindow *window,
|
|
MetaTileMode mode);
|
|
MetaTileMode meta_window_get_tile_mode (MetaWindow *window);
|
|
void meta_window_restore_tile (MetaWindow *window,
|
|
MetaTileMode mode,
|
|
int width,
|
|
int height);
|
|
void meta_window_maximize_internal (MetaWindow *window,
|
|
MetaMaximizeFlags directions,
|
|
MetaRectangle *saved_rect);
|
|
|
|
void meta_window_make_fullscreen_internal (MetaWindow *window);
|
|
void meta_window_update_fullscreen_monitors (MetaWindow *window,
|
|
MetaLogicalMonitor *top,
|
|
MetaLogicalMonitor *bottom,
|
|
MetaLogicalMonitor *left,
|
|
MetaLogicalMonitor *right);
|
|
|
|
gboolean meta_window_has_fullscreen_monitors (MetaWindow *window);
|
|
|
|
void meta_window_adjust_fullscreen_monitor_rect (MetaWindow *window,
|
|
MetaRectangle *monitor_rect);
|
|
|
|
void meta_window_resize_frame_with_gravity (MetaWindow *window,
|
|
gboolean user_op,
|
|
int w,
|
|
int h,
|
|
MetaGravity gravity);
|
|
|
|
/* Return whether the window should be currently mapped */
|
|
gboolean meta_window_should_be_showing (MetaWindow *window);
|
|
|
|
void meta_window_update_struts (MetaWindow *window);
|
|
|
|
/* gets position we need to set to stay in current position,
|
|
* assuming position will be gravity-compensated. i.e.
|
|
* this is the position a client would send in a configure
|
|
* request.
|
|
*/
|
|
void meta_window_get_gravity_position (MetaWindow *window,
|
|
MetaGravity gravity,
|
|
int *x,
|
|
int *y);
|
|
/* Get geometry for saving in the session; x/y are gravity
|
|
* position, and w/h are in resize inc above the base size.
|
|
*/
|
|
void meta_window_get_session_geometry (MetaWindow *window,
|
|
int *x,
|
|
int *y,
|
|
int *width,
|
|
int *height);
|
|
|
|
void meta_window_update_unfocused_button_grabs (MetaWindow *window);
|
|
|
|
void meta_window_set_focused_internal (MetaWindow *window,
|
|
gboolean focused);
|
|
|
|
gboolean meta_window_is_focusable (MetaWindow *window);
|
|
|
|
gboolean meta_window_can_ping (MetaWindow *window);
|
|
|
|
MetaStackLayer meta_window_calculate_layer (MetaWindow *window);
|
|
|
|
void meta_window_current_workspace_changed (MetaWindow *window);
|
|
|
|
void meta_window_show_menu (MetaWindow *window,
|
|
MetaWindowMenuType menu,
|
|
int x,
|
|
int y);
|
|
|
|
void meta_window_show_menu_for_rect (MetaWindow *window,
|
|
MetaWindowMenuType menu,
|
|
MetaRectangle *rect);
|
|
|
|
gboolean meta_window_handle_mouse_grab_op_event (MetaWindow *window,
|
|
const ClutterEvent *event);
|
|
|
|
GList* meta_window_get_workspaces (MetaWindow *window);
|
|
|
|
void meta_window_get_work_area_for_logical_monitor (MetaWindow *window,
|
|
MetaLogicalMonitor *logical_monitor,
|
|
MetaRectangle *area);
|
|
|
|
int meta_window_get_current_tile_monitor_number (MetaWindow *window);
|
|
void meta_window_get_tile_area (MetaWindow *window,
|
|
MetaTileMode mode,
|
|
MetaRectangle *tile_area);
|
|
|
|
|
|
gboolean meta_window_same_application (MetaWindow *window,
|
|
MetaWindow *other_window);
|
|
|
|
#define META_WINDOW_IN_NORMAL_TAB_CHAIN_TYPE(w) \
|
|
((w)->type != META_WINDOW_DOCK && (w)->type != META_WINDOW_DESKTOP)
|
|
#define META_WINDOW_IN_NORMAL_TAB_CHAIN(w) \
|
|
(meta_window_is_focusable (w) && META_WINDOW_IN_NORMAL_TAB_CHAIN_TYPE (w) && (!(w)->skip_taskbar))
|
|
#define META_WINDOW_IN_DOCK_TAB_CHAIN(w) \
|
|
(meta_window_is_focusable (w) && (! META_WINDOW_IN_NORMAL_TAB_CHAIN_TYPE (w) || (w)->skip_taskbar))
|
|
#define META_WINDOW_IN_GROUP_TAB_CHAIN(w, g) \
|
|
(meta_window_is_focusable (w) && (!g || meta_window_get_group(w)==g))
|
|
|
|
void meta_window_free_delete_dialog (MetaWindow *window);
|
|
|
|
void meta_window_update_keyboard_resize (MetaWindow *window,
|
|
gboolean update_cursor);
|
|
void meta_window_update_keyboard_move (MetaWindow *window);
|
|
|
|
MetaStackLayer meta_window_get_default_layer (MetaWindow *window);
|
|
void meta_window_update_layer (MetaWindow *window);
|
|
|
|
void meta_window_recalc_features (MetaWindow *window);
|
|
|
|
void meta_window_set_type (MetaWindow *window,
|
|
MetaWindowType type);
|
|
|
|
void meta_window_frame_size_changed (MetaWindow *window);
|
|
|
|
gboolean meta_window_is_in_stack (MetaWindow *window);
|
|
|
|
void meta_window_stack_just_below (MetaWindow *window,
|
|
MetaWindow *below_this_one);
|
|
|
|
void meta_window_stack_just_above (MetaWindow *window,
|
|
MetaWindow *above_this_one);
|
|
|
|
void meta_window_set_user_time (MetaWindow *window,
|
|
guint32 timestamp);
|
|
|
|
void meta_window_update_for_monitors_changed (MetaWindow *window);
|
|
void meta_window_on_all_workspaces_changed (MetaWindow *window);
|
|
|
|
gboolean meta_window_should_attach_to_parent (MetaWindow *window);
|
|
gboolean meta_window_can_tile_side_by_side (MetaWindow *window);
|
|
|
|
void meta_window_compute_tile_match (MetaWindow *window);
|
|
|
|
gboolean meta_window_updates_are_frozen (MetaWindow *window);
|
|
|
|
void meta_window_set_title (MetaWindow *window,
|
|
const char *title);
|
|
void meta_window_set_wm_class (MetaWindow *window,
|
|
const char *wm_class,
|
|
const char *wm_instance);
|
|
void meta_window_set_gtk_dbus_properties (MetaWindow *window,
|
|
const char *application_id,
|
|
const char *unique_bus_name,
|
|
const char *appmenu_path,
|
|
const char *menubar_path,
|
|
const char *application_object_path,
|
|
const char *window_object_path);
|
|
|
|
gboolean meta_window_has_transient_type (MetaWindow *window);
|
|
|
|
void meta_window_set_transient_for (MetaWindow *window,
|
|
MetaWindow *parent);
|
|
|
|
void meta_window_set_opacity (MetaWindow *window,
|
|
guint8 opacity);
|
|
|
|
void meta_window_handle_enter (MetaWindow *window,
|
|
guint32 timestamp,
|
|
guint root_x,
|
|
guint root_y);
|
|
void meta_window_handle_leave (MetaWindow *window);
|
|
|
|
gboolean meta_window_handle_ui_frame_event (MetaWindow *window,
|
|
const ClutterEvent *event);
|
|
|
|
void meta_window_handle_ungrabbed_event (MetaWindow *window,
|
|
const ClutterEvent *event);
|
|
|
|
void meta_window_get_client_area_rect (const MetaWindow *window,
|
|
cairo_rectangle_int_t *rect);
|
|
void meta_window_get_titlebar_rect (MetaWindow *window,
|
|
MetaRectangle *titlebar_rect);
|
|
|
|
void meta_window_activate_full (MetaWindow *window,
|
|
guint32 timestamp,
|
|
MetaClientType source_indication,
|
|
MetaWorkspace *workspace);
|
|
|
|
META_EXPORT_TEST
|
|
MetaLogicalMonitor * meta_window_calculate_main_logical_monitor (MetaWindow *window);
|
|
|
|
MetaLogicalMonitor * meta_window_get_main_logical_monitor (MetaWindow *window);
|
|
void meta_window_update_monitor (MetaWindow *window,
|
|
MetaWindowUpdateMonitorFlags flags);
|
|
|
|
void meta_window_set_urgent (MetaWindow *window,
|
|
gboolean urgent);
|
|
|
|
void meta_window_update_resize (MetaWindow *window,
|
|
gboolean snap,
|
|
int x, int y,
|
|
gboolean force);
|
|
|
|
void meta_window_move_resize_internal (MetaWindow *window,
|
|
MetaMoveResizeFlags flags,
|
|
MetaGravity gravity,
|
|
MetaRectangle frame_rect);
|
|
|
|
void meta_window_grab_op_began (MetaWindow *window, MetaGrabOp op);
|
|
void meta_window_grab_op_ended (MetaWindow *window, MetaGrabOp op);
|
|
|
|
void meta_window_set_alive (MetaWindow *window, gboolean is_alive);
|
|
|
|
gboolean meta_window_has_pointer (MetaWindow *window);
|
|
|
|
void meta_window_emit_size_changed (MetaWindow *window);
|
|
|
|
MetaPlacementRule *meta_window_get_placement_rule (MetaWindow *window);
|
|
|
|
void meta_window_force_placement (MetaWindow *window,
|
|
gboolean force_move);
|
|
|
|
void meta_window_force_restore_shortcuts (MetaWindow *window,
|
|
ClutterInputDevice *source);
|
|
|
|
gboolean meta_window_shortcuts_inhibited (MetaWindow *window,
|
|
ClutterInputDevice *source);
|
|
gboolean meta_window_is_stackable (MetaWindow *window);
|
|
#endif
|