2006-10-01 22:30:10 +00:00
|
|
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
|
|
|
|
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
|
|
|
/* Mutter X window decorations */
|
2001-05-31 06:42:58 +00:00
|
|
|
|
2014-05-02 13:34:02 +00:00
|
|
|
/*
|
2001-05-31 06:42:58 +00:00
|
|
|
* Copyright (C) 2001 Havoc Pennington
|
2014-05-02 13:34:02 +00:00
|
|
|
*
|
2001-05-31 06:42:58 +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-31 06:42:58 +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-31 06:42:58 +00:00
|
|
|
*/
|
|
|
|
|
2023-07-21 13:37:20 +00:00
|
|
|
#pragma once
|
2001-05-31 06:42:58 +00:00
|
|
|
|
2018-07-10 08:36:24 +00:00
|
|
|
#include "core/window-private.h"
|
2015-01-01 05:55:36 +00:00
|
|
|
|
2022-09-09 13:54:28 +00:00
|
|
|
#include "x11/meta-sync-counter.h"
|
|
|
|
|
2001-05-31 06:42:58 +00:00
|
|
|
struct _MetaFrame
|
|
|
|
{
|
|
|
|
/* window we frame */
|
|
|
|
MetaWindow *window;
|
|
|
|
|
|
|
|
/* reparent window */
|
|
|
|
Window xwindow;
|
|
|
|
|
2001-06-03 21:39:57 +00:00
|
|
|
/* This rect is trusted info from where we put the
|
2001-06-02 04:14:18 +00:00
|
|
|
* frame, not the result of ConfigureNotify
|
|
|
|
*/
|
2023-07-19 23:46:15 +00:00
|
|
|
MtkRectangle rect;
|
2001-06-18 03:24:25 +00:00
|
|
|
|
2013-11-15 22:37:50 +00:00
|
|
|
MetaFrameBorders cached_borders; /* valid if borders_cached is set */
|
|
|
|
|
2023-09-04 14:30:38 +00:00
|
|
|
MtkRegion *opaque_region;
|
2022-12-16 11:55:15 +00:00
|
|
|
|
2022-09-09 13:54:28 +00:00
|
|
|
MetaSyncCounter sync_counter;
|
|
|
|
|
2001-06-18 03:24:25 +00:00
|
|
|
/* position of client, size of frame */
|
2001-06-03 01:33:27 +00:00
|
|
|
int child_x;
|
|
|
|
int child_y;
|
2001-06-07 05:18:10 +00:00
|
|
|
int right_width;
|
|
|
|
int bottom_height;
|
2001-06-06 04:47:37 +00:00
|
|
|
|
2013-11-15 22:37:50 +00:00
|
|
|
guint borders_cached : 1;
|
2001-05-31 06:42:58 +00:00
|
|
|
};
|
|
|
|
|
2001-06-03 01:33:27 +00:00
|
|
|
void meta_window_ensure_frame (MetaWindow *window);
|
|
|
|
void meta_window_destroy_frame (MetaWindow *window);
|
|
|
|
|
2011-03-06 00:29:12 +00:00
|
|
|
Window meta_frame_get_xwindow (MetaFrame *frame);
|
2001-06-18 03:24:25 +00:00
|
|
|
|
|
|
|
/* These should ONLY be called from meta_window_move_resize_internal */
|
2011-07-12 04:37:41 +00:00
|
|
|
void meta_frame_calc_borders (MetaFrame *frame,
|
|
|
|
MetaFrameBorders *borders);
|
|
|
|
|
2011-03-22 19:36:12 +00:00
|
|
|
gboolean meta_frame_sync_to_window (MetaFrame *frame,
|
2001-06-10 03:17:15 +00:00
|
|
|
gboolean need_resize);
|
2001-05-31 06:42:58 +00:00
|
|
|
|
2013-11-15 22:37:50 +00:00
|
|
|
void meta_frame_clear_cached_borders (MetaFrame *frame);
|
|
|
|
|
2023-09-04 14:30:38 +00:00
|
|
|
MtkRegion *meta_frame_get_frame_bounds (MetaFrame *frame);
|
2011-03-22 19:36:12 +00:00
|
|
|
|
2023-07-19 23:46:15 +00:00
|
|
|
void meta_frame_get_mask (MetaFrame *frame,
|
|
|
|
MtkRectangle *frame_rect,
|
|
|
|
cairo_t *cr);
|
2013-04-12 17:00:15 +00:00
|
|
|
|
x11: Integrate frames client into Mutter
Replace the in-process implementation of frames with the external
frames client.
When a client window is created and managed by Mutter, Mutter will
determine whether it is a window that requires decorations and
hint the creation of a frame for it by setting the _MUTTER_NEEDS_FRAME
property on the client window.
After the frames client created a window that has the _MUTTER_FRAME_FOR
property, Mutter will proceed to reparent the client window on the
frame window, and show them as a single unit.
Rendering and event handling on the frame window will be performed by
the external client, Mutter is still responsible for everything else,
namely resizing client and frame window in synchronization, and
managing updates on the MetaWindowActor.
In order to let the frame be managed by the external client, Mutter
needs to change the way some properties are forwarded to the client
and/or frame windows. Some properties are necessary to keep propagating
to the client window only, some others need to happen on the frame
window now, and some others needs to be propagated on both so they
are synchronized about the behavior.
Also, some events that were previously totally unexpected in frame
windows are now susceptible to happen, so must be allowed now.
MetaFrame in src/core/frame.c now acts as the wrapper of foreign
windows created by the frames client, from the Mutter side. Location,
size, and lifetime are still largely in control of Mutter, some
details like visible/invisible borders are obtained from the client
instead (through the _MUTTER_FRAME_EXTENTS and _GTK_FRAME_EXTENTS
properties, respectively).
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/2175>
2022-09-08 08:35:47 +00:00
|
|
|
gboolean meta_frame_handle_xevent (MetaFrame *frame,
|
|
|
|
XEvent *event);
|
2001-05-31 06:42:58 +00:00
|
|
|
|
x11: Integrate frames client into Mutter
Replace the in-process implementation of frames with the external
frames client.
When a client window is created and managed by Mutter, Mutter will
determine whether it is a window that requires decorations and
hint the creation of a frame for it by setting the _MUTTER_NEEDS_FRAME
property on the client window.
After the frames client created a window that has the _MUTTER_FRAME_FOR
property, Mutter will proceed to reparent the client window on the
frame window, and show them as a single unit.
Rendering and event handling on the frame window will be performed by
the external client, Mutter is still responsible for everything else,
namely resizing client and frame window in synchronization, and
managing updates on the MetaWindowActor.
In order to let the frame be managed by the external client, Mutter
needs to change the way some properties are forwarded to the client
and/or frame windows. Some properties are necessary to keep propagating
to the client window only, some others need to happen on the frame
window now, and some others needs to be propagated on both so they
are synchronized about the behavior.
Also, some events that were previously totally unexpected in frame
windows are now susceptible to happen, so must be allowed now.
MetaFrame in src/core/frame.c now acts as the wrapper of foreign
windows created by the frames client, from the Mutter side. Location,
size, and lifetime are still largely in control of Mutter, some
details like visible/invisible borders are obtained from the client
instead (through the _MUTTER_FRAME_EXTENTS and _GTK_FRAME_EXTENTS
properties, respectively).
Part-of: <https://gitlab.gnome.org/GNOME/mutter/-/merge_requests/2175>
2022-09-08 08:35:47 +00:00
|
|
|
GSubprocess * meta_frame_launch_client (MetaX11Display *x11_display,
|
|
|
|
const char *display_name);
|
2001-06-03 01:33:27 +00:00
|
|
|
|
2022-09-09 13:54:28 +00:00
|
|
|
MetaSyncCounter * meta_frame_get_sync_counter (MetaFrame *frame);
|
|
|
|
|
2023-09-04 14:30:38 +00:00
|
|
|
void meta_frame_set_opaque_region (MetaFrame *frame,
|
|
|
|
MtkRegion *region);
|