mirror of
https://gitlab.freedesktop.org/pipewire/pipewire.git
synced 2025-10-29 05:40:27 -04:00
spa: add spa_json_begin_array/object and relaxed versions
Add spa_json_begin_array/object to replace spa_json_init+spa_json_begin_array/object This function is better because it does not waste a useless spa_json structure as an iterator. The relaxed versions also error out when the container is mismatched because parsing a mismatched container is not going to give any results anyway.
This commit is contained in:
parent
feccb882b6
commit
cd81b5f39a
51 changed files with 401 additions and 452 deletions
|
|
@ -968,16 +968,15 @@ int spa_alsa_init(struct state *state, const struct spa_dict *info)
|
|||
} else if (spa_streq(k, "clock.quantum-limit")) {
|
||||
spa_atou32(s, &state->quantum_limit, 0);
|
||||
} else if (spa_streq(k, SPA_KEY_API_ALSA_BIND_CTLS)) {
|
||||
struct spa_json it[2];
|
||||
struct spa_json it[1];
|
||||
char v[256];
|
||||
unsigned int i = 0;
|
||||
|
||||
/* Read a list of ALSA control names to bind as params */
|
||||
spa_json_init(&it[0], s, strlen(s));
|
||||
if (spa_json_enter_array(&it[0], &it[1]) <= 0)
|
||||
spa_json_init(&it[1], s, strlen(s));
|
||||
if (spa_json_begin_array_relax(&it[0], s, strlen(s)) <= 0)
|
||||
continue;
|
||||
|
||||
while (spa_json_get_string(&it[1], v, sizeof(v)) > 0 &&
|
||||
while (spa_json_get_string(&it[0], v, sizeof(v)) > 0 &&
|
||||
i < SPA_N_ELEMENTS(state->bound_ctls)) {
|
||||
snprintf(state->bound_ctls[i].name,
|
||||
sizeof(state->bound_ctls[i].name), "%s", v);
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue