previous patch breaks the build, just revert for now, bug 316142.
2005-09-14 Ray Strode <rstrode@redhat.com> * gnome-settings-daemon/gnome-settings-mouse.c: previous patch breaks the build, just revert for now, bug 316142.
This commit is contained in:
parent
428bfe0ffd
commit
0d86f01422
2 changed files with 26 additions and 147 deletions
|
@ -1,3 +1,8 @@
|
||||||
|
2005-09-14 Ray Strode <rstrode@redhat.com>
|
||||||
|
|
||||||
|
* gnome-settings-mouse.c: previous patch breaks the build,
|
||||||
|
just revert for now, bug 316142.
|
||||||
|
|
||||||
2005-09-12 Ray Strode <rstrode@redhat.com>
|
2005-09-12 Ray Strode <rstrode@redhat.com>
|
||||||
|
|
||||||
Remap buttons on auxillary mice for left-handed
|
Remap buttons on auxillary mice for left-handed
|
||||||
|
|
|
@ -1,5 +1,3 @@
|
||||||
#include <config.h>
|
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
|
|
||||||
|
@ -8,167 +6,43 @@
|
||||||
#include <gdk/gdkkeysyms.h>
|
#include <gdk/gdkkeysyms.h>
|
||||||
#include <X11/keysym.h>
|
#include <X11/keysym.h>
|
||||||
|
|
||||||
#ifdef HAVE_X11_EXTENSIONS_XINPUT_H
|
|
||||||
#include <X11/extensions/XInput.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <gconf/gconf.h>
|
#include <gconf/gconf.h>
|
||||||
|
|
||||||
#include "gnome-settings-locate-pointer.h"
|
#include "gnome-settings-locate-pointer.h"
|
||||||
#include "gnome-settings-daemon.h"
|
#include "gnome-settings-daemon.h"
|
||||||
|
|
||||||
#ifdef HAVE_X11_EXTENSIONS_XINPUT_H
|
#define DEFAULT_PTR_MAP_SIZE 128
|
||||||
static gboolean
|
|
||||||
supports_xinput_devices (void)
|
|
||||||
{
|
|
||||||
gint op_code, event, error;
|
|
||||||
|
|
||||||
return XQueryExtension (GDK_DISPLAY (), "XInputExtension",
|
|
||||||
&op_code, &event, &error);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static void
|
|
||||||
configure_button_layout (guchar *buttons,
|
|
||||||
gint n_buttons,
|
|
||||||
gboolean left_handed)
|
|
||||||
{
|
|
||||||
const gint left_button = 0;
|
|
||||||
gint right_button;
|
|
||||||
|
|
||||||
/* if the button is higher than 2 (3rd button) then it's
|
|
||||||
* probably one direction of a scroll wheel or something else
|
|
||||||
* uninteresting
|
|
||||||
*/
|
|
||||||
right_button = MIN (n_buttons - 1, 2);
|
|
||||||
|
|
||||||
if (left_handed)
|
|
||||||
{
|
|
||||||
buttons[left_button] = right_button + 1;
|
|
||||||
buttons[right_button] = left_button + 1;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
buttons[left_button] = left_button + 1;
|
|
||||||
buttons[right_button] = right_button + 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef HAVE_X11_EXTENSIONS_XINPUT_H
|
|
||||||
static gboolean
|
|
||||||
xinput_device_has_buttons (XDeviceInfo *device_info)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
XAnyClassInfo *class_info;
|
|
||||||
|
|
||||||
class_info = device_info->inputclassinfo;
|
|
||||||
for (i = 0; i < device_info->num_classes; i++)
|
|
||||||
{
|
|
||||||
if (class_info->class == ButtonClass)
|
|
||||||
{
|
|
||||||
XButtonInfo *button_info;
|
|
||||||
|
|
||||||
button_info = (XButtonInfo *) class_info;
|
|
||||||
if (button_info->num_buttons > 0)
|
|
||||||
return TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
class_info = (XAnyClassInfo *) (((guchar *) class_info) +
|
|
||||||
class_info->length);
|
|
||||||
}
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
set_xinput_devices_left_handed (gboolean left_handed)
|
|
||||||
{
|
|
||||||
XDeviceInfo *device_info;
|
|
||||||
gint n_devices;
|
|
||||||
guchar *buttons;
|
|
||||||
gsize buttons_capacity = 16;
|
|
||||||
gint n_buttons;
|
|
||||||
gint i;
|
|
||||||
|
|
||||||
device_info = XListInputDevices (GDK_DISPLAY (), &n_devices);
|
|
||||||
|
|
||||||
if (n_devices > 0)
|
|
||||||
buttons = g_new (guchar, buttons_capacity);
|
|
||||||
else
|
|
||||||
buttons = NULL;
|
|
||||||
|
|
||||||
for (i = 0; i < n_devices; i++)
|
|
||||||
{
|
|
||||||
XDevice *device = NULL;
|
|
||||||
|
|
||||||
if ((device_info[i].use != IsXExtensionDevice) ||
|
|
||||||
(!xinput_device_has_buttons (&device_info[i])))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
gdk_error_trap_push ();
|
|
||||||
|
|
||||||
device = XOpenDevice (GDK_DISPLAY (), device_info[i].id);
|
|
||||||
|
|
||||||
if ((gdk_error_trap_pop () != 0) ||
|
|
||||||
(device == NULL))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
n_buttons = XGetDeviceButtonMapping (GDK_DISPLAY (), device,
|
|
||||||
buttons,
|
|
||||||
buttons_capacity);
|
|
||||||
|
|
||||||
while (n_buttons > buttons_capacity)
|
|
||||||
{
|
|
||||||
buttons_capacity = n_buttons;
|
|
||||||
buttons = (guchar *) g_realloc (buttons,
|
|
||||||
buttons_capacity * sizeof (guchar));
|
|
||||||
|
|
||||||
n_buttons = XGetDeviceButtonMapping (GDK_DISPLAY (), device,
|
|
||||||
buttons,
|
|
||||||
buttons_capacity);
|
|
||||||
}
|
|
||||||
|
|
||||||
configure_button_layout (buttons, n_buttons, left_handed);
|
|
||||||
|
|
||||||
XSetDeviceButtonMapping (GDK_DISPLAY (), device, buttons, n_buttons);
|
|
||||||
XCloseDevice (GDK_DISPLAY (), device);
|
|
||||||
}
|
|
||||||
g_free (buttons);
|
|
||||||
|
|
||||||
if (device_info != NULL)
|
|
||||||
XFreeDeviceList (device_info);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
set_left_handed (gboolean left_handed)
|
set_left_handed (gboolean left_handed)
|
||||||
{
|
{
|
||||||
guchar *buttons ;
|
unsigned char *buttons;
|
||||||
gsize buttons_capacity = 16;
|
gint n_buttons, i;
|
||||||
gint n_buttons;
|
gint idx_1 = 0, idx_3 = 1;
|
||||||
|
|
||||||
#ifdef HAVE_X11_EXTENSIONS_XINPUT_H
|
buttons = g_alloca (DEFAULT_PTR_MAP_SIZE);
|
||||||
if (supports_xinput_devices ())
|
n_buttons = XGetPointerMapping (GDK_DISPLAY (), buttons, DEFAULT_PTR_MAP_SIZE);
|
||||||
set_xinput_devices_left_handed (left_handed);
|
if (n_buttons > DEFAULT_PTR_MAP_SIZE) {
|
||||||
#endif
|
buttons = g_alloca (n_buttons);
|
||||||
|
n_buttons = XGetPointerMapping (GDK_DISPLAY (), buttons, n_buttons);
|
||||||
|
}
|
||||||
|
|
||||||
buttons = g_new (guchar, buttons_capacity);
|
for (i = 0; i < n_buttons; i++)
|
||||||
n_buttons = XGetPointerMapping (GDK_DISPLAY (), buttons,
|
|
||||||
(gint) buttons_capacity);
|
|
||||||
while (n_buttons > buttons_capacity)
|
|
||||||
{
|
{
|
||||||
buttons_capacity = n_buttons;
|
if (buttons[i] == 1)
|
||||||
buttons = (guchar *) g_realloc (buttons,
|
idx_1 = i;
|
||||||
buttons_capacity * sizeof (guchar));
|
else if (buttons[i] == ((n_buttons < 3) ? 2 : 3))
|
||||||
|
idx_3 = i;
|
||||||
n_buttons = XGetPointerMapping (GDK_DISPLAY (), buttons,
|
|
||||||
(gint) buttons_capacity);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
configure_button_layout (buttons, n_buttons, left_handed);
|
if ((left_handed && idx_1 < idx_3) ||
|
||||||
|
(!left_handed && idx_1 > idx_3))
|
||||||
|
{
|
||||||
|
buttons[idx_1] = ((n_buttons < 3) ? 2 : 3);
|
||||||
|
buttons[idx_3] = 1;
|
||||||
|
}
|
||||||
|
|
||||||
XSetPointerMapping (GDK_DISPLAY (), buttons, n_buttons);
|
XSetPointerMapping (GDK_DISPLAY (), buttons, n_buttons);
|
||||||
|
|
||||||
g_free (buttons);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
|
Loading…
Add table
Reference in a new issue