sdlHidSendFeatureReport function

int sdlHidSendFeatureReport(
  1. Pointer<SdlHidDevice> dev,
  2. Pointer<Uint8> data,
  3. int length
)

Send a Feature report to the device.

Feature reports are sent over the Control endpoint as a Set_Report transfer. The first byte of data must contain the Report ID. For devices which only support a single report, this must be set to 0x0. The remaining bytes contain the report data. Since the Report ID is mandatory, calls to SDL_hid_send_feature_report() will always contain one more byte than the report contains. For example, if a hid report is 16 bytes long, 17 bytes must be passed to SDL_hid_send_feature_report(): the Report ID (or 0x0, for devices which do not use numbered reports), followed by the report data (16 bytes). In this example, the length passed in would be 17.

\param dev a device handle returned from SDL_hid_open(). \param data the data to send, including the report number as the first byte. \param length the length in bytes of the data to send, including the report number. \returns the actual number of bytes written and -1 on failure; call SDL_GetError() for more information.

\since This function is available since SDL 3.1.3.

extern SDL_DECLSPEC int SDLCALL SDL_hid_send_feature_report(SDL_hid_device *dev, const unsigned char *data, size_t length)

Implementation

int sdlHidSendFeatureReport(
    Pointer<SdlHidDevice> dev, Pointer<Uint8> data, int length) {
  final sdlHidSendFeatureReportLookupFunction = libSdl3.lookupFunction<
      Int32 Function(
          Pointer<SdlHidDevice> dev, Pointer<Uint8> data, Uint32 length),
      int Function(Pointer<SdlHidDevice> dev, Pointer<Uint8> data,
          int length)>('SDL_hid_send_feature_report');
  return sdlHidSendFeatureReportLookupFunction(dev, data, length);
}