mirror of
https://github.com/YGGverse/xash3d-fwgs.git
synced 2025-01-18 02:50:33 +00:00
platform/evdev: add some keys, add keyevent debug
This commit is contained in:
parent
5e31e3fad0
commit
291fdfac68
@ -37,6 +37,8 @@ struct evdev_s
|
|||||||
qboolean shift;
|
qboolean shift;
|
||||||
} evdev;
|
} evdev;
|
||||||
|
|
||||||
|
static convar_t *evdev_keydebug;
|
||||||
|
|
||||||
static int KeycodeFromEvdev(int keycode, int value)
|
static int KeycodeFromEvdev(int keycode, int value)
|
||||||
{
|
{
|
||||||
switch (keycode) {
|
switch (keycode) {
|
||||||
@ -119,6 +121,10 @@ static int KeycodeFromEvdev(int keycode, int value)
|
|||||||
case BTN_LEFT: return K_MOUSE1;
|
case BTN_LEFT: return K_MOUSE1;
|
||||||
case BTN_RIGHT: return K_MOUSE2;
|
case BTN_RIGHT: return K_MOUSE2;
|
||||||
case BTN_MIDDLE: return K_MOUSE3;
|
case BTN_MIDDLE: return K_MOUSE3;
|
||||||
|
case KEY_POWER: return K_ESCAPE;
|
||||||
|
case KEY_VOLUMEDOWN: return K_PGDN;
|
||||||
|
case KEY_VOLUMEUP: return K_PGUP;
|
||||||
|
case KEY_PLAYPAUSE: return K_ENTER;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -216,7 +222,7 @@ void Evdev_Autodetect_f( void )
|
|||||||
open:
|
open:
|
||||||
Q_strncpy( evdev.paths[evdev.devices], path, MAX_STRING );
|
Q_strncpy( evdev.paths[evdev.devices], path, MAX_STRING );
|
||||||
evdev.fds[evdev.devices++] = fd;
|
evdev.fds[evdev.devices++] = fd;
|
||||||
Msg( "Opened device %s\n", path );
|
Con_Printf( "Opened device %s\n", path );
|
||||||
#if XASH_INPUT == INPUT_EVDEV
|
#if XASH_INPUT == INPUT_EVDEV
|
||||||
if( Sys_CheckParm( "-grab" ) )
|
if( Sys_CheckParm( "-grab" ) )
|
||||||
ioctl( evdev.fds[i], EVIOCGRAB, (void*) 1 );
|
ioctl( evdev.fds[i], EVIOCGRAB, (void*) 1 );
|
||||||
@ -244,7 +250,7 @@ void Evdev_OpenDevice ( const char *path )
|
|||||||
|
|
||||||
if ( evdev.devices >= MAX_EVDEV_DEVICES )
|
if ( evdev.devices >= MAX_EVDEV_DEVICES )
|
||||||
{
|
{
|
||||||
Msg( "Only %d devices supported!\n", MAX_EVDEV_DEVICES );
|
Con_Printf( "Only %d devices supported!\n", MAX_EVDEV_DEVICES );
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -256,7 +262,7 @@ void Evdev_OpenDevice ( const char *path )
|
|||||||
{
|
{
|
||||||
if( !Q_strncmp( evdev.paths[i], path, MAX_STRING ) )
|
if( !Q_strncmp( evdev.paths[i], path, MAX_STRING ) )
|
||||||
{
|
{
|
||||||
Msg( "device %s already open!\n", path );
|
Con_Printf( "device %s already open!\n", path );
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -267,7 +273,7 @@ void Evdev_OpenDevice ( const char *path )
|
|||||||
Con_Reportf( S_ERROR "Could not open input device %s: %s\n", path, strerror( errno ) );
|
Con_Reportf( S_ERROR "Could not open input device %s: %s\n", path, strerror( errno ) );
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
Msg( "Input device #%d: %s opened sucessfully\n", evdev.devices, path );
|
Con_Printf( "Input device #%d: %s opened sucessfully\n", evdev.devices, path );
|
||||||
evdev.fds[evdev.devices] = ret;
|
evdev.fds[evdev.devices] = ret;
|
||||||
Q_strncpy( evdev.paths[evdev.devices++], path, MAX_STRING );
|
Q_strncpy( evdev.paths[evdev.devices++], path, MAX_STRING );
|
||||||
|
|
||||||
@ -280,7 +286,7 @@ void Evdev_OpenDevice ( const char *path )
|
|||||||
void Evdev_OpenDevice_f( void )
|
void Evdev_OpenDevice_f( void )
|
||||||
{
|
{
|
||||||
if( Cmd_Argc() < 2 )
|
if( Cmd_Argc() < 2 )
|
||||||
Msg( S_USAGE "evdev_opendevice <path>\n" );
|
Con_Printf( S_USAGE "evdev_opendevice <path>\n" );
|
||||||
|
|
||||||
Evdev_OpenDevice( Cmd_Argv( 1 ) );
|
Evdev_OpenDevice( Cmd_Argv( 1 ) );
|
||||||
}
|
}
|
||||||
@ -308,13 +314,13 @@ void Evdev_CloseDevice_f ( void )
|
|||||||
|
|
||||||
if( i >= evdev.devices )
|
if( i >= evdev.devices )
|
||||||
{
|
{
|
||||||
Msg( "Device %s is not open\n", arg );
|
Con_Printf( "Device %s is not open\n", arg );
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
close( evdev.fds[i] );
|
close( evdev.fds[i] );
|
||||||
evdev.devices--;
|
evdev.devices--;
|
||||||
Msg( "Device %s closed successfully\n", evdev.paths[i] );
|
Con_Printf( "Device %s closed successfully\n", evdev.paths[i] );
|
||||||
|
|
||||||
for( ; i < evdev.devices; i++ )
|
for( ; i < evdev.devices; i++ )
|
||||||
{
|
{
|
||||||
@ -360,6 +366,10 @@ void IN_EvdevFrame ( void )
|
|||||||
else if ( ( ev.type == EV_KEY ) && (cls.key_dest == key_game || XASH_INPUT == INPUT_EVDEV ) )
|
else if ( ( ev.type == EV_KEY ) && (cls.key_dest == key_game || XASH_INPUT == INPUT_EVDEV ) )
|
||||||
{
|
{
|
||||||
int key = KeycodeFromEvdev( ev.code, ev.value );
|
int key = KeycodeFromEvdev( ev.code, ev.value );
|
||||||
|
|
||||||
|
if( CVAR_TO_BOOL(evdev_keydebug) )
|
||||||
|
Con_Printf( "key %d %d %d\n", ev.code, key, ev.value );
|
||||||
|
|
||||||
Key_Event( key , ev.value );
|
Key_Event( key , ev.value );
|
||||||
|
|
||||||
if( evdev.chars && ev.value )
|
if( evdev.chars && ev.value )
|
||||||
@ -452,6 +462,7 @@ void Evdev_Shutdown( void )
|
|||||||
Cmd_RemoveCommand( "evdev_open" );
|
Cmd_RemoveCommand( "evdev_open" );
|
||||||
Cmd_RemoveCommand( "evdev_close" );
|
Cmd_RemoveCommand( "evdev_close" );
|
||||||
Cmd_RemoveCommand( "evdev_autodetect" );
|
Cmd_RemoveCommand( "evdev_autodetect" );
|
||||||
|
evdev_keydebug = Cvar_Get( "evdev_keydebug", "0", 0, "print key events to console" );
|
||||||
|
|
||||||
for( i = 0; i < evdev.devices; i++ )
|
for( i = 0; i < evdev.devices; i++ )
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user