[mate-settings-daemon] 02/03: debian/patches: Add 0001_hidpi.patch. HiDPI configuration in XSettings.

Martin Wimpress flexiondotorg-guest at moszumanska.debian.org
Tue Feb 6 15:14:43 UTC 2018


This is an automated email from the git hooks/post-receive script.

flexiondotorg-guest pushed a commit to branch ubuntu/bionic
in repository mate-settings-daemon.

commit 8f16cf3fee070a3815f263e366888e47631f0ba1
Author: Martin Wimpress <martin.wimpress at ubuntu.com>
Date:   Tue Feb 6 14:47:17 2018 +0000

    debian/patches: Add 0001_hidpi.patch. HiDPI configuration in XSettings.
---
 debian/patches/0001_hidpi.patch | 754 ++++++++++++++++++++++++++++++++++++++++
 debian/patches/series           |   1 +
 2 files changed, 755 insertions(+)

diff --git a/debian/patches/0001_hidpi.patch b/debian/patches/0001_hidpi.patch
new file mode 100644
index 0000000..8e675fc
--- /dev/null
+++ b/debian/patches/0001_hidpi.patch
@@ -0,0 +1,754 @@
+Author: Victor Kareh <vkareh at vkareh.net>
+Description: Add HiDPI configuration in XSettings
+
+diff --git a/configure.ac b/configure.ac
+index 753a56f..2b84e0d 100644
+--- a/configure.ac
++++ b/configure.ac
+@@ -486,6 +486,7 @@ data/org.mate.SettingsDaemon.plugins.typing-break.gschema.xml
+ data/org.mate.SettingsDaemon.plugins.xrandr.gschema.xml
+ data/org.mate.SettingsDaemon.plugins.xrdb.gschema.xml
+ data/org.mate.SettingsDaemon.plugins.xsettings.gschema.xml
++data/org.mate.SettingsDaemon.plugins.gschema.xml
+ po/Makefile.in
+ ])
+ 
+diff --git a/data/Makefile.am b/data/Makefile.am
+index 8655e3f..34cf52e 100644
+--- a/data/Makefile.am
++++ b/data/Makefile.am
+@@ -22,6 +22,7 @@ msd_gschemas_in = \
+ 	org.mate.SettingsDaemon.plugins.xrandr.gschema.xml.in \
+ 	org.mate.SettingsDaemon.plugins.xrdb.gschema.xml.in \
+ 	org.mate.SettingsDaemon.plugins.xsettings.gschema.xml.in \
++	org.mate.SettingsDaemon.plugins.gschema.xml.in \
+ 	$(NULL)
+ 
+ @INTLTOOL_XML_NOMERGE_RULE@
+diff --git a/data/org.mate.SettingsDaemon.plugins.gschema.xml.in b/data/org.mate.SettingsDaemon.plugins.gschema.xml.in
+new file mode 100644
+index 0000000..d406525
+--- /dev/null
++++ b/data/org.mate.SettingsDaemon.plugins.gschema.xml.in
+@@ -0,0 +1,9 @@
++<schemalist>
++  <schema gettext-domain="@GETTEXT_PACKAGE@" id="org.mate.SettingsDaemon.plugins" path="/org/mate/settings-daemon/plugins/">
++    <key name="init-load-priority" type="i">
++      <default>2</default>
++      <summary>Load priority for Initialization phase</summary>
++      <description>Priority to use as the cut-off for loading plugins during the session initialization phase. Plugins that are this number or lower, will be loaded before mate-settings-daemon registers itself as an initialized application. This is useful for plugins that need the set environment variables, or change settings before the window manager, panel, or desktop has started loading. Values higher than this number will be deferred to be loaded asynchronously.</description>
++    </key>
++  </schema>
++</schemalist>
+diff --git a/mate-settings-daemon/main.c b/mate-settings-daemon/main.c
+index da87c36..b070361 100644
+--- a/mate-settings-daemon/main.c
++++ b/mate-settings-daemon/main.c
+@@ -519,13 +519,24 @@ main (int argc, char *argv[])
+                 goto out;
+         }
+ 
++        /* If we aren't started by dbus then load the plugins automatically during the
++         * Initialization phase. Otherwise, wait for an Awake etc. */
++        if (g_getenv ("DBUS_STARTER_BUS_TYPE") == NULL) {
++                error = NULL;
++                res = mate_settings_manager_start (manager, PLUGIN_LOAD_INIT, &error);
++                if (! res) {
++                        g_warning ("Unable to start: %s", error->message);
++                        g_error_free (error);
++                }
++        }
++
+         set_session_over_handler (bus, manager);
+ 
+-        /* If we aren't started by dbus then load the plugins
+-           automatically.  Otherwise, wait for an Awake etc. */
++        /* If we aren't started by dbus then load the plugins automatically after
++         * mate-settings-daemon has registered itself. Otherwise, wait for an Awake etc. */
+         if (g_getenv ("DBUS_STARTER_BUS_TYPE") == NULL) {
+                 error = NULL;
+-                res = mate_settings_manager_start (manager, &error);
++                res = mate_settings_manager_start (manager, PLUGIN_LOAD_DEFER, &error);
+                 if (! res) {
+                         g_warning ("Unable to start: %s", error->message);
+                         g_error_free (error);
+diff --git a/mate-settings-daemon/mate-settings-manager.c b/mate-settings-daemon/mate-settings-manager.c
+index b076951..4936c84 100644
+--- a/mate-settings-daemon/mate-settings-manager.c
++++ b/mate-settings-daemon/mate-settings-manager.c
+@@ -50,6 +50,8 @@ struct MateSettingsManagerPrivate
+ {
+         DBusGConnection            *connection;
+         GSList                     *plugins;
++        gint                        init_load_priority;
++        gint                        load_init_flag;
+ };
+ 
+ enum {
+@@ -80,15 +82,25 @@ mate_settings_manager_error_quark (void)
+ }
+ 
+ static void
+-maybe_activate_plugin (MateSettingsPluginInfo *info, gpointer user_data)
++maybe_activate_plugin (MateSettingsPluginInfo *info,
++                       MateSettingsManager    *manager)
+ {
+         if (mate_settings_plugin_info_get_enabled (info)) {
+-                gboolean res;
+-                res = mate_settings_plugin_info_activate (info);
+-                if (res) {
+-                        g_debug ("Plugin %s: active", mate_settings_plugin_info_get_location (info));
++                int plugin_priority;
++                plugin_priority = mate_settings_plugin_info_get_priority (info);
++
++                if (manager->priv->load_init_flag == PLUGIN_LOAD_ALL ||
++                   (manager->priv->load_init_flag == PLUGIN_LOAD_INIT && plugin_priority <= manager->priv->init_load_priority) ||
++                   (manager->priv->load_init_flag == PLUGIN_LOAD_DEFER && plugin_priority > manager->priv->init_load_priority)) {
++                        gboolean res;
++                        res = mate_settings_plugin_info_activate (info);
++                        if (res) {
++                                g_debug ("Plugin %s: active", mate_settings_plugin_info_get_location (info));
++                        } else {
++                                g_debug ("Plugin %s: activation failed", mate_settings_plugin_info_get_location (info));
++                        }
+                 } else {
+-                        g_debug ("Plugin %s: activation failed", mate_settings_plugin_info_get_location (info));
++                        g_debug ("Plugin %s: loading deferred or previously loaded", mate_settings_plugin_info_get_location (info));
+                 }
+         } else {
+                 g_debug ("Plugin %s: inactive", mate_settings_plugin_info_get_location (info));
+@@ -262,7 +274,7 @@ _load_all (MateSettingsManager *manager)
+         _load_dir (manager, MATE_SETTINGS_PLUGINDIR G_DIR_SEPARATOR_S);
+ 
+         manager->priv->plugins = g_slist_sort (manager->priv->plugins, (GCompareFunc) compare_priority);
+-        g_slist_foreach (manager->priv->plugins, (GFunc) maybe_activate_plugin, NULL);
++        g_slist_foreach (manager->priv->plugins, (GFunc) maybe_activate_plugin, manager);
+         mate_settings_profile_end (NULL);
+ }
+ 
+@@ -295,7 +307,7 @@ mate_settings_manager_awake (MateSettingsManager *manager,
+                               GError              **error)
+ {
+         g_debug ("Awake called");
+-        return mate_settings_manager_start (manager, error);
++        return mate_settings_manager_start (manager, PLUGIN_LOAD_ALL, error);
+ }
+ 
+ static gboolean
+@@ -319,7 +331,8 @@ register_manager (MateSettingsManager *manager)
+ 
+ gboolean
+ mate_settings_manager_start (MateSettingsManager *manager,
+-                              GError              **error)
++                              gint               load_init_flag,
++                              GError             **error)
+ {
+         gboolean ret;
+ 
+@@ -339,6 +352,7 @@ mate_settings_manager_start (MateSettingsManager *manager,
+                 goto out;
+         }
+ 
++        manager->priv->load_init_flag = load_init_flag;
+         _load_all (manager);
+ 
+         ret = TRUE;
+@@ -405,8 +419,16 @@ mate_settings_manager_class_init (MateSettingsManagerClass *klass)
+ static void
+ mate_settings_manager_init (MateSettingsManager *manager)
+ {
++        char      *schema;
++        GSettings *settings;
+ 
+         manager->priv = MATE_SETTINGS_MANAGER_GET_PRIVATE (manager);
++
++        schema = g_strdup_printf ("%s.plugins", DEFAULT_SETTINGS_PREFIX);
++        if (is_schema (schema)) {
++                settings = g_settings_new (schema);
++                manager->priv->init_load_priority = g_settings_get_int (settings, "init-load-priority");
++        }
+ }
+ 
+ static void
+diff --git a/mate-settings-daemon/mate-settings-manager.h b/mate-settings-daemon/mate-settings-manager.h
+index 3d2296f..6eaf360 100644
+--- a/mate-settings-daemon/mate-settings-manager.h
++++ b/mate-settings-daemon/mate-settings-manager.h
+@@ -57,6 +57,13 @@ typedef enum
+         MATE_SETTINGS_MANAGER_ERROR_GENERAL
+ } MateSettingsManagerError;
+ 
++enum
++{
++        PLUGIN_LOAD_ALL,
++        PLUGIN_LOAD_INIT,
++        PLUGIN_LOAD_DEFER
++};
++
+ #define MATE_SETTINGS_MANAGER_ERROR mate_settings_manager_error_quark ()
+ 
+ GQuark                 mate_settings_manager_error_quark         (void);
+@@ -65,7 +72,8 @@ GType                  mate_settings_manager_get_type   (void);
+ MateSettingsManager * mate_settings_manager_new        (void);
+ 
+ gboolean               mate_settings_manager_start      (MateSettingsManager *manager,
+-                                                          GError              **error);
++                                                          gint                load_init_flag,
++                                                          GError            **error);
+ void                   mate_settings_manager_stop       (MateSettingsManager *manager);
+ 
+ gboolean               mate_settings_manager_awake      (MateSettingsManager *manager,
+diff --git a/plugins/xsettings/Makefile.am b/plugins/xsettings/Makefile.am
+index c4d0520..c4b821f 100644
+--- a/plugins/xsettings/Makefile.am
++++ b/plugins/xsettings/Makefile.am
+@@ -15,6 +15,8 @@ libxsettings_la_SOURCES = 	\
+ 	xsettings-manager.c	\
+ 	fontconfig-monitor.h	\
+ 	fontconfig-monitor.c	\
++	wm-common.h	\
++	wm-common.c	\
+ 	$(NULL)
+ 
+ libxsettings_la_CPPFLAGS = \
+diff --git a/plugins/xsettings/msd-xsettings-manager.c b/plugins/xsettings/msd-xsettings-manager.c
+index 9105088..69683fb 100644
+--- a/plugins/xsettings/msd-xsettings-manager.c
++++ b/plugins/xsettings/msd-xsettings-manager.c
+@@ -43,6 +43,7 @@
+ #include "msd-xsettings-manager.h"
+ #include "xsettings-manager.h"
+ #include "fontconfig-monitor.h"
++#include "wm-common.h"
+ 
+ #define MATE_XSETTINGS_MANAGER_GET_PRIVATE(o) (G_TYPE_INSTANCE_GET_PRIVATE ((o), MATE_TYPE_XSETTINGS_MANAGER, MateXSettingsManagerPrivate))
+ 
+@@ -52,6 +53,7 @@
+ 
+ #define CURSOR_THEME_KEY      "cursor-theme"
+ #define CURSOR_SIZE_KEY       "cursor-size"
++#define SCALING_FACTOR_KEY    "window-scaling-factor"
+ 
+ #define FONT_RENDER_SCHEMA    "org.mate.font-rendering"
+ #define FONT_ANTIALIASING_KEY "antialiasing"
+@@ -73,6 +75,14 @@
+ #define DPI_LOW_REASONABLE_VALUE 50
+ #define DPI_HIGH_REASONABLE_VALUE 500
+ 
++/* The minimum resolution at which we turn on a window-scale of 2 */
++#define HIDPI_LIMIT (DPI_FALLBACK * 2)
++
++/* The minimum screen height at which we turn on a window-scale of 2;
++ * below this there just isn't enough vertical real estate for GNOME
++ * apps to work, and it's better to just be tiny */
++#define HIDPI_MIN_HEIGHT 1500
++
+ typedef struct _TranslationEntry TranslationEntry;
+ typedef void (* TranslationFunc) (MateXSettingsManager  *manager,
+                                   TranslationEntry      *trans,
+@@ -92,6 +102,7 @@ struct MateXSettingsManagerPrivate
+         GHashTable *gsettings;
+         GSettings *gsettings_font;
+         fontconfig_monitor_handle_t *fontconfig_handle;
++        gint window_scale;
+ };
+ 
+ #define MSD_XSETTINGS_ERROR msd_xsettings_error_quark ()
+@@ -213,6 +224,70 @@ static TranslationEntry translations [] = {
+         { SOUND_SCHEMA, "input-feedback-sounds",      "Net/EnableInputFeedbackSounds", translate_bool_int }
+ };
+ 
++/* Auto-detect the most appropriate scale factor for the primary monitor.
++ * A lot of this code is shamelessly copied and adapted from Linux Mint/Cinnamon.
++ */
++static int
++get_window_scale_auto ()
++{
++        GdkDisplay   *display;
++        GdkMonitor   *monitor;
++        GdkRectangle  rect;
++        int width_mm, height_mm;
++        int monitor_scale, window_scale;
++
++        display = gdk_display_get_default ();
++        monitor = gdk_display_get_primary_monitor (display);
++
++        /* Use current value as the default */
++        window_scale = 1;
++
++        gdk_monitor_get_geometry (monitor, &rect);
++        width_mm = gdk_monitor_get_width_mm (monitor);
++        height_mm = gdk_monitor_get_height_mm (monitor);
++        monitor_scale = gdk_monitor_get_scale_factor (monitor);
++
++        if (rect.height * monitor_scale < HIDPI_MIN_HEIGHT)
++                return 1;
++
++        /* Some monitors/TV encode the aspect ratio (16/9 or 16/10) instead of the physical size */
++        if ((width_mm == 160 && height_mm == 90) ||
++            (width_mm == 160 && height_mm == 100) ||
++            (width_mm == 16 && height_mm == 9) ||
++            (width_mm == 16 && height_mm == 10))
++                return 1;
++
++        if (width_mm > 0 && height_mm > 0) {
++                double dpi_x, dpi_y;
++
++                dpi_x = (double)rect.width * monitor_scale / (width_mm / 25.4);
++                dpi_y = (double)rect.height * monitor_scale / (height_mm / 25.4);
++                /* We don't completely trust these values so both must be high, and never pick
++                 * higher ratio than 2 automatically */
++                if (dpi_x > HIDPI_LIMIT && dpi_y > HIDPI_LIMIT)
++                        window_scale = 2;
++        }
++
++        return window_scale;
++}
++
++static int
++get_window_scale (MateXSettingsManager *manager)
++{
++        GSettings   *gsettings;
++        gint         scale;
++
++        /* Get scale factor from gsettings */
++        gsettings = g_hash_table_lookup (manager->priv->gsettings, INTERFACE_SCHEMA);
++        scale = g_settings_get_int (gsettings, SCALING_FACTOR_KEY);
++
++        /* Auto-detect */
++        if (scale == 0)
++                scale = get_window_scale_auto ();
++
++        return scale;
++}
++
+ static double
+ dpi_from_pixels_and_mm (int pixels,
+                         int mm)
+@@ -232,7 +307,6 @@ get_dpi_from_x_server (void)
+ {
+         GdkScreen *screen;
+         double     dpi;
+-        gint       scale;
+ 
+         screen = gdk_screen_get_default ();
+         if (screen != NULL) {
+@@ -255,21 +329,15 @@ get_dpi_from_x_server (void)
+                 dpi = DPI_FALLBACK;
+         }
+ 
+-
+-        scale = gdk_window_get_scale_factor (gdk_screen_get_root_window (screen));
+-        if (scale)
+-                dpi = dpi * scale;
+-
+         return dpi;
+ }
+ 
+ static double
+-get_dpi_from_gsettings_or_x_server (GSettings *gsettings)
++get_dpi_from_gsettings_or_x_server (GSettings *gsettings, gint scale)
+ {
+-        double value;
+         double dpi;
+ 
+-        value = g_settings_get_double (gsettings, FONT_DPI_KEY);
++        dpi = g_settings_get_double (gsettings, FONT_DPI_KEY);
+ 
+         /* If the user has ever set the DPI preference in GSettings, we use that.
+          * Otherwise, we see if the X server reports a reasonable DPI value:  some X
+@@ -277,11 +345,11 @@ get_dpi_from_gsettings_or_x_server (GSettings *gsettings)
+          * fonts which are unusable.
+          */
+ 
+-        if (value != 0) {
+-                dpi = value;
+-        } else {
++        if (dpi == 0)
+                 dpi = get_dpi_from_x_server ();
+-        }
++
++        dpi *= (double)scale;
++        dpi = CLAMP(dpi, DPI_LOW_REASONABLE_VALUE, DPI_HIGH_REASONABLE_VALUE);
+ 
+         return dpi;
+ }
+@@ -290,7 +358,9 @@ typedef struct
+ {
+         gboolean    antialias;
+         gboolean    hinting;
++        int         window_scale;
+         int         dpi;
++        int         scaled_dpi;
+         char       *cursor_theme;
+         int         cursor_size;
+         const char *rgba;
+@@ -307,7 +377,6 @@ xft_settings_get (MateXSettingsManager *manager,
+                   MateXftSettings *settings)
+ {
+         GSettings *mouse_gsettings;
+-        GdkScreen *screen;
+         char      *antialiasing;
+         char      *hinting;
+         char      *rgba_order;
+@@ -315,18 +384,19 @@ xft_settings_get (MateXSettingsManager *manager,
+         gint       scale;
+ 
+         mouse_gsettings = g_hash_table_lookup (manager->priv->gsettings, MOUSE_SCHEMA);
+-        screen = gdk_screen_get_default();
+ 
+         antialiasing = g_settings_get_string (manager->priv->gsettings_font, FONT_ANTIALIASING_KEY);
+         hinting = g_settings_get_string (manager->priv->gsettings_font, FONT_HINTING_KEY);
+         rgba_order = g_settings_get_string (manager->priv->gsettings_font, FONT_RGBA_ORDER_KEY);
+-        dpi = get_dpi_from_gsettings_or_x_server (manager->priv->gsettings_font);
+-        scale = gdk_window_get_scale_factor (gdk_screen_get_root_window (screen));
++        scale = get_window_scale (manager);
++        dpi = get_dpi_from_gsettings_or_x_server (manager->priv->gsettings_font, scale);
+ 
+         settings->antialias = TRUE;
+         settings->hinting = TRUE;
+         settings->hintstyle = "hintslight";
+-        settings->dpi = dpi * 1024; /* Xft wants 1/1024ths of an inch */
++        settings->window_scale = scale;
++        settings->dpi = dpi / scale * 1024; /* Xft wants 1/1024ths of an inch */
++        settings->scaled_dpi = dpi * 1024;
+         settings->cursor_theme = g_settings_get_string (mouse_gsettings, CURSOR_THEME_KEY);
+         settings->cursor_size = scale * g_settings_get_int (mouse_gsettings, CURSOR_SIZE_KEY);
+         settings->rgba = "rgb";
+@@ -392,6 +462,121 @@ xft_settings_get (MateXSettingsManager *manager,
+         g_free (antialiasing);
+ }
+ 
++/* Set environment variable.
++ * This should only work during the initialization phase. */
++static gboolean
++update_user_env_variable (const gchar  *variable,
++                          const gchar  *value,
++                          GError      **error)
++{
++        GDBusConnection *connection;
++        gboolean         environment_updated;
++        GVariant        *reply;
++        GError          *bus_error = NULL;
++
++        g_setenv (variable, value, TRUE);
++
++        environment_updated = FALSE;
++        connection = g_bus_get_sync (G_BUS_TYPE_SESSION, NULL, error);
++
++        if (connection == NULL) {
++                return FALSE;
++        }
++
++        reply = g_dbus_connection_call_sync (connection,
++                        "org.gnome.SessionManager",
++                        "/org/gnome/SessionManager",
++                        "org.gnome.SessionManager",
++                        "Setenv",
++                        g_variant_new ("(ss)", variable, value),
++                        NULL,
++                        G_DBUS_CALL_FLAGS_NONE,
++                        -1, NULL, &bus_error);
++
++        if (bus_error != NULL) {
++                g_propagate_error (error, bus_error);
++        } else {
++                environment_updated = TRUE;
++                g_variant_unref (reply);
++        }
++
++        g_clear_object (&connection);
++
++        return environment_updated;
++}
++
++static gboolean
++delayed_toggle_bg_draw (gboolean value)
++{
++        GSettings *settings;
++        settings = g_settings_new ("org.mate.background");
++        g_settings_set_boolean (settings, "show-desktop-icons", value);
++        return FALSE;
++}
++
++static void
++scale_change_workarounds (MateXSettingsManager *manager, int new_scale)
++{
++        if (manager->priv->window_scale == new_scale)
++                return;
++
++        GError *error = NULL;
++
++        /* This is only useful during the Initialization phase, so we guard against
++         * unnecessarily attempting to set it later. */
++        if (!manager->priv->window_scale) {
++                /* Set env variables to properly scale QT applications */
++                if (!update_user_env_variable ("QT_AUTO_SCREEN_SCALE_FACTOR", "0", &error)) {
++                        g_warning ("There was a problem when setting QT_AUTO_SCREEN_SCALE_FACTOR=0: %s", error->message);
++                        g_clear_error (&error);
++                }
++                if (!update_user_env_variable ("QT_SCALE_FACTOR", new_scale == 2 ? "2" : "1", &error)) {
++                        g_warning ("There was a problem when setting QT_SCALE_FACTOR=%d: %s", new_scale, error->message);
++                        g_clear_error (&error);
++                }
++        } else {
++                /* Restart marco */
++                /* FIXME: The ideal scenario would be for marco to respect window scaling and thus
++                 * resize itself. Currently this is not happening, so msd restarts it when the window
++                 * scaling factor changes so that it's visually correct. */
++                wm_common_update_window();
++                gchar *wm = wm_common_get_current_window_manager ();
++                if (g_strcmp0 (wm, WM_COMMON_MARCO) == 0) {
++                        const gchar * const marco[] = {"marco", "--replace", NULL};
++                        if (!g_spawn_async (NULL, marco, NULL, G_SPAWN_SEARCH_PATH, NULL, NULL, NULL, &error)) {
++                                g_warning ("There was a problem restarting marco: %s", error->message);
++                                g_clear_error (&error);
++                        }
++                }
++                g_free (wm);
++
++                /* Restart mate-panel */
++                /* FIXME: The ideal scenario would be for mate-panel to respect window scaling and thus
++                 * resize itself. Currently this is not happening, so msd restarts it when the window
++                 * scaling factor changes so that it's visually correct. */
++                const gchar * const mate_panel[] = {"mate-panel", "--replace", NULL};
++                if (!g_spawn_async (NULL, mate_panel, NULL, G_SPAWN_SEARCH_PATH, NULL, NULL, NULL, &error)) {
++                        g_warning ("There was a problem restarting mate-panel: %s", error->message);
++                        g_clear_error (&error);
++                }
++
++                /* Toggle icons on desktop to fix size */
++                /* FIXME: The ideal scenario would be for caja to respect window scaling and thus
++                 * resize itself. Currently this is not happening, so msd restarts it when the window
++                 * scaling factor changes so that it's visually correct. */
++                GSettings *desktop_settings;
++                desktop_settings = g_settings_new ("org.mate.background");
++                if (g_settings_get_boolean (desktop_settings, "show-desktop-icons")) {
++                        /* Delay the toggle to allow enough time for the desktop to redraw */
++                        g_timeout_add_seconds (1, (GSourceFunc) delayed_toggle_bg_draw, (gpointer) FALSE);
++                        g_timeout_add_seconds (2, (GSourceFunc) delayed_toggle_bg_draw, (gpointer) TRUE);
++                }
++        }
++
++        /* Store new scale value */
++        manager->priv->window_scale = new_scale;
++}
++
+ static void
+ xft_settings_set_xsettings (MateXSettingsManager *manager,
+                             MateXftSettings      *settings)
+@@ -404,7 +589,9 @@ xft_settings_set_xsettings (MateXSettingsManager *manager,
+                 xsettings_manager_set_int (manager->priv->managers [i], "Xft/Antialias", settings->antialias);
+                 xsettings_manager_set_int (manager->priv->managers [i], "Xft/Hinting", settings->hinting);
+                 xsettings_manager_set_string (manager->priv->managers [i], "Xft/HintStyle", settings->hintstyle);
+-                xsettings_manager_set_int (manager->priv->managers [i], "Xft/DPI", settings->dpi);
++                xsettings_manager_set_int (manager->priv->managers [i], "Gdk/WindowScalingFactor", settings->window_scale);
++                xsettings_manager_set_int (manager->priv->managers [i], "Gdk/UnscaledDPI", settings->dpi);
++                xsettings_manager_set_int (manager->priv->managers [i], "Xft/DPI", settings->scaled_dpi);
+                 xsettings_manager_set_string (manager->priv->managers [i], "Xft/RGBA", settings->rgba);
+                 xsettings_manager_set_string (manager->priv->managers [i], "Xft/lcdfilter",
+                                               g_str_equal (settings->rgba, "rgb") ? "lcddefault" : "none");
+@@ -412,6 +599,8 @@ xft_settings_set_xsettings (MateXSettingsManager *manager,
+                 xsettings_manager_set_string (manager->priv->managers [i], "Gtk/CursorThemeName", settings->cursor_theme);
+         }
+         mate_settings_profile_end (NULL);
++
++        scale_change_workarounds (manager, settings->window_scale);
+ }
+ 
+ static void
+@@ -507,6 +696,23 @@ update_xft_settings (MateXSettingsManager *manager)
+         mate_settings_profile_end (NULL);
+ }
+ 
++static void
++recalculate_scale_callback (GdkScreen            *screen,
++                            MateXSettingsManager *manager)
++{
++        int i;
++        int new_scale = get_window_scale (manager);
++
++        if (manager->priv->window_scale == new_scale)
++                return;
++
++        update_xft_settings (manager);
++
++        for (i = 0; manager->priv->managers [i]; i++) {
++                xsettings_manager_notify (manager->priv->managers [i]);
++        }
++}
++
+ static void
+ xft_callback (GSettings            *gsettings,
+               const gchar          *key,
+@@ -609,6 +815,7 @@ xsettings_callback (GSettings             *gsettings,
+         GVariant         *value;
+ 
+         if (g_str_equal (key, CURSOR_THEME_KEY) ||
++            g_str_equal (key, SCALING_FACTOR_KEY) ||
+             g_str_equal (key, CURSOR_SIZE_KEY)) {
+                 xft_callback (NULL, key, manager);
+                 return;
+@@ -692,6 +899,7 @@ mate_xsettings_manager_start (MateXSettingsManager *manager,
+ {
+         guint        i;
+         GList       *list, *l;
++        GdkScreen   *screen;
+ 
+         g_debug ("Starting xsettings manager");
+         mate_settings_profile_start (NULL);
+@@ -718,6 +926,7 @@ mate_xsettings_manager_start (MateXSettingsManager *manager,
+                 g_signal_connect_object (G_OBJECT (l->data), "changed",
+                 			 G_CALLBACK (xsettings_callback), manager, 0);
+         }
++
+         g_list_free (list);
+ 
+         for (i = 0; i < G_N_ELEMENTS (translations); i++) {
+@@ -738,6 +947,11 @@ mate_xsettings_manager_start (MateXSettingsManager *manager,
+                 g_variant_unref (val);
+         }
+ 
++        /* Detect changes in screen resolution */
++        screen = gdk_screen_get_default();
++        g_signal_connect(screen, "size-changed", G_CALLBACK (recalculate_scale_callback), manager);
++        g_signal_connect(screen, "monitors-changed", G_CALLBACK (recalculate_scale_callback), manager);
++
+         manager->priv->gsettings_font = g_settings_new (FONT_RENDER_SCHEMA);
+         g_signal_connect (manager->priv->gsettings_font, "changed", G_CALLBACK (xft_callback), manager);
+         update_xft_settings (manager);
+diff --git a/plugins/xsettings/wm-common.c b/plugins/xsettings/wm-common.c
+new file mode 100644
+index 0000000..ccb9629
+--- /dev/null
++++ b/plugins/xsettings/wm-common.c
+@@ -0,0 +1,108 @@
++#include <X11/Xatom.h>
++#include <gdk/gdkx.h>
++#include <gdk/gdk.h>
++#include <string.h>
++#include <glib.h>
++#include <glib-object.h>
++#include "wm-common.h"
++
++/* Our WM Window */
++static Window wm_window = None;
++
++static char *
++wm_common_get_window_manager_property (Atom atom)
++{
++  Atom utf8_string, type;
++  int result;
++  char *retval;
++  int format;
++  gulong nitems;
++  gulong bytes_after;
++  gchar *val;
++
++  if (wm_window == None)
++    return NULL;
++
++  utf8_string = gdk_x11_get_xatom_by_name ("UTF8_STRING");
++
++  gdk_error_trap_push ();
++
++  val = NULL;
++  result = XGetWindowProperty (GDK_DISPLAY_XDISPLAY(gdk_display_get_default()),
++		  	       wm_window,
++			       atom,
++			       0, G_MAXLONG,
++			       False, utf8_string,
++			       &type, &format, &nitems,
++			       &bytes_after, (guchar **) &val);
++
++  if (gdk_error_trap_pop () || result != Success ||
++      type != utf8_string || format != 8 || nitems == 0 ||
++      !g_utf8_validate (val, nitems, NULL))
++    {
++      retval = NULL;
++    }
++  else
++    {
++      retval = g_strndup (val, nitems);
++    }
++
++  if (val)
++    XFree (val);
++
++  return retval;
++}
++
++char*
++wm_common_get_current_window_manager (void)
++{
++  Atom atom = gdk_x11_get_xatom_by_name ("_NET_WM_NAME");
++  char *result;
++
++  result = wm_common_get_window_manager_property (atom);
++  if (result)
++    return result;
++  else
++    return g_strdup (WM_COMMON_UNKNOWN);
++}
++
++static void
++update_wm_window (void)
++{
++  Window *xwindow;
++  Atom type;
++  gint format;
++  gulong nitems;
++  gulong bytes_after;
++
++  XGetWindowProperty (GDK_DISPLAY_XDISPLAY(gdk_display_get_default()), GDK_ROOT_WINDOW (),
++		      gdk_x11_get_xatom_by_name ("_NET_SUPPORTING_WM_CHECK"),
++		      0, G_MAXLONG, False, XA_WINDOW, &type, &format,
++		      &nitems, &bytes_after, (guchar **) &xwindow);
++
++  if (type != XA_WINDOW)
++    {
++      wm_window = None;
++     return;
++    }
++
++  gdk_error_trap_push ();
++  XSelectInput (GDK_DISPLAY_XDISPLAY(gdk_display_get_default()), *xwindow, StructureNotifyMask | PropertyChangeMask);
++  XSync (GDK_DISPLAY_XDISPLAY(gdk_display_get_default()), False);
++
++  if (gdk_error_trap_pop ())
++    {
++       XFree (xwindow);
++       wm_window = None;
++       return;
++    }
++
++    wm_window = *xwindow;
++    XFree (xwindow);
++}
++
++void
++wm_common_update_window ()
++{
++  update_wm_window();
++}
+diff --git a/plugins/xsettings/wm-common.h b/plugins/xsettings/wm-common.h
+new file mode 100644
+index 0000000..379adbf
+--- /dev/null
++++ b/plugins/xsettings/wm-common.h
+@@ -0,0 +1,15 @@
++#ifndef WM_COMMON_H
++#define WM_COMMON_H
++
++#define WM_COMMON_MARCO       "Metacity (Marco)"
++#define WM_COMMON_SAWFISH     "Sawfish"
++#define WM_COMMON_METACITY    "Metacity"
++#define WM_COMMON_COMPIZ      "Compiz"
++#define WM_COMMON_COMPIZ_OLD  "compiz"
++#define WM_COMMON_UNKNOWN     "Unknown"
++
++gchar *wm_common_get_current_window_manager (void);
++void   wm_common_update_window (void);
++
++#endif /* WM_COMMON_H */
++
diff --git a/debian/patches/series b/debian/patches/series
index 8f7d3a1..441b7de 100644
--- a/debian/patches/series
+++ b/debian/patches/series
@@ -1 +1,2 @@
 0000_hidpi.patch
+0001_hidpi.patch

-- 
Alioth's /usr/local/bin/git-commit-notice on /srv/git.debian.org/git/pkg-mate/mate-settings-daemon.git



More information about the pkg-mate-commits mailing list