[alsa-devel] [PATCH v2 07/13] topology: Add private data parser
Liam Girdwood
liam.r.girdwood at linux.intel.com
Wed Jul 8 16:21:15 CEST 2015
On Wed, 2015-07-08 at 16:14 +0200, Takashi Iwai wrote:
> 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.
>
Ok, lets make commas at the end illegal.
> 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.
>
So I'll fix this to be "0x01, 0x02, 0x03" syntax only. i.e. comma
between each value and no comma at the end.
Liam
More information about the Alsa-devel
mailing list