ao: use g_strsplit() instead of strtok_r()

g_strsplit() is more portable than strtok_r().
This commit is contained in:
Max Kellermann 2009-01-03 13:20:12 +01:00
parent 5b543e8fa6
commit 59067e6a92

View File

@ -79,12 +79,6 @@ static void *audioOutputAo_initDriver(struct audio_output *ao,
ConfigParam * param) ConfigParam * param)
{ {
ao_info *ai; ao_info *ai;
char *duplicated;
char *stk1;
char *stk2;
char *n1;
char *key;
char *value;
char *test; char *test;
AoData *ad = newAoData(); AoData *ad = newAoData();
BlockParam *blockParam; BlockParam *blockParam;
@ -121,40 +115,24 @@ static void *audioOutputAo_initDriver(struct audio_output *ao,
audio_output_get_name(ao)); audio_output_get_name(ao));
blockParam = getBlockParam(param, "options"); blockParam = getBlockParam(param, "options");
if (blockParam) { if (blockParam) {
duplicated = g_strdup(blockParam->value); gchar **options = g_strsplit(blockParam->value, ";", 0);
} else
duplicated = g_strdup("");
if (strlen(duplicated)) { for (unsigned i = 0; options[i] != NULL; ++i) {
stk1 = NULL; gchar **key_value = g_strsplit(options[i], "=", 2);
n1 = strtok_r(duplicated, ";", &stk1);
while (n1) { if (key_value[0] == NULL || key_value[1] == NULL)
stk2 = NULL; g_error("problems parsing options \"%s\"\n",
key = strtok_r(n1, "=", &stk2); options[i]);
if (!key)
g_error("problems parsing options \"%s\"\n", n1); ao_append_option(&ad->options, key_value[0],
/*found = 0; key_value[1]);
for(i=0;i<ai->option_count;i++) {
if(strcmp(ai->options[i],key)==0) { g_strfreev(key_value);
found = 1;
break;
}
}
if(!found) {
FATAL("\"%s\" is not an option for "
"\"%s\" ao driver\n",key,
ai->short_name);
} */
value = strtok_r(NULL, "", &stk2);
if (!value)
g_error("problems parsing options \"%s\"\n", n1);
ao_append_option(&ad->options, key, value);
n1 = strtok_r(NULL, ";", &stk1);
} }
g_strfreev(options);
} }
free(duplicated);
return ad; return ad;
} }