# HG changeset patch # User Sam Lantinga # Date 1198957509 0 # Node ID 15a242fca6c420612a30abaa6d89f606438fb5f3 # Parent 41a6675d8700c042adc49c5bd41f30fcc1011706 Fixed bug #478 Take the min and max values into account. diff -r 41a6675d8700 -r 15a242fca6c4 src/joystick/darwin/SDL_sysjoystick.c --- a/src/joystick/darwin/SDL_sysjoystick.c Sat Dec 29 19:29:20 2007 +0000 +++ b/src/joystick/darwin/SDL_sysjoystick.c Sat Dec 29 19:45:09 2007 +0000 @@ -770,7 +770,7 @@ { recDevice *device = joystick->hwdata; recElement *element; - SInt32 value; + SInt32 value, range; int i; if (device->removed) { /* device was unplugged; ignore it. */ @@ -818,10 +818,11 @@ while (element) { Uint8 pos = 0; - value = HIDGetElementValue(device, element); - if (element->max == 3) /* 4 position hatswitch - scale up value */ + range = (element->max - element->min + 1); + value = HIDGetElementValue(device, element) - element->min; + if (range == 4) /* 4 position hatswitch - scale up value */ value *= 2; - else if (element->max != 7) /* Neither a 4 nor 8 positions - fall back to default position (centered) */ + else if (range != 8) /* Neither a 4 nor 8 positions - fall back to default position (centered) */ value = -1; switch (value) { case 0: