mirror of
https://github.com/holub/mame
synced 2025-07-01 08:18:59 +03:00
Reverted to older behavior for how modified input port fields are handled.
The originally intended behavior is that a new field that intersected a previous field would completely wipe out the original field. Recently a change was made that changed the behavior to only remove a portion of the bits from the original field. This is actually problematic behavior, so the original behavior was restored. Currently I put this behind a compile-time define until we see that we haven't come to rely on the newer behavior.
This commit is contained in:
parent
aa53f5fd34
commit
a97a3f416f
@ -108,6 +108,12 @@
|
|||||||
#endif /* MESS */
|
#endif /* MESS */
|
||||||
|
|
||||||
|
|
||||||
|
/* temporary: set this to 1 to enable the originally defined behavior that
|
||||||
|
a field specified via PORT_MODIFY which intersects a previously-defined
|
||||||
|
field completely wipes out the previous definition */
|
||||||
|
#define INPUT_PORT_OVERRIDE_FULLY_NUKES_PREVIOUS 1
|
||||||
|
|
||||||
|
|
||||||
/***************************************************************************
|
/***************************************************************************
|
||||||
CONSTANTS
|
CONSTANTS
|
||||||
***************************************************************************/
|
***************************************************************************/
|
||||||
@ -3066,7 +3072,7 @@ static void field_config_insert(input_field_config *field, input_port_value *dis
|
|||||||
config->mask &= ~field->mask;
|
config->mask &= ~field->mask;
|
||||||
|
|
||||||
/* if the new entry fully overrides the previous one, we nuke */
|
/* if the new entry fully overrides the previous one, we nuke */
|
||||||
if (config->mask == 0)
|
if (INPUT_PORT_OVERRIDE_FULLY_NUKES_PREVIOUS || config->mask == 0)
|
||||||
{
|
{
|
||||||
field_config_free((input_field_config **)scanfieldptr);
|
field_config_free((input_field_config **)scanfieldptr);
|
||||||
scanfieldnextptr = scanfieldptr;
|
scanfieldnextptr = scanfieldptr;
|
||||||
|
Loading…
Reference in New Issue
Block a user