sdlPutAudioStreamData function

bool sdlPutAudioStreamData(
  1. Pointer<SdlAudioStream> stream,
  2. Pointer<NativeType> buf,
  3. int len
)

Add data to the stream.

This data must match the format/channels/samplerate specified in the latest call to SDL_SetAudioStreamFormat, or the format specified when creating the stream if it hasn't been changed.

Note that this call simply copies the unconverted data for later. This is different than SDL2, where data was converted during the Put call and the Get call would just dequeue the previously-converted data.

\param stream the stream the audio data is being added to. \param buf a pointer to the audio data to add. \param len the number of bytes to write to the stream. \returns true on success or false on failure; call SDL_GetError() for more information.

\threadsafety It is safe to call this function from any thread, but if the stream has a callback set, the caller might need to manage extra locking.

\since This function is available since SDL 3.1.3.

\sa SDL_ClearAudioStream \sa SDL_FlushAudioStream \sa SDL_GetAudioStreamData \sa SDL_GetAudioStreamQueued

extern SDL_DECLSPEC bool SDLCALL SDL_PutAudioStreamData(SDL_AudioStream *stream, const void *buf, int len)

Implementation

bool sdlPutAudioStreamData(
    Pointer<SdlAudioStream> stream, Pointer<NativeType> buf, int len) {
  final sdlPutAudioStreamDataLookupFunction = libSdl3.lookupFunction<
      Uint8 Function(
          Pointer<SdlAudioStream> stream, Pointer<NativeType> buf, Int32 len),
      int Function(Pointer<SdlAudioStream> stream, Pointer<NativeType> buf,
          int len)>('SDL_PutAudioStreamData');
  return sdlPutAudioStreamDataLookupFunction(stream, buf, len) == 1;
}