Skip to content

Commit

Permalink
SDL_vitatouch.c: Fixed the incorrect touch device IDs
Browse files Browse the repository at this point in the history
- Begining of device ID with 0 violates the SDL's specification that means the 0 is an error, invalid, failure, etc. But on Vita here it's an actual device...
- Replacing 0 and 1 with 1 and 2 to resolve this violation.

(cherry picked from commit dd6c663)
  • Loading branch information
Wohlstand authored and slouken committed Aug 14, 2024
1 parent 95aed34 commit 847a6cc
Showing 1 changed file with 2 additions and 2 deletions.
4 changes: 2 additions & 2 deletions src/video/vita/SDL_vitatouch.c
Original file line number Diff line number Diff line change
Expand Up @@ -70,8 +70,8 @@ void VITA_InitTouch(void)
}

// Support passing both front and back touch devices in events
SDL_AddTouch((SDL_TouchID)0, SDL_TOUCH_DEVICE_DIRECT, "Front");
SDL_AddTouch((SDL_TouchID)1, SDL_TOUCH_DEVICE_INDIRECT_ABSOLUTE, "Back");
SDL_AddTouch((SDL_TouchID)1, SDL_TOUCH_DEVICE_DIRECT, "Front");
SDL_AddTouch((SDL_TouchID)2, SDL_TOUCH_DEVICE_INDIRECT_ABSOLUTE, "Back");
}

void VITA_QuitTouch(void)
Expand Down

5 comments on commit 847a6cc

@rsn8887
Copy link

@rsn8887 rsn8887 commented on 847a6cc Nov 10, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Did you test this at all?

It is not enough to make this change only. You also have to send the correct touch_ID:
SDL_SendTouchMotion((SDL_TouchID)port,...

Is wrong, it should be port + 1 there.

@Wohlstand
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Whoops, a good note, I tested the thing on my end, and it worked, but I guess, the thing wasn't properly tested in this case, thanks for this catch!

@xfangfang
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I encountered the same issue, and I think that this commit should not be merged into 2.30.x. After checking with other devices under 2.30.x (such as n3ds), the TouchID still starts from 0.

Is it possible that this is due to a change in SDL3 being mistakenly merged into SDL2?

@slouken
Copy link
Collaborator

@slouken slouken commented on 847a6cc Jan 1, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You are correct, this change was unnecessary on SDL2. I backed out this commit and the original one as well.

@Wohlstand
Copy link
Contributor Author

@Wohlstand Wohlstand commented on 847a6cc Jan 1, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I encountered the same issue, and I think that this commit should not be merged into 2.30.x. After checking with other devices under 2.30.x (such as n3ds), the TouchID still starts from 0.

Is it possible that this is due to a change in SDL3 being mistakenly merged into SDL2?

As was discussed at #9830 and #11441, this change was done in order to resolve the BUG that TouchID 0 by documentation is reserved to use as a report of "invalid device" error, and Vita with 3DS violated this specification, and therefore programs that had verification condition that checks whatever id is valid or not, reports that first touch id is always invalid. Actually, these touch ID should never used as raw integers in the code at all (all the examples showing the obtaining of touch id via SDL_GetTouchDevice() function, and never supposed to just explicitly and manually assign the touch id). This change (and the fix of the imperfection that was done a bit later) should don't cause problems when code uses Touch API properly, it breaks only incorrect uses where touch id assigned by developer manually and was not retrieved from the SDL_GetTouchDevice().

Please sign in to comment.