summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJonas Ã…dahl <jadahl@gmail.com>2016-06-22 17:38:00 +0800
committerCarlos Garnacho <carlosg@gnome.org>2016-08-10 10:39:24 +0200
commit364b184f41210b02ddafd4a51bb276a8f40e093b (patch)
tree9b75a48abc9cb25b13b5259d44247d7d2432b3ba
parent94016f725700b235af9f3c5364d2e7e93d917270 (diff)
downloadmutter-364b184f41210b02ddafd4a51bb276a8f40e093b.tar.gz
ClutterVirtualInputDevice: Store the device type
https://bugzilla.gnome.org/show_bug.cgi?id=765009
-rw-r--r--clutter/clutter/clutter-virtual-input-device.c25
-rw-r--r--clutter/clutter/clutter-virtual-input-device.h2
-rw-r--r--clutter/clutter/evdev/clutter-device-manager-evdev.c1
3 files changed, 28 insertions, 0 deletions
diff --git a/clutter/clutter/clutter-virtual-input-device.c b/clutter/clutter/clutter-virtual-input-device.c
index f79d7c43b..ab19e650a 100644
--- a/clutter/clutter/clutter-virtual-input-device.c
+++ b/clutter/clutter/clutter-virtual-input-device.c
@@ -31,12 +31,14 @@
#include "clutter-device-manager.h"
#include "clutter-private.h"
+#include "clutter-enum-types.h"
enum
{
PROP_0,
PROP_DEVICE_MANAGER,
+ PROP_DEVICE_TYPE,
PROP_LAST
};
@@ -46,6 +48,7 @@ static GParamSpec *obj_props[PROP_LAST];
typedef struct _ClutterVirtualInputDevicePrivate
{
ClutterDeviceManager *manager;
+ ClutterInputDeviceType device_type;
} ClutterVirtualInputDevicePrivate;
G_DEFINE_TYPE_WITH_PRIVATE (ClutterVirtualInputDevice,
@@ -109,6 +112,15 @@ clutter_virtual_input_device_get_manager (ClutterVirtualInputDevice *virtual_dev
return priv->manager;
}
+int
+clutter_virtual_input_device_get_device_type (ClutterVirtualInputDevice *virtual_device)
+{
+ ClutterVirtualInputDevicePrivate *priv =
+ clutter_virtual_input_device_get_instance_private (virtual_device);
+
+ return priv->device_type;
+}
+
static void
clutter_virtual_input_device_get_property (GObject *object,
guint prop_id,
@@ -125,6 +137,9 @@ clutter_virtual_input_device_get_property (GObject *object,
case PROP_DEVICE_MANAGER:
g_value_set_object (value, priv->manager);
break;
+ case PROP_DEVICE_TYPE:
+ g_value_set_enum (value, priv->device_type);
+ break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
break;
@@ -147,6 +162,9 @@ clutter_virtual_input_device_set_property (GObject *object,
case PROP_DEVICE_MANAGER:
priv->manager = g_value_get_object (value);
break;
+ case PROP_DEVICE_TYPE:
+ priv->device_type = g_value_get_enum (value);
+ break;
default:
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
break;
@@ -172,6 +190,13 @@ clutter_virtual_input_device_class_init (ClutterVirtualInputDeviceClass *klass)
P_("The device manager instance"),
CLUTTER_TYPE_DEVICE_MANAGER,
CLUTTER_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY);
+ obj_props[PROP_DEVICE_TYPE] =
+ g_param_spec_enum ("device-type",
+ P_("Device type"),
+ P_("Device type"),
+ CLUTTER_TYPE_INPUT_DEVICE_TYPE,
+ CLUTTER_POINTER_DEVICE,
+ CLUTTER_PARAM_READWRITE | G_PARAM_CONSTRUCT_ONLY);
g_object_class_install_properties (object_class, PROP_LAST, obj_props);
}
diff --git a/clutter/clutter/clutter-virtual-input-device.h b/clutter/clutter/clutter-virtual-input-device.h
index d1a27d77d..976c123f9 100644
--- a/clutter/clutter/clutter-virtual-input-device.h
+++ b/clutter/clutter/clutter-virtual-input-device.h
@@ -94,4 +94,6 @@ void clutter_virtual_input_device_notify_key (ClutterVirtualInputDevice *virtual
ClutterDeviceManager * clutter_virtual_input_device_get_manager (ClutterVirtualInputDevice *virtual_device);
+int clutter_virtual_input_device_get_device_type (ClutterVirtualInputDevice *virtual_device);
+
#endif /* __CLUTTER_VIRTUAL_INPUT_DEVICE_H__ */
diff --git a/clutter/clutter/evdev/clutter-device-manager-evdev.c b/clutter/clutter/evdev/clutter-device-manager-evdev.c
index 096fe4c19..d7d727178 100644
--- a/clutter/clutter/evdev/clutter-device-manager-evdev.c
+++ b/clutter/clutter/evdev/clutter-device-manager-evdev.c
@@ -1961,6 +1961,7 @@ clutter_device_manager_evdev_create_virtual_device (ClutterDeviceManager *manag
{
return g_object_new (CLUTTER_TYPE_VIRTUAL_INPUT_DEVICE_EVDEV,
"device-manager", manager,
+ "device-type", device_type,
NULL);
}