2008-12-17 09:33:56 +00:00
|
|
|
/* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Copyright (c) 2008 Intel Corp.
|
|
|
|
*
|
|
|
|
* Author: Tomas Frydrych <tf@linux.intel.com>
|
|
|
|
*
|
|
|
|
* 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
|
2014-01-12 01:42:06 +00:00
|
|
|
* along with this program; if not, see <http://www.gnu.org/licenses/>.
|
2008-12-17 09:33:56 +00:00
|
|
|
*/
|
|
|
|
|
2013-03-11 15:52:36 +00:00
|
|
|
/**
|
|
|
|
* SECTION:meta-plugin
|
|
|
|
* @title: MetaPlugin
|
|
|
|
* @short_description: Entry point for plugins
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2018-07-10 08:36:24 +00:00
|
|
|
#include "config.h"
|
|
|
|
|
|
|
|
#include "meta/meta-plugin.h"
|
2008-12-17 09:33:56 +00:00
|
|
|
|
|
|
|
#include <string.h>
|
|
|
|
#include <X11/Xlib.h>
|
|
|
|
#include <X11/extensions/Xfixes.h>
|
|
|
|
#include <X11/extensions/shape.h>
|
|
|
|
|
2018-07-10 08:36:24 +00:00
|
|
|
#include "backends/meta-monitor-manager-private.h"
|
2021-05-10 21:40:49 +00:00
|
|
|
#include "backends/x11/meta-clutter-backend-x11.h"
|
2018-07-10 08:36:24 +00:00
|
|
|
#include "compositor/compositor-private.h"
|
|
|
|
#include "compositor/meta-window-actor-private.h"
|
|
|
|
#include "compositor/meta-plugin-manager.h"
|
|
|
|
#include "meta/display.h"
|
|
|
|
#include "meta/util.h"
|
2009-06-26 19:33:20 +00:00
|
|
|
|
2018-10-30 10:19:36 +00:00
|
|
|
|
|
|
|
typedef struct _MetaPluginPrivate
|
2008-12-17 09:33:56 +00:00
|
|
|
{
|
2014-03-18 21:31:22 +00:00
|
|
|
MetaCompositor *compositor;
|
2018-10-30 10:19:36 +00:00
|
|
|
} MetaPluginPrivate;
|
2008-12-17 09:33:56 +00:00
|
|
|
|
2018-07-19 11:40:39 +00:00
|
|
|
G_DEFINE_ABSTRACT_TYPE_WITH_PRIVATE (MetaPlugin, meta_plugin, G_TYPE_OBJECT);
|
|
|
|
|
2008-12-17 09:33:56 +00:00
|
|
|
static void
|
2010-10-18 17:27:14 +00:00
|
|
|
meta_plugin_class_init (MetaPluginClass *klass)
|
2008-12-17 09:33:56 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2010-10-18 17:27:14 +00:00
|
|
|
meta_plugin_init (MetaPlugin *self)
|
2008-12-17 09:33:56 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2010-10-18 17:27:14 +00:00
|
|
|
const MetaPluginInfo *
|
|
|
|
meta_plugin_get_info (MetaPlugin *plugin)
|
2008-12-17 09:33:56 +00:00
|
|
|
{
|
2010-10-18 17:27:14 +00:00
|
|
|
MetaPluginClass *klass = META_PLUGIN_GET_CLASS (plugin);
|
2008-12-17 09:33:56 +00:00
|
|
|
|
|
|
|
if (klass && klass->plugin_info)
|
|
|
|
return klass->plugin_info (plugin);
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2013-09-04 16:11:43 +00:00
|
|
|
gboolean
|
|
|
|
_meta_plugin_xevent_filter (MetaPlugin *plugin,
|
|
|
|
XEvent *xev)
|
|
|
|
{
|
|
|
|
MetaPluginClass *klass = META_PLUGIN_GET_CLASS (plugin);
|
|
|
|
|
2014-04-22 16:42:14 +00:00
|
|
|
if (klass->xevent_filter)
|
|
|
|
return klass->xevent_filter (plugin, xev);
|
2013-09-04 16:11:43 +00:00
|
|
|
else
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2008-12-17 09:33:56 +00:00
|
|
|
void
|
2010-10-18 17:27:14 +00:00
|
|
|
meta_plugin_switch_workspace_completed (MetaPlugin *plugin)
|
2010-06-16 21:15:56 +00:00
|
|
|
{
|
2018-10-30 10:19:36 +00:00
|
|
|
MetaPluginPrivate *priv = meta_plugin_get_instance_private (plugin);
|
2010-06-16 21:15:56 +00:00
|
|
|
|
2014-03-18 21:31:22 +00:00
|
|
|
meta_switch_workspace_completed (priv->compositor);
|
2010-06-16 21:15:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2010-10-18 17:27:14 +00:00
|
|
|
meta_plugin_window_effect_completed (MetaPlugin *plugin,
|
|
|
|
MetaWindowActor *actor,
|
|
|
|
unsigned long event)
|
2008-12-17 09:33:56 +00:00
|
|
|
{
|
2010-10-18 17:27:14 +00:00
|
|
|
meta_window_actor_effect_completed (actor, event);
|
2010-06-16 21:15:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2010-10-18 17:27:14 +00:00
|
|
|
meta_plugin_minimize_completed (MetaPlugin *plugin,
|
|
|
|
MetaWindowActor *actor)
|
2010-06-16 21:15:56 +00:00
|
|
|
{
|
2010-10-18 17:27:14 +00:00
|
|
|
meta_plugin_window_effect_completed (plugin, actor, META_PLUGIN_MINIMIZE);
|
2010-06-16 21:15:56 +00:00
|
|
|
}
|
|
|
|
|
2013-06-14 01:01:17 +00:00
|
|
|
void
|
|
|
|
meta_plugin_unminimize_completed (MetaPlugin *plugin,
|
|
|
|
MetaWindowActor *actor)
|
|
|
|
{
|
|
|
|
meta_plugin_window_effect_completed (plugin, actor, META_PLUGIN_UNMINIMIZE);
|
|
|
|
}
|
|
|
|
|
2010-06-16 21:15:56 +00:00
|
|
|
void
|
2015-07-06 04:08:08 +00:00
|
|
|
meta_plugin_size_change_completed (MetaPlugin *plugin,
|
|
|
|
MetaWindowActor *actor)
|
2010-06-16 21:15:56 +00:00
|
|
|
{
|
2015-07-06 04:08:08 +00:00
|
|
|
meta_plugin_window_effect_completed (plugin, actor, META_PLUGIN_SIZE_CHANGE);
|
2010-06-16 21:15:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2010-10-18 17:27:14 +00:00
|
|
|
meta_plugin_map_completed (MetaPlugin *plugin,
|
|
|
|
MetaWindowActor *actor)
|
2010-06-16 21:15:56 +00:00
|
|
|
{
|
2010-10-18 17:27:14 +00:00
|
|
|
meta_plugin_window_effect_completed (plugin, actor, META_PLUGIN_MAP);
|
2010-06-16 21:15:56 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void
|
2010-10-18 17:27:14 +00:00
|
|
|
meta_plugin_destroy_completed (MetaPlugin *plugin,
|
|
|
|
MetaWindowActor *actor)
|
2010-06-16 21:15:56 +00:00
|
|
|
{
|
2010-10-18 17:27:14 +00:00
|
|
|
meta_plugin_window_effect_completed (plugin, actor, META_PLUGIN_DESTROY);
|
2008-12-17 09:33:56 +00:00
|
|
|
}
|
|
|
|
|
2009-08-12 04:12:52 +00:00
|
|
|
/**
|
2010-10-18 17:27:14 +00:00
|
|
|
* meta_plugin_begin_modal:
|
|
|
|
* @plugin: a #MetaPlugin
|
2009-08-12 04:12:52 +00:00
|
|
|
* @options: flags that modify the behavior of the modal grab
|
|
|
|
* @timestamp: the timestamp used for establishing grabs
|
|
|
|
*
|
|
|
|
* This function is used to grab the keyboard and mouse for the exclusive
|
|
|
|
* use of the plugin. Correct operation requires that both the keyboard
|
|
|
|
* and mouse are grabbed, or thing will break. (In particular, other
|
2010-10-18 17:27:14 +00:00
|
|
|
* passive X grabs in Meta can trigger but not be handled by the normal
|
2009-08-12 04:12:52 +00:00
|
|
|
* keybinding handling code.) However, the plugin can establish the keyboard
|
|
|
|
* and/or mouse grabs ahead of time and pass in the
|
|
|
|
* %META_MODAL_POINTER_ALREADY_GRABBED and/or %META_MODAL_KEYBOARD_ALREADY_GRABBED
|
|
|
|
* options. This facility is provided for two reasons: first to allow using
|
|
|
|
* this function to establish modality after a passive grab, and second to
|
|
|
|
* allow using obscure features of XGrabPointer() and XGrabKeyboard() without
|
|
|
|
* having to add them to this API.
|
|
|
|
*
|
|
|
|
* Return value: whether we successfully grabbed the keyboard and
|
|
|
|
* mouse and made the plugin modal.
|
|
|
|
*/
|
|
|
|
gboolean
|
2010-10-18 17:27:14 +00:00
|
|
|
meta_plugin_begin_modal (MetaPlugin *plugin,
|
|
|
|
MetaModalOptions options,
|
|
|
|
guint32 timestamp)
|
2009-08-12 04:12:52 +00:00
|
|
|
{
|
2018-10-30 10:19:36 +00:00
|
|
|
MetaPluginPrivate *priv = meta_plugin_get_instance_private (plugin);
|
2009-08-12 04:12:52 +00:00
|
|
|
|
2014-03-18 21:31:22 +00:00
|
|
|
return meta_begin_modal_for_plugin (priv->compositor, plugin,
|
2013-08-16 13:03:03 +00:00
|
|
|
options, timestamp);
|
2009-08-12 04:12:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2011-11-02 15:34:45 +00:00
|
|
|
* meta_plugin_end_modal:
|
2010-10-18 17:27:14 +00:00
|
|
|
* @plugin: a #MetaPlugin
|
2009-08-12 04:12:52 +00:00
|
|
|
* @timestamp: the time used for releasing grabs
|
|
|
|
*
|
|
|
|
* Ends the modal operation begun with meta_plugin_begin_modal(). This
|
|
|
|
* ungrabs both the mouse and keyboard even when
|
|
|
|
* %META_MODAL_POINTER_ALREADY_GRABBED or
|
|
|
|
* %META_MODAL_KEYBOARD_ALREADY_GRABBED were provided as options
|
|
|
|
* when beginnning the modal operation.
|
|
|
|
*/
|
|
|
|
void
|
2010-10-18 17:27:14 +00:00
|
|
|
meta_plugin_end_modal (MetaPlugin *plugin,
|
|
|
|
guint32 timestamp)
|
2009-08-12 04:12:52 +00:00
|
|
|
{
|
2018-10-30 10:19:36 +00:00
|
|
|
MetaPluginPrivate *priv = meta_plugin_get_instance_private (plugin);
|
2009-08-12 04:12:52 +00:00
|
|
|
|
2014-03-18 21:31:22 +00:00
|
|
|
meta_end_modal_for_plugin (priv->compositor, plugin, timestamp);
|
2009-08-12 04:12:52 +00:00
|
|
|
}
|
|
|
|
|
2008-11-17 21:34:28 +00:00
|
|
|
/**
|
2017-08-26 19:43:17 +00:00
|
|
|
* meta_plugin_get_display:
|
2010-10-18 17:27:14 +00:00
|
|
|
* @plugin: a #MetaPlugin
|
2008-11-17 21:34:28 +00:00
|
|
|
*
|
2017-08-26 19:43:17 +00:00
|
|
|
* Gets the #MetaDisplay corresponding to a plugin.
|
2008-11-17 21:34:28 +00:00
|
|
|
*
|
2017-08-26 19:43:17 +00:00
|
|
|
* Return value: (transfer none): the #MetaDisplay for the plugin
|
2008-11-17 21:34:28 +00:00
|
|
|
*/
|
2017-08-26 19:43:17 +00:00
|
|
|
MetaDisplay *
|
|
|
|
meta_plugin_get_display (MetaPlugin *plugin)
|
2008-12-17 09:33:56 +00:00
|
|
|
{
|
2018-10-30 10:19:36 +00:00
|
|
|
MetaPluginPrivate *priv = meta_plugin_get_instance_private (plugin);
|
2019-08-14 17:04:41 +00:00
|
|
|
MetaDisplay *display = meta_compositor_get_display (priv->compositor);
|
2008-12-17 09:33:56 +00:00
|
|
|
|
2019-08-14 17:04:41 +00:00
|
|
|
return display;
|
2008-12-17 09:33:56 +00:00
|
|
|
}
|
2013-07-29 08:12:24 +00:00
|
|
|
|
2014-03-18 21:41:22 +00:00
|
|
|
void
|
2014-03-18 21:31:22 +00:00
|
|
|
_meta_plugin_set_compositor (MetaPlugin *plugin, MetaCompositor *compositor)
|
2014-03-18 21:41:22 +00:00
|
|
|
{
|
2018-10-30 10:19:36 +00:00
|
|
|
MetaPluginPrivate *priv = meta_plugin_get_instance_private (plugin);
|
2014-03-18 21:41:22 +00:00
|
|
|
|
2014-03-18 21:31:22 +00:00
|
|
|
priv->compositor = compositor;
|
2014-03-18 21:41:22 +00:00
|
|
|
}
|
|
|
|
|
2013-07-29 08:12:24 +00:00
|
|
|
void
|
|
|
|
meta_plugin_complete_display_change (MetaPlugin *plugin,
|
|
|
|
gboolean ok)
|
|
|
|
{
|
|
|
|
MetaMonitorManager *manager;
|
|
|
|
|
|
|
|
manager = meta_monitor_manager_get ();
|
|
|
|
meta_monitor_manager_confirm_configuration (manager, ok);
|
|
|
|
}
|