2015-06-21 09:33:46 -06:00
|
|
|
/*
|
2024-01-01 14:15:26 -07:00
|
|
|
Copyright (C) 1997-2024 Sam Lantinga <slouken@libsdl.org>
|
2015-06-21 09:33:46 -06:00
|
|
|
|
|
|
|
This software is provided 'as-is', without any express or implied
|
|
|
|
warranty. In no event will the authors be held liable for any damages
|
|
|
|
arising from the use of this software.
|
|
|
|
|
|
|
|
Permission is granted to anyone to use this software for any purpose,
|
|
|
|
including commercial applications, and to alter it and redistribute it
|
|
|
|
freely.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* Simple program to test the SDL joystick hotplugging */
|
|
|
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
2022-11-26 21:43:38 -07:00
|
|
|
#include <SDL3/SDL.h>
|
2022-12-14 21:58:20 -07:00
|
|
|
#include <SDL3/SDL_main.h>
|
2023-03-16 17:25:39 -06:00
|
|
|
#include <SDL3/SDL_test.h>
|
2015-06-21 09:33:46 -06:00
|
|
|
|
2022-11-30 13:51:59 -07:00
|
|
|
int main(int argc, char *argv[])
|
2015-06-21 09:33:46 -06:00
|
|
|
{
|
2022-12-27 19:10:06 -07:00
|
|
|
int num_joysticks = 0;
|
2015-06-21 09:33:46 -06:00
|
|
|
SDL_Joystick *joystick = NULL;
|
|
|
|
SDL_Haptic *haptic = NULL;
|
2022-12-27 19:10:06 -07:00
|
|
|
SDL_JoystickID instance = 0;
|
2015-06-21 09:33:46 -06:00
|
|
|
SDL_bool keepGoing = SDL_TRUE;
|
|
|
|
int i;
|
|
|
|
SDL_bool enable_haptic = SDL_TRUE;
|
|
|
|
Uint32 init_subsystems = SDL_INIT_VIDEO | SDL_INIT_JOYSTICK;
|
2023-03-16 17:25:39 -06:00
|
|
|
SDLTest_CommonState *state;
|
2022-11-30 13:51:59 -07:00
|
|
|
|
2023-03-16 17:25:39 -06:00
|
|
|
/* Initialize test framework */
|
|
|
|
state = SDLTest_CommonCreateState(argv, 0);
|
2023-11-09 14:29:15 -07:00
|
|
|
if (!state) {
|
2023-03-16 17:25:39 -06:00
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Enable standard application logging */
|
|
|
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
|
|
|
|
|
|
|
/* Parse commandline */
|
|
|
|
for (i = 1; i < argc;) {
|
|
|
|
int consumed;
|
|
|
|
|
|
|
|
consumed = SDLTest_CommonArg(state, i);
|
|
|
|
if (!consumed) {
|
|
|
|
if (SDL_strcasecmp(argv[i], "--nohaptic") == 0) {
|
|
|
|
enable_haptic = SDL_FALSE;
|
|
|
|
consumed = 1;
|
|
|
|
}
|
2015-06-21 09:33:46 -06:00
|
|
|
}
|
2023-03-16 17:25:39 -06:00
|
|
|
if (consumed <= 0) {
|
|
|
|
static const char *options[] = { "[--nohaptic]", NULL };
|
|
|
|
SDLTest_CommonLogUsage(state, argv[0], options);
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
i += consumed;
|
2015-06-21 09:33:46 -06:00
|
|
|
}
|
|
|
|
|
2022-11-27 09:38:43 -07:00
|
|
|
if (enable_haptic) {
|
2015-06-21 09:33:46 -06:00
|
|
|
init_subsystems |= SDL_INIT_HAPTIC;
|
|
|
|
}
|
2022-11-30 13:51:59 -07:00
|
|
|
|
2015-06-21 09:33:46 -06:00
|
|
|
/* Enable standard application logging */
|
2015-11-25 13:39:28 -07:00
|
|
|
SDL_LogSetPriority(SDL_LOG_CATEGORY_APPLICATION, SDL_LOG_PRIORITY_INFO);
|
2015-06-21 09:33:46 -06:00
|
|
|
|
|
|
|
SDL_SetHint(SDL_HINT_JOYSTICK_ALLOW_BACKGROUND_EVENTS, "1");
|
|
|
|
|
|
|
|
/* Initialize SDL (Note: video is required to start event loop) */
|
|
|
|
if (SDL_Init(init_subsystems) < 0) {
|
|
|
|
SDL_LogError(SDL_LOG_CATEGORY_APPLICATION, "Couldn't initialize SDL: %s\n", SDL_GetError());
|
|
|
|
exit(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
2023-03-05 15:44:38 -07:00
|
|
|
//SDL_CreateWindow("Dummy", 128, 128, 0);
|
2015-06-21 09:33:46 -06:00
|
|
|
*/
|
|
|
|
|
2022-12-27 19:10:06 -07:00
|
|
|
SDL_free(SDL_GetJoysticks(&num_joysticks));
|
|
|
|
SDL_Log("There are %d joysticks at startup\n", num_joysticks);
|
2022-11-27 09:38:43 -07:00
|
|
|
if (enable_haptic) {
|
2024-01-17 16:22:35 -07:00
|
|
|
int num_haptics;
|
|
|
|
SDL_HapticID *haptics = SDL_GetHaptics(&num_haptics);
|
|
|
|
SDL_free(haptics);
|
|
|
|
SDL_Log("There are %d haptic devices at startup\n", num_haptics);
|
2022-11-27 09:38:43 -07:00
|
|
|
}
|
2015-06-21 09:33:46 -06:00
|
|
|
|
2022-11-27 09:38:43 -07:00
|
|
|
while (keepGoing) {
|
2015-06-21 09:33:46 -06:00
|
|
|
SDL_Event event;
|
2022-11-27 09:38:43 -07:00
|
|
|
while (SDL_PollEvent(&event)) {
|
2022-11-30 13:51:59 -07:00
|
|
|
switch (event.type) {
|
2023-01-23 18:54:09 -07:00
|
|
|
case SDL_EVENT_QUIT:
|
2022-11-30 13:51:59 -07:00
|
|
|
keepGoing = SDL_FALSE;
|
|
|
|
break;
|
2023-01-23 18:54:09 -07:00
|
|
|
case SDL_EVENT_JOYSTICK_ADDED:
|
2023-11-09 14:29:15 -07:00
|
|
|
if (joystick) {
|
2022-11-30 13:51:59 -07:00
|
|
|
SDL_Log("Only one joystick supported by this test\n");
|
|
|
|
} else {
|
2022-12-27 06:50:46 -07:00
|
|
|
joystick = SDL_OpenJoystick(event.jdevice.which);
|
2022-12-27 19:10:06 -07:00
|
|
|
instance = event.jdevice.which;
|
|
|
|
SDL_Log("Joy Added : %" SDL_PRIu32 " : %s\n", event.jdevice.which, SDL_GetJoystickName(joystick));
|
2022-11-30 13:51:59 -07:00
|
|
|
if (enable_haptic) {
|
2024-01-17 16:22:35 -07:00
|
|
|
if (SDL_IsJoystickHaptic(joystick)) {
|
|
|
|
haptic = SDL_OpenHapticFromJoystick(joystick);
|
2022-11-30 13:51:59 -07:00
|
|
|
if (haptic) {
|
|
|
|
SDL_Log("Joy Haptic Opened\n");
|
2024-01-17 16:22:35 -07:00
|
|
|
if (SDL_InitHapticRumble(haptic) != 0) {
|
2022-11-30 13:51:59 -07:00
|
|
|
SDL_Log("Could not init Rumble!: %s\n", SDL_GetError());
|
2024-01-17 16:22:35 -07:00
|
|
|
SDL_CloseHaptic(haptic);
|
2022-11-30 13:51:59 -07:00
|
|
|
haptic = NULL;
|
2015-06-21 09:33:46 -06:00
|
|
|
}
|
2022-11-27 09:38:43 -07:00
|
|
|
} else {
|
2022-11-30 13:51:59 -07:00
|
|
|
SDL_Log("Joy haptic open FAILED!: %s\n", SDL_GetError());
|
2015-06-21 09:33:46 -06:00
|
|
|
}
|
2022-11-30 13:51:59 -07:00
|
|
|
} else {
|
|
|
|
SDL_Log("No haptic found\n");
|
2015-06-21 09:33:46 -06:00
|
|
|
}
|
|
|
|
}
|
2022-11-30 13:51:59 -07:00
|
|
|
}
|
|
|
|
break;
|
2023-01-23 18:54:09 -07:00
|
|
|
case SDL_EVENT_JOYSTICK_REMOVED:
|
2022-11-30 13:51:59 -07:00
|
|
|
if (instance == event.jdevice.which) {
|
|
|
|
SDL_Log("Joy Removed: %" SDL_PRIs32 "\n", event.jdevice.which);
|
2022-12-27 19:10:06 -07:00
|
|
|
instance = 0;
|
2022-11-27 09:38:43 -07:00
|
|
|
if (enable_haptic && haptic) {
|
2024-01-17 16:22:35 -07:00
|
|
|
SDL_CloseHaptic(haptic);
|
2022-11-30 13:51:59 -07:00
|
|
|
haptic = NULL;
|
2015-11-25 13:39:28 -07:00
|
|
|
}
|
2022-12-27 06:50:46 -07:00
|
|
|
SDL_CloseJoystick(joystick);
|
2022-11-30 13:51:59 -07:00
|
|
|
joystick = NULL;
|
|
|
|
} else {
|
2023-07-03 09:29:42 -06:00
|
|
|
SDL_Log("Unknown joystick disconnected\n");
|
2022-11-30 13:51:59 -07:00
|
|
|
}
|
|
|
|
break;
|
2023-01-23 18:54:09 -07:00
|
|
|
case SDL_EVENT_JOYSTICK_AXIS_MOTION:
|
2022-11-30 13:51:59 -07:00
|
|
|
/*
|
|
|
|
// SDL_Log("Axis Move: %d\n", event.jaxis.axis);
|
|
|
|
*/
|
|
|
|
if (enable_haptic) {
|
2024-01-17 16:22:35 -07:00
|
|
|
SDL_PlayHapticRumble(haptic, 0.25, 250);
|
2022-11-30 13:51:59 -07:00
|
|
|
}
|
|
|
|
break;
|
2023-01-23 18:54:09 -07:00
|
|
|
case SDL_EVENT_JOYSTICK_BUTTON_DOWN:
|
2022-11-30 13:51:59 -07:00
|
|
|
SDL_Log("Button Press: %d\n", event.jbutton.button);
|
|
|
|
if (enable_haptic && haptic) {
|
2024-01-17 16:22:35 -07:00
|
|
|
SDL_PlayHapticRumble(haptic, 0.25, 250);
|
2022-11-30 13:51:59 -07:00
|
|
|
}
|
|
|
|
if (event.jbutton.button == 0) {
|
|
|
|
SDL_Log("Exiting due to button press of button 0\n");
|
|
|
|
keepGoing = SDL_FALSE;
|
|
|
|
}
|
|
|
|
break;
|
2023-01-23 18:54:09 -07:00
|
|
|
case SDL_EVENT_JOYSTICK_BUTTON_UP:
|
2022-11-30 13:51:59 -07:00
|
|
|
SDL_Log("Button Release: %d\n", event.jbutton.button);
|
|
|
|
break;
|
2015-06-21 09:33:46 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
SDL_Quit();
|
2023-03-16 17:25:39 -06:00
|
|
|
SDLTest_CommonDestroyState(state);
|
2015-06-21 09:33:46 -06:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|