src/joystick/SDL_joystick_c.h
author Ethan Lee <flibitijibibo@flibitijibibo.com>
Tue, 12 Mar 2019 20:27:54 -0400
changeset 12641 64597a7e8771
parent 12503 806492103856
child 12896 b91647e1a977
permissions -rw-r--r--
hidapi: Add support for Wii U/Switch USB GameCube controller adapter.

Note that a single USB device is responsible for all 4 joysticks, so a large
rewrite of the DeviceDriver functions was necessary to allow a single device to
produce multiple joysticks.
     1 /*
     2   Simple DirectMedia Layer
     3   Copyright (C) 1997-2019 Sam Lantinga <slouken@libsdl.org>
     4 
     5   This software is provided 'as-is', without any express or implied
     6   warranty.  In no event will the authors be held liable for any damages
     7   arising from the use of this software.
     8 
     9   Permission is granted to anyone to use this software for any purpose,
    10   including commercial applications, and to alter it and redistribute it
    11   freely, subject to the following restrictions:
    12 
    13   1. The origin of this software must not be misrepresented; you must not
    14      claim that you wrote the original software. If you use this software
    15      in a product, an acknowledgment in the product documentation would be
    16      appreciated but is not required.
    17   2. Altered source versions must be plainly marked as such, and must not be
    18      misrepresented as being the original software.
    19   3. This notice may not be removed or altered from any source distribution.
    20 */
    21 
    22 #ifndef SDL_joystick_c_h_
    23 #define SDL_joystick_c_h_
    24 
    25 #include "../SDL_internal.h"
    26 
    27 /* Useful functions and variables from SDL_joystick.c */
    28 #include "SDL_joystick.h"
    29 
    30 struct _SDL_JoystickDriver;
    31 
    32 /* Initialization and shutdown functions */
    33 extern int SDL_JoystickInit(void);
    34 extern void SDL_JoystickQuit(void);
    35 
    36 /* Function to get the next available joystick instance ID */
    37 extern SDL_JoystickID SDL_GetNextJoystickInstanceID(void);
    38 
    39 /* Initialization and shutdown functions */
    40 extern int SDL_GameControllerInitMappings(void);
    41 extern void SDL_GameControllerQuitMappings(void);
    42 extern int SDL_GameControllerInit(void);
    43 extern void SDL_GameControllerQuit(void);
    44 
    45 /* Function to get the joystick driver and device index for an API device index */
    46 extern SDL_bool SDL_GetDriverAndJoystickIndex(int device_index, struct _SDL_JoystickDriver **driver, int *driver_index);
    47 
    48 /* Function to return the device index for a joystick ID, or -1 if not found */
    49 extern int SDL_JoystickGetDeviceIndexFromInstanceID(SDL_JoystickID instance_id);
    50 
    51 /* Function to extract information from an SDL joystick GUID */
    52 extern void SDL_GetJoystickGUIDInfo(SDL_JoystickGUID guid, Uint16 *vendor, Uint16 *product, Uint16 *version);
    53 
    54 /* Function to return whether a joystick is a PS4 controller */
    55 extern SDL_bool SDL_IsJoystickPS4(Uint16 vendor_id, Uint16 product_id);
    56 
    57 /* Function to return whether a joystick is a Nintendo Switch Pro controller */
    58 extern SDL_bool SDL_IsJoystickNintendoSwitchPro(Uint16 vendor_id, Uint16 product_id);
    59 
    60 /* Function to return whether a joystick is a Steam Controller */
    61 extern SDL_bool SDL_IsJoystickSteamController(Uint16 vendor_id, Uint16 product_id);
    62 
    63 /* Function to return whether a joystick is an Xbox 360 controller */
    64 extern SDL_bool SDL_IsJoystickXbox360(Uint16 vendor_id, Uint16 product_id);
    65 
    66 /* Function to return whether a joystick is an Xbox One controller */
    67 extern SDL_bool SDL_IsJoystickXboxOne(Uint16 vendor_id, Uint16 product_id);
    68 
    69 /* Function to return whether a joystick is a GameCube controller */
    70 extern SDL_bool SDL_IsJoystickGameCube(Uint16 vendor_id, Uint16 product_id);
    71 
    72 /* Function to return whether a joystick guid comes from the XInput driver */
    73 extern SDL_bool SDL_IsJoystickXInput(SDL_JoystickGUID guid);
    74 
    75 /* Function to return whether a joystick guid comes from the HIDAPI driver */
    76 extern SDL_bool SDL_IsJoystickHIDAPI(SDL_JoystickGUID guid);
    77 
    78 /* Function to return whether a joystick should be ignored */
    79 extern SDL_bool SDL_ShouldIgnoreJoystick(const char *name, SDL_JoystickGUID guid);
    80 
    81 /* Function to return whether a joystick name and GUID is a game controller  */
    82 extern SDL_bool SDL_IsGameControllerNameAndGUID(const char *name, SDL_JoystickGUID guid);
    83 
    84 /* Function to return whether a game controller should be ignored */
    85 extern SDL_bool SDL_ShouldIgnoreGameController(const char *name, SDL_JoystickGUID guid);
    86 
    87 /* Handle delayed guide button on a game controller */
    88 extern void SDL_GameControllerHandleDelayedGuideButton(SDL_Joystick *joystick);
    89 
    90 /* Internal event queueing functions */
    91 extern void SDL_PrivateJoystickAdded(SDL_JoystickID device_instance);
    92 extern void SDL_PrivateJoystickRemoved(SDL_JoystickID device_instance);
    93 extern int SDL_PrivateJoystickAxis(SDL_Joystick * joystick,
    94                                    Uint8 axis, Sint16 value);
    95 extern int SDL_PrivateJoystickBall(SDL_Joystick * joystick,
    96                                    Uint8 ball, Sint16 xrel, Sint16 yrel);
    97 extern int SDL_PrivateJoystickHat(SDL_Joystick * joystick,
    98                                   Uint8 hat, Uint8 value);
    99 extern int SDL_PrivateJoystickButton(SDL_Joystick * joystick,
   100                                      Uint8 button, Uint8 state);
   101 extern void SDL_PrivateJoystickBatteryLevel(SDL_Joystick * joystick,
   102                                             SDL_JoystickPowerLevel ePowerLevel);
   103 
   104 /* Internal sanity checking functions */
   105 extern int SDL_PrivateJoystickValid(SDL_Joystick * joystick);
   106 
   107 #endif /* SDL_joystick_c_h_ */
   108 
   109 /* vi: set ts=4 sw=4 expandtab: */