#pragma once #include #include enum { apm3_IO_OPBTN_TEST = 0x01, apm3_IO_OPBTN_SERVICE = 0x02, apm3_IO_OPBTN_COIN = 0x04, }; /* Get the version of the AllS.Net PRAS Multi 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 apm3_io_get_api_version(void); /* Initialize the IO DLL. This is the second function that will be called on your DLL, after apm3_io_get_api_version. All subsequent calls to this API may originate from arbitrary threads. Minimum API version: 0x0100 */ HRESULT apm3_io_init(void); /* Send any queued outputs (of which there are currently none, though this may change in subsequent API versions) and retrieve any new inputs. Minimum API version: 0x0100 */ HRESULT apm3_io_poll(void); /* Get the state of the cabinet's operator buttons as of the last poll. See apm3_IO_OPBTN enum above: this contains bit mask definitions for button states returned in *opbtn. All buttons are active-high. Minimum API version: 0x0100 */ void apm3_io_get_opbtns(uint8_t *opbtn); /* Initialize LED emulation. This function will be called before any other apm3_io_led_*() function calls. All subsequent calls may originate from arbitrary threads and some may overlap with each other. Ensuring synchronization inside your IO DLL is your responsibility. Minimum API version: 0x0101 */ HRESULT apm3_io_led_init(void);