From a7325d2b89947179fd220fef699e89ca8ae7fa2e Mon Sep 17 00:00:00 2001 From: Soren Sandmann Pedersen Date: Tue, 12 Feb 2008 19:57:10 +0000 Subject: [PATCH] Add randr 12 patch --- add-randr-12.patch | 309 +++++++++++++++++++++++++++++++++++++ gnome-settings-daemon.spec | 12 +- 2 files changed, 319 insertions(+), 2 deletions(-) create mode 100644 add-randr-12.patch diff --git a/add-randr-12.patch b/add-randr-12.patch new file mode 100644 index 0000000..9f2086d --- /dev/null +++ b/add-randr-12.patch @@ -0,0 +1,309 @@ +diff -up gnome-settings-daemon-2.21.91/plugins/xrandr/gsd-xrandr-manager.c.add-randr-12 gnome-settings-daemon-2.21.91/plugins/xrandr/gsd-xrandr-manager.c +--- gnome-settings-daemon-2.21.91/plugins/xrandr/gsd-xrandr-manager.c.add-randr-12 2007-12-24 06:18:48.000000000 -0500 ++++ gnome-settings-daemon-2.21.91/plugins/xrandr/gsd-xrandr-manager.c 2008-02-12 14:42:57.000000000 -0500 +@@ -36,6 +36,10 @@ + #include + #include + ++#define I_KNOW_THIS_IS_UNSTABLE_AND_ONLY_IN_FEDORA ++#include ++#include ++ + #ifdef HAVE_RANDR + #include + #endif +@@ -61,258 +65,60 @@ G_DEFINE_TYPE (GsdXrandrManager, gsd_xra + + static gpointer manager_object = NULL; + +-#ifdef HAVE_RANDR +-static int +-get_rotation (GConfClient *client, +- char *display, +- int screen) +-{ +- char *key; +- int val; +- GError *error; +- +- key = g_strdup_printf ("%s/%d/rotation", display, screen); +- error = NULL; +- val = gconf_client_get_int (client, key, &error); +- g_free (key); +- +- if (error == NULL) { +- return val; +- } +- +- g_error_free (error); +- +- return 0; +-} +- +-static int +-get_resolution (GConfClient *client, +- int screen, +- char *keys[], +- int *width, +- int *height) +-{ +- int i; +- char *key; +- char *val; +- int w; +- int h; +- +- val = NULL; +- for (i = 0; keys[i] != NULL; i++) { +- key = g_strdup_printf ("%s/%d/resolution", keys[i], screen); +- val = gconf_client_get_string (client, key, NULL); +- g_free (key); +- +- if (val != NULL) { +- break; +- } +- } +- +- if (val == NULL) { +- return -1; +- } +- +- if (sscanf (val, "%dx%d", &w, &h) != 2) { +- g_free (val); +- return -1; +- } +- +- g_free (val); +- +- *width = w; +- *height = h; +- +- return i; ++static GdkAtom ++gnome_randr_atom (void) ++{ ++ return gdk_atom_intern ("_GNOME_RANDR_ATOM", FALSE); + } + +-static int +-get_rate (GConfClient *client, +- char *display, +- int screen) ++static Atom ++gnome_randr_xatom (void) + { +- char *key; +- int val; +- GError *error; +- +- key = g_strdup_printf ("%s/%d/rate", display, screen); +- error = NULL; +- val = gconf_client_get_int (client, key, &error); +- g_free (key); +- +- if (error == NULL) { +- return val; +- } +- +- g_error_free (error); +- +- return 0; ++ return gdk_x11_atom_to_xatom (gnome_randr_atom()); + } + +-static int +-find_closest_size (XRRScreenSize *sizes, +- int nsizes, +- int width, +- int height) +-{ +- int closest; +- int closest_width; +- int closest_height; +- int i; +- +- closest = 0; +- closest_width = sizes[0].width; +- closest_height = sizes[0].height; +- for (i = 1; i < nsizes; i++) { +- if (ABS (sizes[i].width - width) < ABS (closest_width - width) || +- (sizes[i].width == closest_width && +- ABS (sizes[i].height - height) < ABS (closest_height - height))) { +- closest = i; +- closest_width = sizes[i].width; +- closest_height = sizes[i].height; +- } ++static GdkFilterReturn ++on_client_message (GdkXEvent *xevent, ++ GdkEvent *event, ++ gpointer data) ++{ ++ RWScreen *screen = data; ++ XEvent *ev = (XEvent *)xevent; ++ ++ if (ev->type == ClientMessage && ++ ev->xclient.message_type == gnome_randr_xatom()) { ++ ++ configuration_apply_stored (screen); ++ ++ return GDK_FILTER_REMOVE; + } +- +- return closest; ++ ++ /* Pass the event on to GTK+ */ ++ return GDK_FILTER_CONTINUE; + } +-#endif /* HAVE_RANDR */ + + static void +-apply_settings (GsdXrandrManager *manager) ++on_randr_event (RWScreen *screen, gpointer data) + { +-#ifdef HAVE_RANDR +- GdkDisplay *display; +- Display *xdisplay; +- int major; +- int minor; +- int event_base; +- int error_base; +- GConfClient *client; +- int n_screens; +- GdkScreen *screen; +- GdkWindow *root_window; +- int width; +- int height; +- int rate; +- int rotation; +-#ifdef HOST_NAME_MAX +- char hostname[HOST_NAME_MAX + 1]; +-#else +- char hostname[256]; +-#endif +- char *specific_path; +- char *keys[3]; +- int i; +- int residx; +- +- display = gdk_display_get_default (); +- xdisplay = gdk_x11_display_get_xdisplay (display); +- +- /* Check if XRandR is supported on the display */ +- if (!XRRQueryExtension (xdisplay, &event_base, &error_base) +- || XRRQueryVersion (xdisplay, &major, &minor) == 0) { +- return; +- } +- +- if (major != 1 || minor < 1) { +- g_message ("Display has unsupported version of XRandR (%d.%d), not setting resolution.", major, minor); +- return; +- } +- +- client = gconf_client_get_default (); +- +- i = 0; +- specific_path = NULL; +- if (gethostname (hostname, sizeof (hostname)) == 0) { +- specific_path = g_strconcat ("/desktop/gnome/screen/", hostname, NULL); +- keys[i++] = specific_path; +- } +- keys[i++] = "/desktop/gnome/screen/default"; +- keys[i++] = NULL; +- +- n_screens = gdk_display_get_n_screens (display); +- for (i = 0; i < n_screens; i++) { +- screen = gdk_display_get_screen (display, i); +- root_window = gdk_screen_get_root_window (screen); +- residx = get_resolution (client, i, keys, &width, &height); +- +- if (residx != -1) { +- XRRScreenSize *sizes; +- int nsizes; +- int j; +- int closest; +- short *rates; +- int nrates; +- int status; +- int current_size; +- short current_rate; +- XRRScreenConfiguration *config; +- Rotation current_rotation; +- +- config = XRRGetScreenInfo (xdisplay, gdk_x11_drawable_get_xid (GDK_DRAWABLE (root_window))); +- +- rate = get_rate (client, keys[residx], i); +- +- sizes = XRRConfigSizes (config, &nsizes); +- closest = find_closest_size (sizes, nsizes, width, height); +- +- rates = XRRConfigRates (config, closest, &nrates); +- for (j = 0; j < nrates; j++) { +- if (rates[j] == rate) +- break; +- } +- +- /* Rate not supported, let X pick */ +- if (j == nrates) +- rate = 0; +- +- rotation = get_rotation (client, keys[residx], i); +- if (rotation == 0) +- rotation = RR_Rotate_0; +- +- current_size = XRRConfigCurrentConfiguration (config, ¤t_rotation); +- current_rate = XRRConfigCurrentRate (config); +- +- if (closest != current_size || +- rate != current_rate || +- rotation != current_rotation) { +- status = XRRSetScreenConfigAndRate (xdisplay, +- config, +- gdk_x11_drawable_get_xid (GDK_DRAWABLE (root_window)), +- closest, +- (Rotation) rotation, +- rate, +- GDK_CURRENT_TIME); +- } +- +- XRRFreeScreenConfigInfo (config); +- } +- } +- +- g_free (specific_path); +- +- /* We need to make sure we process the screen resize event. */ +- gdk_display_sync (display); +- +- while (gtk_events_pending ()) { +- gtk_main_iteration (); +- } +- +- if (client != NULL) { +- g_object_unref (client); +- } +- +-#endif /* HAVE_RANDR */ ++ /* FIXME: Set up any new screens here */ + } + + gboolean + gsd_xrandr_manager_start (GsdXrandrManager *manager, + GError **error) + { ++ RWScreen *rw_screen; ++ + g_debug ("Starting xrandr manager"); ++ ++ rw_screen = rw_screen_new (gdk_screen_get_default(), on_randr_event, NULL); + +- apply_settings (manager); +- ++ configuration_apply_stored (rw_screen); ++ ++ gdk_add_client_message_filter (gnome_randr_atom(), ++ on_client_message, ++ rw_screen); ++ + return TRUE; + } + diff --git a/gnome-settings-daemon.spec b/gnome-settings-daemon.spec index 124ffdb..59e25c0 100644 --- a/gnome-settings-daemon.spec +++ b/gnome-settings-daemon.spec @@ -1,6 +1,6 @@ Name: gnome-settings-daemon Version: 2.21.91 -Release: 2%{?dist} +Release: 3%{?dist} Summary: The daemon sharing settings from GNOME to GTK+/KDE applications Group: System Environment/Daemons @@ -17,7 +17,7 @@ BuildRequires: dbus-glib-devel BuildRequires: GConf2-devel BuildRequires: gtk2-devel BuildRequires: gnome-vfs2-devel -BuildRequires: gnome-desktop-devel +BuildRequires: gnome-desktop-devel >= 2.21.91 BuildRequires: libglade2-devel BuildRequires: libgnomeui-devel BuildRequires: libgnome-devel @@ -29,6 +29,8 @@ BuildRequires: libgnomekbd-devel BuildRequires: gettext BuildRequires: perl(XML::Parser) +Patch1: add-randr-12.patch + %description A daemon to share settings from GNOME to other applications. It also handles global keybindings, as well as a number of desktop-wide settings. @@ -47,6 +49,8 @@ developing applications that use %{name}. %prep %setup -q +%patch1 -p1 -b .add-randr-12 + %build %configure --enable-static=no make %{?_smp_mflags} @@ -120,6 +124,10 @@ fi %{_libdir}/pkgconfig/gnome-settings-daemon.pc %changelog +* Tue Feb 12 2008 Soren Sandmann - 2.21.91-3 +- Add patch to make the xrandr plugin listen for client messages from + the control panel and reread the configuration file. + * Mon Feb 11 2008 Matthias Clasen - 2.21.91-2 - Remove obsolete control-center translations