1 /*****************************************************************************/
5 /* Read the joystick on systems that support it */
9 /* (C) 1998-2002 Ullrich von Bassewitz */
11 /* D-70597 Stuttgart */
12 /* EMail: uz@musoftware.de */
15 /* This software is provided 'as-is', without any expressed or implied */
16 /* warranty. In no event will the authors be held liable for any damages */
17 /* arising from the use of this software. */
19 /* Permission is granted to anyone to use this software for any purpose, */
20 /* including commercial applications, and to alter it and redistribute it */
21 /* freely, subject to the following restrictions: */
23 /* 1. The origin of this software must not be misrepresented; you must not */
24 /* claim that you wrote the original software. If you use this software */
25 /* in a product, an acknowledgment in the product documentation would be */
26 /* appreciated but is not required. */
27 /* 2. Altered source versions must be plainly marked as such, and must not */
28 /* be misrepresented as being the original software. */
29 /* 3. This notice may not be removed or altered from any source */
32 /*****************************************************************************/
41 /*****************************************************************************/
43 /*****************************************************************************/
48 #define JOY_ERR_OK 0 /* No error */
49 #define JOY_ERR_NO_DRIVER 1 /* No driver available */
50 #define JOY_ERR_CANNOT_LOAD 2 /* Error loading driver */
51 #define JOY_ERR_INV_DRIVER 3 /* Invalid driver */
52 #define JOY_ERR_NO_DEVICE 4 /* Device (hardware) not found */
54 /* Argument for the joy_read function */
58 /* The following codes are *indices* into the joy_masks array */
65 /* Array of masks used to check the return value of joy_read for a state */
66 extern const unsigned char joy_masks[8];
70 /* Result codes of the function. The actual code is a bitwise or
71 * of one or more of the following values.
74 #if defined(__VIC20__)
76 # define JOY_DOWN 0x04
77 # define JOY_LEFT 0x08
78 # define JOY_RIGHT 0x80
79 # define JOY_FIRE 0x10
82 # define JOY_DOWN 0x02
83 # define JOY_LEFT 0x04
84 # define JOY_RIGHT 0x08
85 # define JOY_FIRE 0x10
91 /*****************************************************************************/
93 /*****************************************************************************/
97 unsigned char __fastcall__ joy_load_driver (const char* driver);
98 /* Load a joystick driver and return an error code */
100 unsigned char __fastcall__ joy_unload (void);
101 /* Unload the currently loaded driver. */
103 unsigned char __fastcall__ joy_count (void);
104 /* Return the number of joysticks supported by the driver */
106 unsigned char __fastcall__ joy_read (unsigned char joystick);
107 /* Read a particular joystick */
111 /* End of joystick.h */