[alsa-devel] [PATCH v2 07/13] topology: Add private data parser
Liam Girdwood
liam.r.girdwood at linux.intel.com
Wed Jul 8 10:57:32 CEST 2015
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 ?
Liam
More information about the Alsa-devel
mailing list