[alsa-devel] [PATCH v2 07/13] topology: Add private data parser
Takashi Iwai
tiwai at suse.de
Wed Jul 8 16:14:01 CEST 2015
On Wed, 08 Jul 2015 15:31:27 +0200,
Jin, Yao wrote:
>
>
>
> On 2015/7/8 16:57, Liam Girdwood wrote:
> > On Tue, 2015-07-07 at 18:19 +0200, Takashi Iwai wrote:
> >> On Tue, 07 Jul 2015 17:54:02 +0200,
> >> Liam Girdwood wrote:
> >>>
> >>> On Wed, 2015-07-01 at 18:20 +0200, Takashi Iwai wrote:
> >>>
> >>>>
> >>>>> +static int get_hex_num(const char *str)
> >>>>> +{
> >>>>> + char *tmp, *s = NULL;
> >>>>> + int i = 0;
> >>>>> +
> >>>>> + tmp = strdup(str);
> >>>>> + if (tmp == NULL)
> >>>>> + return -ENOMEM;
> >>>>> +
> >>>>> + s = strtok(tmp, ",");
> >>>>> + while (s != NULL) {
> >>>>> + s = strtok(NULL, ",");
> >>>>> + i++;
> >>>>> + }
> >>>>> +
> >>>>> + free(tmp);
> >>>>> + return i;
> >>>>
> >>>> Hmm, this just counts the number of comma + 1, so you don't need to
> >>>> duplicate the string?
> >>>>
> >>>
> >>> The string here is duplicated since strtok is destructive (it overwrites
> >>> the delimiters with NULL) and the string is being used later on by the
> >>> calling function.
> >>
> >> Yes, but what I meant is something like below:
> >>
> >> static int get_hex_num(const char *str)
> >> {
> >> int i = 0;
> >>
> >> if (!*str)
> >> return 0;
> >> for (;;) {
> >> i++;
> >> str = strchr(str, ',');
> >> if (!str)
> >> return i;
> >> str++;
> >> }
> >> }
> >>
> >> ... so that it works without strdup().
> >>
> >> But it seems that strtok() skips the starting delimiter or handles
> >> multiple delimiters as a single, so the result will become
> >> inconsistent. That is, all the following strings will give "a" and
> >> "b" via strtok():
> >> a,b
> >> a,,b
> >> ,a,b
> >> a,b,
> >>
> >> I guess you don't want to have an empty list element, right?
> >>
> >
> > Lets ask the author :) but IMO an empty list should be skipped here.
> >
> > Yao, what's your rational behind this code ?
>
> Sorry for replying late, I just see this mail.
>
> The get_hex_num() returns the number of hexadecimal in string.
>
> Say the string is "0x12,0x34,0x56,0x78" or "0x12,0x34,0x56,0x78,",
> the get_hex_num() returns 4.
>
> But if I use strchr, for above string, I get different number (3 or 4).
> That's the reason I choose the strtok().
>
> I do this is because I think user may append the comma at the end of
> string.
So, is this allowed intentionally as a valid syntax? As I showed,
a string like ",,,0x12,,0x34,,,,0x56,0x78,," would be handled as a
valid string.
The above may look strange, but the strtok() behavior is natural if
you imagine to replace "," with a space.
Takashi
More information about the Alsa-devel
mailing list