forked from Dniel97/segatools
Add api versioning to divaio
This commit is contained in:
parent
8dddb18793
commit
a940c0b47b
@ -16,6 +16,11 @@ static HANDLE diva_io_slider_thread;
|
||||
static bool diva_io_slider_stop_flag;
|
||||
static struct diva_io_config diva_io_cfg;
|
||||
|
||||
uint16_t diva_io_get_api_version(void)
|
||||
{
|
||||
return 0x0100;
|
||||
}
|
||||
|
||||
HRESULT diva_io_jvs_init(void)
|
||||
{
|
||||
diva_io_config_load(&diva_io_cfg, L".\\segatools.ini");
|
||||
|
@ -5,13 +5,24 @@
|
||||
#include <stdbool.h>
|
||||
#include <stdint.h>
|
||||
|
||||
/* Get the version of the Project Diva IO API that this DLL supports. This
|
||||
function should return a positive 16-bit integer, where the high byte is
|
||||
the major version and the low byte is the minor version (as defined by the
|
||||
Semantic Versioning standard).
|
||||
|
||||
The latest API version as of this writing is 0x0100. */
|
||||
|
||||
uint16_t diva_io_get_api_version(void);
|
||||
|
||||
/* Initialize JVS-based input. This function will be called before any other
|
||||
diva_io_jvs_*() function calls. Errors returned from this function will
|
||||
manifest as a disconnected JVS bus.
|
||||
|
||||
All subsequent calls may originate from arbitrary threads and some may
|
||||
overlap with each other. Ensuring synchronization inside your IO DLL is
|
||||
your responsibility. */
|
||||
your responsibility.
|
||||
|
||||
Minimum API version: 0x0100 */
|
||||
|
||||
HRESULT diva_io_jvs_init(void);
|
||||
|
||||
@ -22,13 +33,17 @@ HRESULT diva_io_jvs_init(void);
|
||||
|
||||
gamebtn bits, from least significant to most significant, are:
|
||||
|
||||
Circle Cross Square Triangle Start UNUSED UNUSED UNUSED */
|
||||
Circle Cross Square Triangle Start UNUSED UNUSED UNUSED
|
||||
|
||||
Minimum API version: 0x0100 */
|
||||
|
||||
void diva_io_jvs_poll(uint8_t *opbtn, uint8_t *gamebtn);
|
||||
|
||||
/* Read the current state of the coin counter. This value should be incremented
|
||||
for every coin detected by the coin acceptor mechanism. This count does not
|
||||
need to persist beyond the lifetime of the process. */
|
||||
need to persist beyond the lifetime of the process.
|
||||
|
||||
Minimum API Version: 0x0100 */
|
||||
|
||||
void diva_io_jvs_read_coin_counter(uint16_t *out);
|
||||
|
||||
@ -43,7 +58,9 @@ void diva_io_jvs_set_coin_blocker(bool open);
|
||||
|
||||
All subsequent calls may originate from arbitrary threads and some may
|
||||
overlap with each other. Ensuring synchronization inside your IO DLL is
|
||||
your responsibility. */
|
||||
your responsibility.
|
||||
|
||||
Minimum API version: 0x0100 */
|
||||
|
||||
HRESULT diva_io_slider_init(void);
|
||||
|
||||
@ -67,7 +84,9 @@ typedef void (*diva_io_slider_callback_t)(const uint8_t *state);
|
||||
preferred interval then 1 kHz is a reasonable maximum frequency.
|
||||
|
||||
Note that you do have to have to call the callback "occasionally" even if
|
||||
nothing is changing, otherwise the game will raise a comm timeout error. */
|
||||
nothing is changing, otherwise the game will raise a comm timeout error.
|
||||
|
||||
Minimum API version: 0x0100 */
|
||||
|
||||
void diva_io_slider_start(diva_io_slider_callback_t callback);
|
||||
|
||||
@ -80,11 +99,15 @@ void diva_io_slider_start(diva_io_slider_callback_t callback);
|
||||
|
||||
Following on from the above, the slider polling loop *will* be restarted
|
||||
after being stopped in the course of regular operation. Do not permanently
|
||||
tear down your input driver in response to this function call. */
|
||||
tear down your input driver in response to this function call.
|
||||
|
||||
Minimum API version: 0x0100 */
|
||||
|
||||
void diva_io_slider_stop(void);
|
||||
|
||||
/* Update the RGB lighting on the slider. A pointer to an array of 32 * 3 = 96
|
||||
bytes is supplied. Layout is probably strictly linear but still TBD. */
|
||||
bytes is supplied. Layout is probably strictly linear but still TBD.
|
||||
|
||||
Minimum API version: 0x0100 */
|
||||
|
||||
void diva_io_slider_set_leds(const uint8_t *rgb);
|
||||
|
Loading…
Reference in New Issue
Block a user