mirror of
https://github.com/libretro/RetroArch
synced 2025-02-09 09:39:56 +00:00
Remove input_x11_common.c and merge into x11_input.c
This commit is contained in:
parent
b4be9b7e03
commit
a0948c1d9d
@ -1101,8 +1101,7 @@ ifeq ($(HAVE_OPENDINGUX_FBDEV), 1)
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
ifeq ($(HAVE_X11), 1)
|
ifeq ($(HAVE_X11), 1)
|
||||||
OBJ += input/common/input_x11_common.o \
|
OBJ += input/drivers/x11_input.o \
|
||||||
input/drivers/x11_input.o \
|
|
||||||
gfx/common/x11_common.o \
|
gfx/common/x11_common.o \
|
||||||
gfx/common/xinerama_common.o \
|
gfx/common/xinerama_common.o \
|
||||||
gfx/display_servers/dispserv_x11.o
|
gfx/display_servers/dispserv_x11.o
|
||||||
|
@ -1,73 +0,0 @@
|
|||||||
/* RetroArch - A frontend for libretro.
|
|
||||||
* Copyright (C) 2010-2014 - Hans-Kristian Arntzen
|
|
||||||
* Copyright (C) 2011-2017 - Daniel De Matteis
|
|
||||||
*
|
|
||||||
* RetroArch is free software: you can redistribute it and/or modify it under the terms
|
|
||||||
* of the GNU General Public License as published by the Free Software Found-
|
|
||||||
* ation, either version 3 of the License, or (at your option) any later version.
|
|
||||||
*
|
|
||||||
* RetroArch is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
|
|
||||||
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
||||||
* PURPOSE. See the GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License along with RetroArch.
|
|
||||||
* If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <libretro.h>
|
|
||||||
|
|
||||||
#include "input_x11_common.h"
|
|
||||||
|
|
||||||
/* TODO/FIXME - static globals */
|
|
||||||
static bool x11_mouse_wu;
|
|
||||||
static bool x11_mouse_wd;
|
|
||||||
static bool x11_mouse_hwu;
|
|
||||||
static bool x11_mouse_hwd;
|
|
||||||
|
|
||||||
int16_t x_mouse_state_wheel(unsigned id)
|
|
||||||
{
|
|
||||||
int16_t ret = 0;
|
|
||||||
|
|
||||||
switch (id)
|
|
||||||
{
|
|
||||||
case RETRO_DEVICE_ID_MOUSE_WHEELUP:
|
|
||||||
ret = x11_mouse_wu;
|
|
||||||
x11_mouse_wu = 0;
|
|
||||||
return ret;
|
|
||||||
case RETRO_DEVICE_ID_MOUSE_WHEELDOWN:
|
|
||||||
ret = x11_mouse_wd;
|
|
||||||
x11_mouse_wd = 0;
|
|
||||||
return ret;
|
|
||||||
case RETRO_DEVICE_ID_MOUSE_HORIZ_WHEELUP:
|
|
||||||
ret = x11_mouse_hwu;
|
|
||||||
x11_mouse_hwu = 0;
|
|
||||||
return ret;
|
|
||||||
case RETRO_DEVICE_ID_MOUSE_HORIZ_WHEELDOWN:
|
|
||||||
ret = x11_mouse_hwd;
|
|
||||||
x11_mouse_hwd = 0;
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void x_input_poll_wheel(XButtonEvent *event, bool latch)
|
|
||||||
{
|
|
||||||
switch (event->button)
|
|
||||||
{
|
|
||||||
case 4:
|
|
||||||
x11_mouse_wu = 1;
|
|
||||||
break;
|
|
||||||
case 5:
|
|
||||||
x11_mouse_wd = 1;
|
|
||||||
break;
|
|
||||||
case 6:
|
|
||||||
/* Scroll wheel left == HORIZ_WHEELDOWN */
|
|
||||||
x11_mouse_hwd = 1;
|
|
||||||
break;
|
|
||||||
case 7:
|
|
||||||
/* Scroll wheel right == HORIZ_WHEELUP */
|
|
||||||
x11_mouse_hwu = 1;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
@ -40,6 +40,10 @@ typedef struct x11_input
|
|||||||
Window win;
|
Window win;
|
||||||
|
|
||||||
char state[32];
|
char state[32];
|
||||||
|
bool mouse_wu;
|
||||||
|
bool mouse_wd;
|
||||||
|
bool mouse_hwu;
|
||||||
|
bool mouse_hwd;
|
||||||
bool mouse_l, mouse_r, mouse_m;
|
bool mouse_l, mouse_r, mouse_m;
|
||||||
int mouse_x, mouse_y;
|
int mouse_x, mouse_y;
|
||||||
int mouse_last_x, mouse_last_y;
|
int mouse_last_x, mouse_last_y;
|
||||||
@ -77,6 +81,33 @@ static bool x_keyboard_pressed(x11_input_t *x11, unsigned key)
|
|||||||
return x11->state[keycode >> 3] & (1 << (keycode & 7));
|
return x11->state[keycode >> 3] & (1 << (keycode & 7));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int16_t x_mouse_state_wheel(x11_input_t *x11, unsigned id)
|
||||||
|
{
|
||||||
|
int16_t ret = 0;
|
||||||
|
|
||||||
|
switch (id)
|
||||||
|
{
|
||||||
|
case RETRO_DEVICE_ID_MOUSE_WHEELUP:
|
||||||
|
ret = x11->mouse_wu;
|
||||||
|
x11->mouse_wu = 0;
|
||||||
|
return ret;
|
||||||
|
case RETRO_DEVICE_ID_MOUSE_WHEELDOWN:
|
||||||
|
ret = x11->mouse_wd;
|
||||||
|
x11->mouse_wd = 0;
|
||||||
|
return ret;
|
||||||
|
case RETRO_DEVICE_ID_MOUSE_HORIZ_WHEELUP:
|
||||||
|
ret = x11->mouse_hwu;
|
||||||
|
x11->mouse_hwu = 0;
|
||||||
|
return ret;
|
||||||
|
case RETRO_DEVICE_ID_MOUSE_HORIZ_WHEELDOWN:
|
||||||
|
ret = x11->mouse_hwd;
|
||||||
|
x11->mouse_hwd = 0;
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static bool x_mouse_button_pressed(
|
static bool x_mouse_button_pressed(
|
||||||
x11_input_t *x11, unsigned port, unsigned key)
|
x11_input_t *x11, unsigned port, unsigned key)
|
||||||
{
|
{
|
||||||
@ -100,7 +131,7 @@ static bool x_mouse_button_pressed(
|
|||||||
case RETRO_DEVICE_ID_MOUSE_WHEELDOWN:
|
case RETRO_DEVICE_ID_MOUSE_WHEELDOWN:
|
||||||
case RETRO_DEVICE_ID_MOUSE_HORIZ_WHEELUP:
|
case RETRO_DEVICE_ID_MOUSE_HORIZ_WHEELUP:
|
||||||
case RETRO_DEVICE_ID_MOUSE_HORIZ_WHEELDOWN:
|
case RETRO_DEVICE_ID_MOUSE_HORIZ_WHEELDOWN:
|
||||||
return x_mouse_state_wheel(key);
|
return x_mouse_state_wheel(x11, key);
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
@ -199,7 +230,7 @@ static int16_t x_mouse_state(x11_input_t *x11, unsigned id)
|
|||||||
case RETRO_DEVICE_ID_MOUSE_WHEELDOWN:
|
case RETRO_DEVICE_ID_MOUSE_WHEELDOWN:
|
||||||
case RETRO_DEVICE_ID_MOUSE_HORIZ_WHEELUP:
|
case RETRO_DEVICE_ID_MOUSE_HORIZ_WHEELUP:
|
||||||
case RETRO_DEVICE_ID_MOUSE_HORIZ_WHEELDOWN:
|
case RETRO_DEVICE_ID_MOUSE_HORIZ_WHEELDOWN:
|
||||||
return x_mouse_state_wheel(id);
|
return x_mouse_state_wheel(x11, id);
|
||||||
case RETRO_DEVICE_ID_MOUSE_MIDDLE:
|
case RETRO_DEVICE_ID_MOUSE_MIDDLE:
|
||||||
return x11->mouse_m;
|
return x11->mouse_m;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user