RetroArch/input/input_mapper.c

145 lines
3.6 KiB
C
Raw Normal View History

2017-09-08 03:30:42 +00:00
/* RetroArch - A frontend for libretro.
* Copyright (C) 2010-2014 - Hans-Kristian Arntzen
* Copyright (C) 2011-2017 - Daniel De Matteis
* Copyright (C) 2016-2017 - Andrés Suárez
*
* 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 <stdio.h>
#include <stdlib.h>
#include <string.h>
#ifdef _WIN32
#include <direct.h>
#else
#include <unistd.h>
#endif
#include <compat/strl.h>
#include <compat/posix_string.h>
#include <retro_miscellaneous.h>
#include <libretro.h>
#ifdef HAVE_CONFIG_H
#include "../config.h"
#endif
#include "input_mapper.h"
#include "../configuration.h"
#include "../msg_hash.h"
#include "../verbosity.h"
2017-09-09 19:21:00 +00:00
#define MAPPER_GET_KEY(state, key) (((state)->keys[(key) / 32] >> ((key) % 32)) & 1)
#define MAPPER_SET_KEY(state, key) (state)->keys[(key) / 32] |= 1 << ((key) % 32)
2017-09-08 03:30:42 +00:00
struct input_mapper
{
2017-09-09 19:21:00 +00:00
/* The controller port that will be polled*/
uint8_t port;
2017-09-08 03:30:42 +00:00
/* Left X, Left Y, Right X, Right Y */
2017-09-09 19:21:00 +00:00
int16_t analog[4];
2017-09-08 03:30:42 +00:00
/* the whole keyboard state */
uint32_t keys[RETROK_LAST / 32 + 1];
2017-11-12 16:02:14 +00:00
/* This is a bitmask of (1 << key_bind_id). */
uint64_t buttons;
2017-09-09 19:21:00 +00:00
};
2017-09-08 03:30:42 +00:00
input_mapper_t *input_mapper_new(uint16_t port)
{
2017-09-09 19:21:00 +00:00
input_mapper_t* handle = (input_mapper_t*)
calloc(1, sizeof(*handle));
2017-09-09 19:21:00 +00:00
if (!handle)
return NULL;
2017-11-12 16:02:14 +00:00
2017-09-09 19:21:00 +00:00
handle->port = port;
2017-09-09 19:21:00 +00:00
return handle;
2017-09-08 03:30:42 +00:00
}
void input_mapper_free(input_mapper_t *handle)
{
if (!handle)
return;
2017-09-09 19:21:00 +00:00
free (handle);
2017-09-08 03:30:42 +00:00
}
2017-09-09 19:21:00 +00:00
void input_mapper_poll(input_mapper_t *handle)
2017-09-08 03:30:42 +00:00
{
int i;
2017-09-09 19:21:00 +00:00
settings_t *settings = config_get_ptr();
unsigned device = settings->uints.input_libretro_device[handle->port];
device &= RETRO_DEVICE_MASK;
2017-09-09 19:21:00 +00:00
/* for now we only handle keyboard inputs */
if (device != RETRO_DEVICE_KEYBOARD)
return;
memset(handle->keys, 0, sizeof(handle->keys));
2017-09-09 19:21:00 +00:00
for (i = 0; i < RARCH_CUSTOM_BIND_LIST_END; i++)
{
if (i < RETROK_LAST)
2017-09-09 19:21:00 +00:00
{
if (input_state(handle->port, RETRO_DEVICE_JOYPAD, 0, i))
2017-09-09 19:21:00 +00:00
{
MAPPER_SET_KEY (handle,
settings->uints.input_keymapper_ids[i]);
input_keyboard_event(true,
settings->uints.input_keymapper_ids[i],
0, 0, RETRO_DEVICE_KEYBOARD);
2017-09-09 19:21:00 +00:00
}
else
input_keyboard_event(false,
settings->uints.input_keymapper_ids[i],
0, 0, RETRO_DEVICE_KEYBOARD);
2017-09-09 19:21:00 +00:00
}
}
2017-09-08 03:30:42 +00:00
}
void input_mapper_state(
input_mapper_t *handle,
2017-09-08 03:30:42 +00:00
int16_t *ret,
unsigned port,
unsigned device,
unsigned idx,
unsigned id)
{
if (!handle)
return;
2017-09-09 19:21:00 +00:00
switch (device)
{
case RETRO_DEVICE_KEYBOARD:
if (id < RETROK_LAST)
{
/*
RARCH_LOG("State: UDLR %u %u %u %u\n",
MAPPER_GET_KEY(handle, RETROK_UP),
MAPPER_GET_KEY(handle, RETROK_DOWN),
MAPPER_GET_KEY(handle, RETROK_LEFT),
MAPPER_GET_KEY(handle, RETROK_RIGHT)
);*/
if (MAPPER_GET_KEY(handle, id))
2017-09-09 19:21:00 +00:00
*ret |= 1;
}
break;
default:
break;
2017-09-09 19:21:00 +00:00
}
2017-09-16 23:06:55 +00:00
}