mirror of
https://github.com/Ryujinx/libsoundio.git
synced 2025-01-05 18:45:41 +00:00
rename purpose to aim
This commit is contained in:
parent
4ba1fd91a1
commit
e6112b40ed
14
README.md
14
README.md
|
@ -245,17 +245,10 @@ view `coverage/index.html` in a browser.
|
||||||
0. implement WASAPI (Windows) backend, get examples working
|
0. implement WASAPI (Windows) backend, get examples working
|
||||||
0. implement ASIO (Windows) backend, get examples working
|
0. implement ASIO (Windows) backend, get examples working
|
||||||
0. Integrate into libgroove and test with Groove Basin
|
0. Integrate into libgroove and test with Groove Basin
|
||||||
0. PulseAudio: when prebuf gets set to 0 need to pass `PA_STREAM_START_CORKED`.
|
|
||||||
0. clear buffer maybe could take an argument to say how many frames to not clear
|
0. clear buffer maybe could take an argument to say how many frames to not clear
|
||||||
0. In ALSA do we need to wake up the poll when destroying the in or out stream?
|
|
||||||
0. Verify that JACK xrun callback context is the same as process callback.
|
0. Verify that JACK xrun callback context is the same as process callback.
|
||||||
If not, might need to hav xrun callback set a flag and have process callback
|
If not, might need to hav xrun callback set a flag and have process callback
|
||||||
call the underflow callback.
|
call the underflow callback.
|
||||||
0. In PulseAudio, to get buffer duration and period duration, fill the buffer
|
|
||||||
with silence before starting, start the stream corked, and have the
|
|
||||||
callback be a callback that just provides silence. Once
|
|
||||||
`soundio_outstream_start` is called, switch to the real callback, then call
|
|
||||||
`pa_stream_flush`, then uncork the stream.
|
|
||||||
0. API: devices should reference to their "other" device when the same
|
0. API: devices should reference to their "other" device when the same
|
||||||
hardware has input and output. This is important due to clock timing.
|
hardware has input and output. This is important due to clock timing.
|
||||||
0. Detect PulseAudio server going offline and emit `on_backend_disconnect`.
|
0. Detect PulseAudio server going offline and emit `on_backend_disconnect`.
|
||||||
|
@ -294,6 +287,13 @@ view `coverage/index.html` in a browser.
|
||||||
0. write detailed docs on buffer underflows explaining when they occur, what state
|
0. write detailed docs on buffer underflows explaining when they occur, what state
|
||||||
changes are related to them, and how to recover from them.
|
changes are related to them, and how to recover from them.
|
||||||
0. Consider testing on FreeBSD
|
0. Consider testing on FreeBSD
|
||||||
|
0. PulseAudio idea: when prebuf gets set to 0 need to pass `PA_STREAM_START_CORKED`.
|
||||||
|
In PulseAudio, to get buffer duration and period duration, fill the buffer
|
||||||
|
with silence before starting, start the stream corked, and have the
|
||||||
|
callback be a callback that just provides silence. Once
|
||||||
|
`soundio_outstream_start` is called, switch to the real callback, then call
|
||||||
|
`pa_stream_flush`, then uncork the stream.
|
||||||
|
0. In ALSA do we need to wake up the poll when destroying the in or out stream?
|
||||||
|
|
||||||
## Planned Uses for libsoundio
|
## Planned Uses for libsoundio
|
||||||
|
|
||||||
|
|
24
src/alsa.cpp
24
src/alsa.cpp
|
@ -68,12 +68,12 @@ static char * str_partition_on_char(char *str, char c) {
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
static snd_pcm_stream_t purpose_to_stream(SoundIoDevicePurpose purpose) {
|
static snd_pcm_stream_t aim_to_stream(SoundIoDeviceAim aim) {
|
||||||
switch (purpose) {
|
switch (aim) {
|
||||||
case SoundIoDevicePurposeOutput: return SND_PCM_STREAM_PLAYBACK;
|
case SoundIoDeviceAimOutput: return SND_PCM_STREAM_PLAYBACK;
|
||||||
case SoundIoDevicePurposeInput: return SND_PCM_STREAM_CAPTURE;
|
case SoundIoDeviceAimInput: return SND_PCM_STREAM_CAPTURE;
|
||||||
}
|
}
|
||||||
assert(0); // Invalid purpose
|
assert(0); // Invalid aim
|
||||||
return SND_PCM_STREAM_PLAYBACK;
|
return SND_PCM_STREAM_PLAYBACK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -382,7 +382,7 @@ static int probe_device(SoundIoDevice *device, snd_pcm_chmap_query_t **maps) {
|
||||||
int err;
|
int err;
|
||||||
snd_pcm_t *handle;
|
snd_pcm_t *handle;
|
||||||
|
|
||||||
snd_pcm_stream_t stream = purpose_to_stream(device->purpose);
|
snd_pcm_stream_t stream = aim_to_stream(device->aim);
|
||||||
|
|
||||||
if ((err = snd_pcm_open(&handle, device->id, stream, 0)) < 0) {
|
if ((err = snd_pcm_open(&handle, device->id, stream, 0)) < 0) {
|
||||||
handle_channel_maps(device, maps);
|
handle_channel_maps(device, maps);
|
||||||
|
@ -558,13 +558,13 @@ static int refresh_devices(SoundIoPrivate *si) {
|
||||||
SoundIoList<SoundIoDevice *> *device_list;
|
SoundIoList<SoundIoDevice *> *device_list;
|
||||||
bool is_default = str_has_prefix(name, "default:") || strcmp(name, "default") == 0;
|
bool is_default = str_has_prefix(name, "default:") || strcmp(name, "default") == 0;
|
||||||
if (stream == SND_PCM_STREAM_PLAYBACK) {
|
if (stream == SND_PCM_STREAM_PLAYBACK) {
|
||||||
device->purpose = SoundIoDevicePurposeOutput;
|
device->aim = SoundIoDeviceAimOutput;
|
||||||
device_list = &devices_info->output_devices;
|
device_list = &devices_info->output_devices;
|
||||||
if (devices_info->default_output_index < 0 && is_default)
|
if (devices_info->default_output_index < 0 && is_default)
|
||||||
devices_info->default_output_index = device_list->length;
|
devices_info->default_output_index = device_list->length;
|
||||||
} else {
|
} else {
|
||||||
assert(stream == SND_PCM_STREAM_CAPTURE);
|
assert(stream == SND_PCM_STREAM_CAPTURE);
|
||||||
device->purpose = SoundIoDevicePurposeInput;
|
device->aim = SoundIoDeviceAimInput;
|
||||||
device_list = &devices_info->input_devices;
|
device_list = &devices_info->input_devices;
|
||||||
if (devices_info->default_input_index < 0 && is_default)
|
if (devices_info->default_input_index < 0 && is_default)
|
||||||
devices_info->default_input_index = device_list->length;
|
devices_info->default_input_index = device_list->length;
|
||||||
|
@ -671,11 +671,11 @@ static int refresh_devices(SoundIoPrivate *si) {
|
||||||
|
|
||||||
SoundIoList<SoundIoDevice *> *device_list;
|
SoundIoList<SoundIoDevice *> *device_list;
|
||||||
if (stream == SND_PCM_STREAM_PLAYBACK) {
|
if (stream == SND_PCM_STREAM_PLAYBACK) {
|
||||||
device->purpose = SoundIoDevicePurposeOutput;
|
device->aim = SoundIoDeviceAimOutput;
|
||||||
device_list = &devices_info->output_devices;
|
device_list = &devices_info->output_devices;
|
||||||
} else {
|
} else {
|
||||||
assert(stream == SND_PCM_STREAM_CAPTURE);
|
assert(stream == SND_PCM_STREAM_CAPTURE);
|
||||||
device->purpose = SoundIoDevicePurposeInput;
|
device->aim = SoundIoDeviceAimInput;
|
||||||
device_list = &devices_info->input_devices;
|
device_list = &devices_info->input_devices;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1122,7 +1122,7 @@ static int outstream_open_alsa(SoundIoPrivate *si, SoundIoOutStreamPrivate *os)
|
||||||
snd_pcm_hw_params_t *hwparams;
|
snd_pcm_hw_params_t *hwparams;
|
||||||
snd_pcm_hw_params_alloca(&hwparams);
|
snd_pcm_hw_params_alloca(&hwparams);
|
||||||
|
|
||||||
snd_pcm_stream_t stream = purpose_to_stream(outstream->device->purpose);
|
snd_pcm_stream_t stream = aim_to_stream(outstream->device->aim);
|
||||||
|
|
||||||
if ((err = snd_pcm_open(&osa->handle, outstream->device->id, stream, 0)) < 0) {
|
if ((err = snd_pcm_open(&osa->handle, outstream->device->id, stream, 0)) < 0) {
|
||||||
outstream_destroy_alsa(si, os);
|
outstream_destroy_alsa(si, os);
|
||||||
|
@ -1409,7 +1409,7 @@ static int instream_open_alsa(SoundIoPrivate *si, SoundIoInStreamPrivate *is) {
|
||||||
snd_pcm_hw_params_t *hwparams;
|
snd_pcm_hw_params_t *hwparams;
|
||||||
snd_pcm_hw_params_alloca(&hwparams);
|
snd_pcm_hw_params_alloca(&hwparams);
|
||||||
|
|
||||||
snd_pcm_stream_t stream = purpose_to_stream(instream->device->purpose);
|
snd_pcm_stream_t stream = aim_to_stream(instream->device->aim);
|
||||||
|
|
||||||
if ((err = snd_pcm_open(&isa->handle, instream->device->id, stream, 0)) < 0) {
|
if ((err = snd_pcm_open(&isa->handle, instream->device->id, stream, 0)) < 0) {
|
||||||
instream_destroy_alsa(si, is);
|
instream_destroy_alsa(si, is);
|
||||||
|
|
|
@ -448,7 +448,7 @@ int soundio_dummy_init(SoundIoPrivate *si) {
|
||||||
device->period_duration_min = 0.01;
|
device->period_duration_min = 0.01;
|
||||||
device->period_duration_max = 2;
|
device->period_duration_max = 2;
|
||||||
device->period_duration_current = 0.05;
|
device->period_duration_current = 0.05;
|
||||||
device->purpose = SoundIoDevicePurposeOutput;
|
device->aim = SoundIoDeviceAimOutput;
|
||||||
|
|
||||||
if (si->safe_devices_info->output_devices.append(device)) {
|
if (si->safe_devices_info->output_devices.append(device)) {
|
||||||
soundio_device_unref(device);
|
soundio_device_unref(device);
|
||||||
|
@ -497,7 +497,7 @@ int soundio_dummy_init(SoundIoPrivate *si) {
|
||||||
device->period_duration_min = 0.01;
|
device->period_duration_min = 0.01;
|
||||||
device->period_duration_max = 2;
|
device->period_duration_max = 2;
|
||||||
device->period_duration_current = 0.05;
|
device->period_duration_current = 0.05;
|
||||||
device->purpose = SoundIoDevicePurposeInput;
|
device->aim = SoundIoDeviceAimInput;
|
||||||
|
|
||||||
if (si->safe_devices_info->input_devices.append(device)) {
|
if (si->safe_devices_info->input_devices.append(device)) {
|
||||||
soundio_device_unref(device);
|
soundio_device_unref(device);
|
||||||
|
|
22
src/jack.cpp
22
src/jack.cpp
|
@ -26,7 +26,7 @@ struct SoundIoJackClient {
|
||||||
const char *name;
|
const char *name;
|
||||||
int name_len;
|
int name_len;
|
||||||
bool is_physical;
|
bool is_physical;
|
||||||
SoundIoDevicePurpose purpose;
|
SoundIoDeviceAim aim;
|
||||||
int port_count;
|
int port_count;
|
||||||
SoundIoJackPort ports[SOUNDIO_MAX_CHANNELS];
|
SoundIoJackPort ports[SOUNDIO_MAX_CHANNELS];
|
||||||
};
|
};
|
||||||
|
@ -47,12 +47,12 @@ static void split_str(const char *input_str, int input_str_len, char c,
|
||||||
}
|
}
|
||||||
|
|
||||||
static SoundIoJackClient *find_or_create_client(SoundIoList<SoundIoJackClient> *clients,
|
static SoundIoJackClient *find_or_create_client(SoundIoList<SoundIoJackClient> *clients,
|
||||||
SoundIoDevicePurpose purpose, bool is_physical, const char *client_name, int client_name_len)
|
SoundIoDeviceAim aim, bool is_physical, const char *client_name, int client_name_len)
|
||||||
{
|
{
|
||||||
for (int i = 0; i < clients->length; i += 1) {
|
for (int i = 0; i < clients->length; i += 1) {
|
||||||
SoundIoJackClient *client = &clients->at(i);
|
SoundIoJackClient *client = &clients->at(i);
|
||||||
if (client->is_physical == is_physical &&
|
if (client->is_physical == is_physical &&
|
||||||
client->purpose == purpose &&
|
client->aim == aim &&
|
||||||
soundio_streql(client->name, client->name_len, client_name, client_name_len))
|
soundio_streql(client->name, client->name_len, client_name, client_name_len))
|
||||||
{
|
{
|
||||||
return client;
|
return client;
|
||||||
|
@ -63,7 +63,7 @@ static SoundIoJackClient *find_or_create_client(SoundIoList<SoundIoJackClient> *
|
||||||
return nullptr;
|
return nullptr;
|
||||||
SoundIoJackClient *client = &clients->last();
|
SoundIoJackClient *client = &clients->last();
|
||||||
client->is_physical = is_physical;
|
client->is_physical = is_physical;
|
||||||
client->purpose = purpose;
|
client->aim = aim;
|
||||||
client->name = client_name;
|
client->name = client_name;
|
||||||
client->name_len = client_name_len;
|
client->name_len = client_name_len;
|
||||||
client->port_count = 0;
|
client->port_count = 0;
|
||||||
|
@ -129,8 +129,8 @@ static int refresh_devices_bare(SoundIoPrivate *si) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
SoundIoDevicePurpose purpose = (flags & JackPortIsInput) ?
|
SoundIoDeviceAim aim = (flags & JackPortIsInput) ?
|
||||||
SoundIoDevicePurposeOutput : SoundIoDevicePurposeInput;
|
SoundIoDeviceAimOutput : SoundIoDeviceAimInput;
|
||||||
bool is_physical = flags & JackPortIsPhysical;
|
bool is_physical = flags & JackPortIsPhysical;
|
||||||
|
|
||||||
const char *client_name = nullptr;
|
const char *client_name = nullptr;
|
||||||
|
@ -143,7 +143,7 @@ static int refresh_devices_bare(SoundIoPrivate *si) {
|
||||||
// device does not have colon, skip it
|
// device does not have colon, skip it
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
SoundIoJackClient *client = find_or_create_client(&clients, purpose, is_physical,
|
SoundIoJackClient *client = find_or_create_client(&clients, aim, is_physical,
|
||||||
client_name, client_name_len);
|
client_name, client_name_len);
|
||||||
if (!client) {
|
if (!client) {
|
||||||
jack_free(port_names);
|
jack_free(port_names);
|
||||||
|
@ -161,7 +161,7 @@ static int refresh_devices_bare(SoundIoPrivate *si) {
|
||||||
port->name_len = port_name_len;
|
port->name_len = port_name_len;
|
||||||
port->channel_id = soundio_parse_channel_id(port_name, port_name_len);
|
port->channel_id = soundio_parse_channel_id(port_name, port_name_len);
|
||||||
|
|
||||||
jack_latency_callback_mode_t latency_mode = (purpose == SoundIoDevicePurposeOutput) ?
|
jack_latency_callback_mode_t latency_mode = (aim == SoundIoDeviceAimOutput) ?
|
||||||
JackPlaybackLatency : JackCaptureLatency;
|
JackPlaybackLatency : JackCaptureLatency;
|
||||||
jack_port_get_latency_range(jport, latency_mode, &port->latency_range);
|
jack_port_get_latency_range(jport, latency_mode, &port->latency_range);
|
||||||
|
|
||||||
|
@ -193,7 +193,7 @@ static int refresh_devices_bare(SoundIoPrivate *si) {
|
||||||
device->ref_count = 1;
|
device->ref_count = 1;
|
||||||
device->soundio = soundio;
|
device->soundio = soundio;
|
||||||
device->is_raw = false;
|
device->is_raw = false;
|
||||||
device->purpose = client->purpose;
|
device->aim = client->aim;
|
||||||
device->id = dupe_str(client->name, client->name_len);
|
device->id = dupe_str(client->name, client->name_len);
|
||||||
device->name = allocate<char>(description_len);
|
device->name = allocate<char>(description_len);
|
||||||
device->layout_count = 1;
|
device->layout_count = 1;
|
||||||
|
@ -267,12 +267,12 @@ static int refresh_devices_bare(SoundIoPrivate *si) {
|
||||||
device->formats[0] = device->current_format;
|
device->formats[0] = device->current_format;
|
||||||
|
|
||||||
SoundIoList<SoundIoDevice *> *device_list;
|
SoundIoList<SoundIoDevice *> *device_list;
|
||||||
if (device->purpose == SoundIoDevicePurposeOutput) {
|
if (device->aim == SoundIoDeviceAimOutput) {
|
||||||
device_list = &devices_info->output_devices;
|
device_list = &devices_info->output_devices;
|
||||||
if (devices_info->default_output_index < 0 && client->is_physical)
|
if (devices_info->default_output_index < 0 && client->is_physical)
|
||||||
devices_info->default_output_index = device_list->length;
|
devices_info->default_output_index = device_list->length;
|
||||||
} else {
|
} else {
|
||||||
assert(device->purpose == SoundIoDevicePurposeInput);
|
assert(device->aim == SoundIoDeviceAimInput);
|
||||||
device_list = &devices_info->input_devices;
|
device_list = &devices_info->input_devices;
|
||||||
if (devices_info->default_input_index < 0 && client->is_physical)
|
if (devices_info->default_input_index < 0 && client->is_physical)
|
||||||
devices_info->default_input_index = device_list->length;
|
devices_info->default_input_index = device_list->length;
|
||||||
|
|
|
@ -220,7 +220,7 @@ static void finish_device_query(SoundIoPrivate *si) {
|
||||||
sipa->current_devices_info->default_input_index = 0;
|
sipa->current_devices_info->default_input_index = 0;
|
||||||
for (int i = 0; i < sipa->current_devices_info->input_devices.length; i += 1) {
|
for (int i = 0; i < sipa->current_devices_info->input_devices.length; i += 1) {
|
||||||
SoundIoDevice *device = sipa->current_devices_info->input_devices.at(i);
|
SoundIoDevice *device = sipa->current_devices_info->input_devices.at(i);
|
||||||
assert(device->purpose == SoundIoDevicePurposeInput);
|
assert(device->aim == SoundIoDeviceAimInput);
|
||||||
if (strcmp(device->id, sipa->default_source_name) == 0) {
|
if (strcmp(device->id, sipa->default_source_name) == 0) {
|
||||||
sipa->current_devices_info->default_input_index = i;
|
sipa->current_devices_info->default_input_index = i;
|
||||||
}
|
}
|
||||||
|
@ -231,7 +231,7 @@ static void finish_device_query(SoundIoPrivate *si) {
|
||||||
sipa->current_devices_info->default_output_index = 0;
|
sipa->current_devices_info->default_output_index = 0;
|
||||||
for (int i = 0; i < sipa->current_devices_info->output_devices.length; i += 1) {
|
for (int i = 0; i < sipa->current_devices_info->output_devices.length; i += 1) {
|
||||||
SoundIoDevice *device = sipa->current_devices_info->output_devices.at(i);
|
SoundIoDevice *device = sipa->current_devices_info->output_devices.at(i);
|
||||||
assert(device->purpose == SoundIoDevicePurposeOutput);
|
assert(device->aim == SoundIoDeviceAimOutput);
|
||||||
if (strcmp(device->id, sipa->default_sink_name) == 0) {
|
if (strcmp(device->id, sipa->default_sink_name) == 0) {
|
||||||
sipa->current_devices_info->default_output_index = i;
|
sipa->current_devices_info->default_output_index = i;
|
||||||
}
|
}
|
||||||
|
@ -304,7 +304,7 @@ static void sink_info_callback(pa_context *pulse_context, const pa_sink_info *in
|
||||||
|
|
||||||
// "period" is not a recognized concept in PulseAudio.
|
// "period" is not a recognized concept in PulseAudio.
|
||||||
|
|
||||||
device->purpose = SoundIoDevicePurposeOutput;
|
device->aim = SoundIoDeviceAimOutput;
|
||||||
|
|
||||||
if (sipa->current_devices_info->output_devices.append(device)) {
|
if (sipa->current_devices_info->output_devices.append(device)) {
|
||||||
soundio_device_unref(device);
|
soundio_device_unref(device);
|
||||||
|
@ -374,7 +374,7 @@ static void source_info_callback(pa_context *pulse_context, const pa_source_info
|
||||||
|
|
||||||
// "period" is not a recognized concept in PulseAudio.
|
// "period" is not a recognized concept in PulseAudio.
|
||||||
|
|
||||||
device->purpose = SoundIoDevicePurposeInput;
|
device->aim = SoundIoDeviceAimInput;
|
||||||
|
|
||||||
if (sipa->current_devices_info->input_devices.append(device)) {
|
if (sipa->current_devices_info->input_devices.append(device)) {
|
||||||
soundio_device_unref(device);
|
soundio_device_unref(device);
|
||||||
|
|
|
@ -296,10 +296,6 @@ struct SoundIoDevice *soundio_get_output_device(struct SoundIo *soundio, int ind
|
||||||
return device;
|
return device;
|
||||||
}
|
}
|
||||||
|
|
||||||
enum SoundIoDevicePurpose soundio_device_purpose(const struct SoundIoDevice *device) {
|
|
||||||
return device->purpose;
|
|
||||||
}
|
|
||||||
|
|
||||||
void soundio_device_unref(struct SoundIoDevice *device) {
|
void soundio_device_unref(struct SoundIoDevice *device) {
|
||||||
if (!device)
|
if (!device)
|
||||||
return;
|
return;
|
||||||
|
|
|
@ -111,9 +111,9 @@ enum SoundIoBackend {
|
||||||
SoundIoBackendDummy,
|
SoundIoBackendDummy,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum SoundIoDevicePurpose {
|
enum SoundIoDeviceAim {
|
||||||
SoundIoDevicePurposeInput,
|
SoundIoDeviceAimInput,
|
||||||
SoundIoDevicePurposeOutput,
|
SoundIoDeviceAimOutput,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum SoundIoFormat {
|
enum SoundIoFormat {
|
||||||
|
@ -249,6 +249,9 @@ struct SoundIoDevice {
|
||||||
char *id;
|
char *id;
|
||||||
char *name;
|
char *name;
|
||||||
|
|
||||||
|
// Tells whether this device is an input device or an output device.
|
||||||
|
enum SoundIoDeviceAim aim;
|
||||||
|
|
||||||
// Channel layouts are handled similarly to sample format; see those docs.
|
// Channel layouts are handled similarly to sample format; see those docs.
|
||||||
// If this information is missing due to a `probe_error`, `layouts`
|
// If this information is missing due to a `probe_error`, `layouts`
|
||||||
// will be NULL. It's OK to modify this data, for example calling
|
// will be NULL. It's OK to modify this data, for example calling
|
||||||
|
@ -305,9 +308,6 @@ struct SoundIoDevice {
|
||||||
double period_duration_max;
|
double period_duration_max;
|
||||||
double period_duration_current;
|
double period_duration_current;
|
||||||
|
|
||||||
// Tells whether this device is an input device or an output device.
|
|
||||||
enum SoundIoDevicePurpose purpose;
|
|
||||||
|
|
||||||
// Raw means that you are directly opening the hardware device and not
|
// Raw means that you are directly opening the hardware device and not
|
||||||
// going through a proxy such as dmix, PulseAudio, or JACK. When you open a
|
// going through a proxy such as dmix, PulseAudio, or JACK. When you open a
|
||||||
// raw device, other applications on the computer are not able to
|
// raw device, other applications on the computer are not able to
|
||||||
|
@ -609,7 +609,6 @@ void soundio_device_unref(struct SoundIoDevice *device);
|
||||||
bool soundio_device_equal(
|
bool soundio_device_equal(
|
||||||
const struct SoundIoDevice *a,
|
const struct SoundIoDevice *a,
|
||||||
const struct SoundIoDevice *b);
|
const struct SoundIoDevice *b);
|
||||||
enum SoundIoDevicePurpose soundio_device_purpose(const struct SoundIoDevice *device);
|
|
||||||
|
|
||||||
// Sorts channel layouts by channel count, descending.
|
// Sorts channel layouts by channel count, descending.
|
||||||
void soundio_device_sort_channel_layouts(struct SoundIoDevice *device);
|
void soundio_device_sort_channel_layouts(struct SoundIoDevice *device);
|
||||||
|
|
Loading…
Reference in a new issue