Fix signed vs. unsigned confusion in actions Some actions could also take relative rather than absolute parameters, so they really needed to be signed instead of explicitly unsigned. Oops. Fixes, e.g., action= MovePtr(x=-1,y=+1), which was reported as (x=+65535,y=+1). Signed-off-by: Daniel Stone <daniel@fooishbar.org>
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52
diff --git a/src/xkb-priv.h b/src/xkb-priv.h
index e8838d3..c52a96e 100644
--- a/src/xkb-priv.h
+++ b/src/xkb-priv.h
@@ -168,23 +168,23 @@ struct xkb_device_valuator_action {
uint8_t device;
uint8_t v1_what;
uint8_t v1_index;
- uint8_t v1_value;
+ int8_t v1_value;
uint8_t v2_what;
uint8_t v2_index;
- uint8_t v2_value;
+ int8_t v2_value;
};
struct xkb_pointer_default_action {
uint8_t type;
uint8_t flags;
uint8_t affect;
- uint8_t value;
+ int8_t value;
};
struct xkb_switch_screen_action {
uint8_t type;
uint8_t flags;
- uint8_t screen;
+ int8_t screen;
};
struct xkb_redirect_key_action {
@@ -199,8 +199,8 @@ struct xkb_redirect_key_action {
struct xkb_pointer_action {
uint8_t type;
uint8_t flags;
- uint16_t x;
- uint16_t y;
+ int16_t x;
+ int16_t y;
};
struct xkb_message_action {
@@ -213,7 +213,7 @@ struct xkb_pointer_button_action {
uint8_t type;
uint8_t flags;
uint8_t count;
- uint8_t button;
+ int8_t button;
};
union xkb_action {