/** * input_keys_pressed: * * Grab an input sample for this frame. * * TODO: In case RARCH_BIND_LIST_END starts exceeding 64, * and you need a bitmask of more than 64 entries, reimplement * it to use something like rarch_bits_t. * * Returns: Input sample containg a mask of all pressed keys. */ retro_input_t input_keys_pressed(void) { unsigned i, key; const struct retro_keybind *binds[MAX_USERS]; retro_input_t ret = {0}; settings_t *settings = config_get_ptr(); for (i = 0; i < MAX_USERS; i++) binds[i] = settings->input.binds[i]; if (!current_input || !current_input_data) return ret; input_driver_turbo_btns.count++; key = RARCH_ENABLE_HOTKEY; if (check_input_driver_block_hotkey(input_driver_key_pressed(&key))) input_driver_set_libretro_input_blocked(); else input_driver_unset_libretro_input_blocked(); for (i = 0; i < settings->input.max_users; i++) { input_push_analog_dpad(settings->input.binds[i], settings->input.analog_dpad_mode[i]); input_push_analog_dpad(settings->input.autoconf_binds[i], settings->input.analog_dpad_mode[i]); input_driver_turbo_btns.frame_enable[i] = 0; } if (!input_driver_is_libretro_input_blocked()) { for (i = 0; i < settings->input.max_users; i++) input_driver_turbo_btns.frame_enable[i] = input_driver_state(binds, i, RETRO_DEVICE_JOYPAD, 0, RARCH_TURBO_ENABLE); } ret = input_driver_keys_pressed(); for (i = 0; i < settings->input.max_users; i++) { input_pop_analog_dpad(settings->input.binds[i]); input_pop_analog_dpad(settings->input.autoconf_binds[i]); } return ret; }
/** * input_keys_pressed: * * Grab an input sample for this frame. * * TODO: In case RARCH_BIND_LIST_END starts exceeding 64, * and you need a bitmask of more than 64 entries, reimplement * it to use something like rarch_bits_t. * * Returns: Input sample containg a mask of all pressed keys. */ static INLINE retro_input_t input_keys_pressed(driver_t *driver, settings_t *settings, global_t *global) { unsigned i; const struct retro_keybind *binds[MAX_USERS]; retro_input_t ret = 0; for (i = 0; i < MAX_USERS; i++) binds[i] = settings->input.binds[i]; if (!driver->input || !driver->input_data) return 0; global->turbo_count++; driver->block_libretro_input = check_block_hotkey(driver, settings, input_driver_key_pressed(RARCH_ENABLE_HOTKEY)); for (i = 0; i < settings->input.max_users; i++) { input_push_analog_dpad(settings->input.binds[i], settings->input.analog_dpad_mode[i]); input_push_analog_dpad(settings->input.autoconf_binds[i], settings->input.analog_dpad_mode[i]); global->turbo_frame_enable[i] = 0; } if (!driver->block_libretro_input) { for (i = 0; i < settings->input.max_users; i++) global->turbo_frame_enable[i] = input_driver_state(binds, i, RETRO_DEVICE_JOYPAD, 0, RARCH_TURBO_ENABLE); } ret = input_driver_keys_pressed(); for (i = 0; i < settings->input.max_users; i++) { input_pop_analog_dpad(settings->input.binds[i]); input_pop_analog_dpad(settings->input.autoconf_binds[i]); } return ret; }
static retro_input_t input_driver_keys_pressed(void) { unsigned key; retro_input_t ret = {0}; for (key = 0; key < RARCH_BIND_LIST_END; key++) { bool state = false; if ((!input_driver_is_libretro_input_blocked() && ((key < RARCH_FIRST_META_KEY))) || !input_driver_is_hotkey_blocked()) state = input_driver_key_pressed(&key); if (key >= RARCH_FIRST_META_KEY) state |= current_input->meta_key_pressed(current_input_data, key); #ifdef HAVE_OVERLAY state |= input_overlay_key_pressed(key); #endif #ifdef HAVE_COMMAND if (input_driver_command) { command_handle_t handle; handle.handle = input_driver_command; handle.id = key; state |= command_get(&handle); } #endif #ifdef HAVE_NETWORKGAMEPAD if (input_driver_remote) state |= input_remote_key_pressed(key,0); #endif if (state) ret.state |= (UINT64_C(1) << key); } return ret; }