Fix a doxygen reference
[platform/upstream/libinput.git] / src / libinput-private.h
index b08c035..94a3e07 100644 (file)
 #ifndef LIBINPUT_PRIVATE_H
 #define LIBINPUT_PRIVATE_H
 
+#include "linux/input.h"
+
 #include "libinput.h"
 #include "libinput-util.h"
 
+struct libinput_source;
+
 struct libinput_interface_backend {
        int (*resume)(struct libinput *libinput);
        void (*suspend)(struct libinput *libinput);
@@ -38,6 +42,12 @@ struct libinput {
 
        struct list seat_list;
 
+       struct {
+               struct list list;
+               struct libinput_source *source;
+               int fd;
+       } timer;
+
        struct libinput_event **events;
        size_t events_count;
        size_t events_len;
@@ -46,7 +56,11 @@ struct libinput {
 
        const struct libinput_interface *interface;
        const struct libinput_interface_backend *interface_backend;
+
+       libinput_log_handler log_handler;
+       enum libinput_log_priority log_priority;
        void *user_data;
+       int refcount;
 };
 
 typedef void (*libinput_seat_destroy_func) (struct libinput_seat *seat);
@@ -57,8 +71,26 @@ struct libinput_seat {
        struct list devices_list;
        void *user_data;
        int refcount;
-       char *name;
        libinput_seat_destroy_func destroy;
+
+       char *physical_name;
+       char *logical_name;
+
+       uint32_t slot_map;
+
+       uint32_t button_count[KEY_CNT];
+};
+
+struct libinput_device_config_tap {
+       int (*count)(struct libinput_device *device);
+       enum libinput_config_status (*set_enabled)(struct libinput_device *device,
+                                                  enum libinput_config_tap_state enable);
+       enum libinput_config_tap_state (*get_enabled)(struct libinput_device *device);
+       enum libinput_config_tap_state (*get_default)(struct libinput_device *device);
+};
+
+struct libinput_device_config {
+       struct libinput_device_config_tap *tap;
 };
 
 struct libinput_device {
@@ -67,11 +99,29 @@ struct libinput_device {
        void *user_data;
        int terminated;
        int refcount;
+       struct libinput_device_config config;
 };
 
 typedef void (*libinput_source_dispatch_t)(void *data);
 
-struct libinput_source;
+
+#define log_debug(li_, ...) log_msg((li_), LIBINPUT_LOG_PRIORITY_DEBUG, __VA_ARGS__)
+#define log_info(li_, ...) log_msg((li_), LIBINPUT_LOG_PRIORITY_INFO, __VA_ARGS__)
+#define log_error(li_, ...) log_msg((li_), LIBINPUT_LOG_PRIORITY_ERROR, __VA_ARGS__)
+#define log_bug_kernel(li_, ...) log_msg((li_), LIBINPUT_LOG_PRIORITY_ERROR, "kernel bug: " __VA_ARGS__)
+#define log_bug_libinput(li_, ...) log_msg((li_), LIBINPUT_LOG_PRIORITY_ERROR, "libinput bug: " __VA_ARGS__);
+#define log_bug_client(li_, ...) log_msg((li_), LIBINPUT_LOG_PRIORITY_ERROR, "client bug: " __VA_ARGS__);
+
+void
+log_msg(struct libinput *libinput,
+       enum libinput_log_priority priority,
+       const char *format, ...);
+
+void
+log_msg_va(struct libinput *libinput,
+          enum libinput_log_priority priority,
+          const char *format,
+          va_list args);
 
 int
 libinput_init(struct libinput *libinput,
@@ -99,7 +149,8 @@ close_restricted(struct libinput *libinput, int fd);
 void
 libinput_seat_init(struct libinput_seat *seat,
                   struct libinput *libinput,
-                  const char *name,
+                  const char *physical_name,
+                  const char *logical_name,
                   libinput_seat_destroy_func destroy);
 
 void
@@ -116,38 +167,55 @@ void
 keyboard_notify_key(struct libinput_device *device,
                    uint32_t time,
                    uint32_t key,
-                   enum libinput_keyboard_key_state state);
+                   enum libinput_key_state state);
 
 void
 pointer_notify_motion(struct libinput_device *device,
                      uint32_t time,
-                     li_fixed_t dx,
-                     li_fixed_t dy);
+                     double dx,
+                     double dy);
 
 void
 pointer_notify_motion_absolute(struct libinput_device *device,
                               uint32_t time,
-                              li_fixed_t x,
-                              li_fixed_t y);
+                              double x,
+                              double y);
 
 void
 pointer_notify_button(struct libinput_device *device,
                      uint32_t time,
                      int32_t button,
-                     enum libinput_pointer_button_state state);
+                     enum libinput_button_state state);
 
 void
 pointer_notify_axis(struct libinput_device *device,
                    uint32_t time,
                    enum libinput_pointer_axis axis,
-                   li_fixed_t value);
+                   double value);
 
 void
-touch_notify_touch(struct libinput_device *device,
-                  uint32_t time,
-                  int32_t slot,
-                  li_fixed_t x,
-                  li_fixed_t y,
-                  enum libinput_touch_type touch_type);
+touch_notify_touch_down(struct libinput_device *device,
+                       uint32_t time,
+                       int32_t slot,
+                       int32_t seat_slot,
+                       double x,
+                       double y);
 
+void
+touch_notify_touch_motion(struct libinput_device *device,
+                         uint32_t time,
+                         int32_t slot,
+                         int32_t seat_slot,
+                         double x,
+                         double y);
+
+void
+touch_notify_touch_up(struct libinput_device *device,
+                     uint32_t time,
+                     int32_t slot,
+                     int32_t seat_slot);
+
+void
+touch_notify_frame(struct libinput_device *device,
+                  uint32_t time);
 #endif /* LIBINPUT_PRIVATE_H */