Merge pull request #1804 from bradhugh/autorepeat_fix

Double-check key state before UI autorepeat. Fixes #1169
This commit is contained in:
Vas Crabb 2016-12-10 14:49:49 +11:00 committed by GitHub
commit d44a1ac1fa

View File

@ -263,7 +263,14 @@ g_profiler.start(PROFILER_INPUT);
/* if this is an autorepeat case, set a 1x delay and leave pressed = 1 */
else if (speed > 0 && (osd_ticks() + tps - m_next_repeat[code]) >= tps)
m_next_repeat[code] += 1 * speed * tps / 60;
{
// In the autorepeatcase, we need to double check the key is still pressed
// as there can be a delay between the key polling and our processing of the event
m_seqpressed[code] = machine().ioport().type_pressed(ioport_type(code));
pressed = (m_seqpressed[code] == SEQ_PRESSED_TRUE);
if (pressed)
m_next_repeat[code] += 1 * speed * tps / 60;
}
/* otherwise, reset pressed = 0 */
else