From cb8b19939d4d74043b3e1f3e2287f59db849b475 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Florian=20M=C3=BCllner?= Date: Sun, 6 Dec 2020 06:00:10 +0100 Subject: [PATCH] magnifier: Stop exposing D-Bus interface Screen magnification is the compositor's business, not that of "random" unprivileged tools. And for cases where a more specialised behavior is wanted, an extension likely does a better job than a consumer of the D-Bus API. In addition to that, exporting the interface has been broken for an unknown time, because the object that holds the implementation isn't referenced and thus ends up being garbage collected, whoops. And last but not least, this gets rid of the last public D-Bus name that isn't clearly in the system namespace (org.gnome.Shell, org.gnome.Mutter, org.gtk). https://gitlab.gnome.org/GNOME/gnome-shell/-/issues/3452 Part-of: --- .../org.gnome.Magnifier.ZoomRegion.xml | 26 -- data/dbus-interfaces/org.gnome.Magnifier.xml | 54 --- .../gnome-shell-dbus-interfaces.gresource.xml | 2 - js/js-resources.gresource.xml | 1 - js/ui/magnifier.js | 3 - js/ui/magnifierDBus.js | 351 ------------------ src/main.c | 41 -- 7 files changed, 478 deletions(-) delete mode 100644 data/dbus-interfaces/org.gnome.Magnifier.ZoomRegion.xml delete mode 100644 data/dbus-interfaces/org.gnome.Magnifier.xml delete mode 100644 js/ui/magnifierDBus.js diff --git a/data/dbus-interfaces/org.gnome.Magnifier.ZoomRegion.xml b/data/dbus-interfaces/org.gnome.Magnifier.ZoomRegion.xml deleted file mode 100644 index 5db2734d0..000000000 --- a/data/dbus-interfaces/org.gnome.Magnifier.ZoomRegion.xml +++ /dev/null @@ -1,26 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/data/dbus-interfaces/org.gnome.Magnifier.xml b/data/dbus-interfaces/org.gnome.Magnifier.xml deleted file mode 100644 index 2ade4dd34..000000000 --- a/data/dbus-interfaces/org.gnome.Magnifier.xml +++ /dev/null @@ -1,54 +0,0 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - diff --git a/data/gnome-shell-dbus-interfaces.gresource.xml b/data/gnome-shell-dbus-interfaces.gresource.xml index 69bc67458..e74070039 100644 --- a/data/gnome-shell-dbus-interfaces.gresource.xml +++ b/data/gnome-shell-dbus-interfaces.gresource.xml @@ -26,8 +26,6 @@ org.freedesktop.realmd.Service.xml org.freedesktop.UPower.Device.xml org.freedesktop.UPower.xml - org.gnome.Magnifier.xml - org.gnome.Magnifier.ZoomRegion.xml org.gnome.Mutter.ScreenCast.xml org.gnome.ScreenSaver.xml org.gnome.SessionManager.EndSessionDialog.xml diff --git a/js/js-resources.gresource.xml b/js/js-resources.gresource.xml index 26878daf8..e7c0dda00 100644 --- a/js/js-resources.gresource.xml +++ b/js/js-resources.gresource.xml @@ -71,7 +71,6 @@ ui/locatePointer.js ui/lookingGlass.js ui/magnifier.js - ui/magnifierDBus.js ui/main.js ui/messageTray.js ui/messageList.js diff --git a/js/ui/magnifier.js b/js/ui/magnifier.js index 7cfe06fd4..75cc1f901 100644 --- a/js/ui/magnifier.js +++ b/js/ui/magnifier.js @@ -7,7 +7,6 @@ const Signals = imports.signals; const Background = imports.ui.background; const FocusCaretTracker = imports.ui.focusCaretTracker; const Main = imports.ui.main; -const MagnifierDBus = imports.ui.magnifierDBus; const Params = imports.misc.params; const PointerWatcher = imports.ui.pointerWatcher; @@ -117,8 +116,6 @@ var Magnifier = class Magnifier { this.setActive(St.Settings.get().magnifier_active); }); - // Export to dbus. - new MagnifierDBus.ShellMagnifier(); this.setActive(St.Settings.get().magnifier_active); } diff --git a/js/ui/magnifierDBus.js b/js/ui/magnifierDBus.js deleted file mode 100644 index 6f962d13a..000000000 --- a/js/ui/magnifierDBus.js +++ /dev/null @@ -1,351 +0,0 @@ -// -*- mode: js; js-indent-level: 4; indent-tabs-mode: nil -*- -/* exported ShellMagnifier */ - -const Gio = imports.gi.Gio; -const Main = imports.ui.main; - -const { loadInterfaceXML } = imports.misc.fileUtils; - -const MAG_SERVICE_PATH = '/org/gnome/Magnifier'; -const ZOOM_SERVICE_PATH = '/org/gnome/Magnifier/ZoomRegion'; - -// Subset of gnome-mag's Magnifier dbus interface -- to be expanded. See: -// http://git.gnome.org/browse/gnome-mag/tree/xml/...Magnifier.xml -const MagnifierIface = loadInterfaceXML('org.gnome.Magnifier'); - -// Subset of gnome-mag's ZoomRegion dbus interface -- to be expanded. See: -// http://git.gnome.org/browse/gnome-mag/tree/xml/...ZoomRegion.xml -const ZoomRegionIface = loadInterfaceXML('org.gnome.Magnifier.ZoomRegion'); - -// For making unique ZoomRegion DBus proxy object paths of the form: -// '/org/gnome/Magnifier/ZoomRegion/zoomer0', -// '/org/gnome/Magnifier/ZoomRegion/zoomer1', etc. -let _zoomRegionInstanceCount = 0; - -var ShellMagnifier = class ShellMagnifier { - constructor() { - this._zoomers = {}; - - this._dbusImpl = Gio.DBusExportedObject.wrapJSObject(MagnifierIface, this); - this._dbusImpl.export(Gio.DBus.session, MAG_SERVICE_PATH); - } - - /** - * setActive: - * @param {bool} activate: activate or de-activate the magnifier. - */ - setActive(activate) { - Main.magnifier.setActive(activate); - } - - /** - * isActive: - * @returns {bool} Whether the magnifier is active. - */ - isActive() { - return Main.magnifier.isActive(); - } - - /** - * showCursor: - * Show the system mouse pointer. - */ - showCursor() { - Main.magnifier.showSystemCursor(); - } - - /** - * hideCursor: - * Hide the system mouse pointer. - */ - hideCursor() { - Main.magnifier.hideSystemCursor(); - } - - /** - * createZoomRegion: - * Create a new ZoomRegion and return its object path. - * @param {number} xMagFactor: - * The power to set horizontal magnification of the ZoomRegion. - * A value of 1.0 means no magnification. A value of 2.0 doubles - * the size. - * @param {number} yMagFactor: - * The power to set the vertical magnification of the - * ZoomRegion. - * @param {number[]} roi - * Array of integers defining the region of the screen/desktop - * to magnify. The array has the form [left, top, right, bottom]. - * @param {number[]} viewPort - * Array of integers, [left, top, right, bottom] that defines - * the position of the ZoomRegion on screen. - * - * FIXME: The arguments here are redundant, since the width and height of - * the ROI are determined by the viewport and magnification factors. - * We ignore the passed in width and height. - * - * @returns {ZoomRegion} The newly created ZoomRegion. - */ - createZoomRegion(xMagFactor, yMagFactor, roi, viewPort) { - let ROI = { x: roi[0], y: roi[1], width: roi[2] - roi[0], height: roi[3] - roi[1] }; - let viewBox = { x: viewPort[0], y: viewPort[1], width: viewPort[2] - viewPort[0], height: viewPort[3] - viewPort[1] }; - let realZoomRegion = Main.magnifier.createZoomRegion(xMagFactor, yMagFactor, ROI, viewBox); - let objectPath = `${ZOOM_SERVICE_PATH}/zoomer${_zoomRegionInstanceCount}`; - _zoomRegionInstanceCount++; - - let zoomRegionProxy = new ShellMagnifierZoomRegion(objectPath, realZoomRegion); - let proxyAndZoomRegion = {}; - proxyAndZoomRegion.proxy = zoomRegionProxy; - proxyAndZoomRegion.zoomRegion = realZoomRegion; - this._zoomers[objectPath] = proxyAndZoomRegion; - return objectPath; - } - - /** - * addZoomRegion: - * Append the given ZoomRegion to the magnifier's list of ZoomRegions. - * @param {string} zoomerObjectPath: The object path for the zoom - * region proxy. - * @returns {bool} whether the region was added successfully - */ - addZoomRegion(zoomerObjectPath) { - let proxyAndZoomRegion = this._zoomers[zoomerObjectPath]; - if (proxyAndZoomRegion && proxyAndZoomRegion.zoomRegion) { - Main.magnifier.addZoomRegion(proxyAndZoomRegion.zoomRegion); - return true; - } else { - return false; - } - } - - /** - * getZoomRegions: - * Return a list of ZoomRegion object paths for this Magnifier. - * @returns {string[]}: The Magnifier's zoom region list as an array - * of DBus object paths. - */ - getZoomRegions() { - // There may be more ZoomRegions in the magnifier itself than have - // been added through dbus. Make sure all of them are associated with - // an object path and proxy. - let zoomRegions = Main.magnifier.getZoomRegions(); - let objectPaths = []; - let thoseZoomers = this._zoomers; - zoomRegions.forEach(aZoomRegion => { - let found = false; - for (let objectPath in thoseZoomers) { - let proxyAndZoomRegion = thoseZoomers[objectPath]; - if (proxyAndZoomRegion.zoomRegion === aZoomRegion) { - objectPaths.push(objectPath); - found = true; - break; - } - } - if (!found) { - // Got a ZoomRegion with no DBus proxy, make one. - let newPath = `${ZOOM_SERVICE_PATH}/zoomer${_zoomRegionInstanceCount}`; - _zoomRegionInstanceCount++; - let zoomRegionProxy = new ShellMagnifierZoomRegion(newPath, aZoomRegion); - let proxyAndZoomer = {}; - proxyAndZoomer.proxy = zoomRegionProxy; - proxyAndZoomer.zoomRegion = aZoomRegion; - thoseZoomers[newPath] = proxyAndZoomer; - objectPaths.push(newPath); - } - }); - return objectPaths; - } - - /** - * clearAllZoomRegions: - * Remove all the zoom regions from this Magnfier's ZoomRegion list. - */ - clearAllZoomRegions() { - Main.magnifier.clearAllZoomRegions(); - for (let objectPath in this._zoomers) { - let proxyAndZoomer = this._zoomers[objectPath]; - proxyAndZoomer.proxy.destroy(); - proxyAndZoomer.proxy = null; - proxyAndZoomer.zoomRegion = null; - delete this._zoomers[objectPath]; - } - this._zoomers = {}; - } - - /** - * fullScreenCapable: - * Consult if the Magnifier can magnify in full-screen mode. - * @returns {bool} Always return true. - */ - fullScreenCapable() { - return true; - } - - /** - * setCrosswireSize: - * Set the crosswire size of all ZoomRegions. - * @param {number} size: The thickness of each line in the cross wire. - */ - setCrosswireSize(size) { - Main.magnifier.setCrosshairsThickness(size); - } - - /** - * getCrosswireSize: - * Get the crosswire size of all ZoomRegions. - * @returns {number}: The thickness of each line in the cross wire. - */ - getCrosswireSize() { - return Main.magnifier.getCrosshairsThickness(); - } - - /** - * setCrosswireLength: - * Set the crosswire length of all zoom-regions.. - * @param {number} length: The length of each line in the cross wire. - */ - setCrosswireLength(length) { - Main.magnifier.setCrosshairsLength(length); - } - - /** - * getCrosswireSize: - * Get the crosswire length of all zoom-regions. - * @returns {number} size: The length of each line in the cross wire. - */ - getCrosswireLength() { - return Main.magnifier.getCrosshairsLength(); - } - - /** - * setCrosswireClip: - * Set if the crosswire will be clipped by the cursor image.. - * @param {bool} clip: Flag to indicate whether to clip the crosswire. - */ - setCrosswireClip(clip) { - Main.magnifier.setCrosshairsClip(clip); - } - - /** - * getCrosswireClip: - * Get the crosswire clip value. - * @returns {bool}: Whether the crosswire is clipped by the cursor image. - */ - getCrosswireClip() { - return Main.magnifier.getCrosshairsClip(); - } - - /** - * setCrosswireColor: - * Set the crosswire color of all ZoomRegions. - * @param {number} color: Unsigned int of the form rrggbbaa. - */ - setCrosswireColor(color) { - Main.magnifier.setCrosshairsColor('#%08x'.format(color)); - } - - /** - * getCrosswireClip: - * Get the crosswire color of all ZoomRegions. - * @returns {number}: The crosswire color as an unsigned int in - * the form rrggbbaa. - */ - getCrosswireColor() { - let colorString = Main.magnifier.getCrosshairsColor(); - // Drop the leading '#'. - return parseInt(colorString.slice(1), 16); - } -}; - -/** - * ShellMagnifierZoomRegion: - * Object that implements the DBus ZoomRegion interface. - * @zoomerObjectPath: String that is the path to a DBus ZoomRegion. - * @zoomRegion: The actual zoom region associated with the object path. - */ -var ShellMagnifierZoomRegion = class ShellMagnifierZoomRegion { - constructor(zoomerObjectPath, zoomRegion) { - this._zoomRegion = zoomRegion; - - this._dbusImpl = Gio.DBusExportedObject.wrapJSObject(ZoomRegionIface, this); - this._dbusImpl.export(Gio.DBus.session, zoomerObjectPath); - } - - /** - * setMagFactor: - * @param {number} xMagFactor: The power to set the horizontal - * magnification factor to of the magnified view. A value of - * 1.0 means no magnification. A value of 2.0 doubles the size. - * @param {number} yMagFactor: The power to set the vertical - * magnification factor to of the magnified view. - */ - setMagFactor(xMagFactor, yMagFactor) { - this._zoomRegion.setMagFactor(xMagFactor, yMagFactor); - } - - /** - * getMagFactor: - * @returns {number[]}: [xMagFactor, yMagFactor], containing the horizontal - * and vertical magnification powers. A value of 1.0 means no - * magnification. A value of 2.0 means the contents are doubled - * in size, and so on. - */ - getMagFactor() { - return this._zoomRegion.getMagFactor(); - } - - /** - * setRoi: - * Sets the "region of interest" that the ZoomRegion is magnifying. - * @param {number[]} roi: [left, top, right, bottom], defining the - * region of the screen to magnify. - * The values are in screen (unmagnified) coordinate space. - */ - setRoi(roi) { - let roiObject = { x: roi[0], y: roi[1], width: roi[2] - roi[0], height: roi[3] - roi[1] }; - this._zoomRegion.setROI(roiObject); - } - - /** - * getRoi: - * Retrieves the "region of interest" -- the rectangular bounds of that part - * of the desktop that the magnified view is showing (x, y, width, height). - * The bounds are given in non-magnified coordinates. - * @returns {Array}: [left, top, right, bottom], representing the bounding - * rectangle of what is shown in the magnified view. - */ - getRoi() { - let roi = this._zoomRegion.getROI(); - roi[2] += roi[0]; - roi[3] += roi[1]; - return roi; - } - - /** - * Set the "region of interest" by centering the given screen coordinate - * within the zoom region. - * @param {number} x: The x-coord of the point to place at the - * center of the zoom region. - * @param {number} y: The y-coord. - * @returns {bool} Whether the shift was successful (for GS-mag, this - * is always true). - */ - shiftContentsTo(x, y) { - this._zoomRegion.scrollContentsTo(x, y); - return true; - } - - /** - * moveResize - * Sets the position and size of the ZoomRegion on screen. - * @param {number[]} viewPort: [left, top, right, bottom], defining - * the position and size on screen to place the zoom region. - */ - moveResize(viewPort) { - let viewRect = { x: viewPort[0], y: viewPort[1], width: viewPort[2] - viewPort[0], height: viewPort[3] - viewPort[1] }; - this._zoomRegion.setViewPort(viewRect); - } - - destroy() { - this._dbusImpl.unexport(); - } -}; diff --git a/src/main.c b/src/main.c index ceb50482b..8c59f9c09 100644 --- a/src/main.c +++ b/src/main.c @@ -27,7 +27,6 @@ extern GType gnome_shell_plugin_get_type (void); #define SHELL_DBUS_SERVICE "org.gnome.Shell" -#define MAGNIFIER_DBUS_SERVICE "org.gnome.Magnifier" #define WM_NAME "GNOME Shell" #define GNOME_WM_KEYBINDINGS "Mutter,GNOME Shell" @@ -74,35 +73,6 @@ shell_dbus_acquire_name (GDBusProxy *bus, g_variant_unref (request_name_variant); } -static void -shell_dbus_acquire_names (GDBusProxy *bus, - guint32 request_name_flags, - const gchar *name, - gboolean fatal, ...) G_GNUC_NULL_TERMINATED; - -static void -shell_dbus_acquire_names (GDBusProxy *bus, - guint32 request_name_flags, - const gchar *name, - gboolean fatal, ...) -{ - va_list al; - guint32 request_name_result; - va_start (al, fatal); - for (;;) - { - shell_dbus_acquire_name (bus, - request_name_flags, - &request_name_result, - name, fatal); - name = va_arg (al, gchar *); - if (!name) - break; - fatal = va_arg (al, gboolean); - } - va_end (al); -} - static void shell_dbus_init (gboolean replace) { @@ -149,17 +119,6 @@ shell_dbus_init (gboolean replace) exit (1); } - /* - * We always specify REPLACE_EXISTING to ensure we kill off - * the existing service if it was running. - */ - request_name_flags |= G_BUS_NAME_OWNER_FLAGS_REPLACE; - - shell_dbus_acquire_names (bus, - request_name_flags, - /* Also grab the org.gnome.Magnifier service. */ - MAGNIFIER_DBUS_SERVICE, FALSE, - NULL); g_object_unref (bus); g_object_unref (session); }