libs/libc/stdio/lib_libsscanf.c: Initialized the lastc pointer to avoid the checks for NULL. Removed a bug in the floating point parsing which allowed several signs after each other.

This commit is contained in:
Johannes 2019-02-14 15:43:21 -06:00 committed by Gregory Nutt
parent 69056d4053
commit 479363ae3b

View File

@ -276,6 +276,13 @@ int lib_vsscanf(FAR struct lib_instream_s *obj, FAR int *lastc,
modifier = NO_MOD;
ngetstart = obj->nget; /* for %n calculations */
/* Make sure lastc is not NULL. */
if (lastc == NULL)
{
lastc = &c;
}
/* Loop until all characters in the fmt string have been processed. We may
* have to continue loop after reaching the end the input data in order to
* handle trailing %n format specifiers.
@ -469,12 +476,8 @@ int lib_vsscanf(FAR struct lib_instream_s *obj, FAR int *lastc,
}
if (!fwidth)
{
if (lastc != NULL)
{
*lastc = c;
}
return assigncount;
}
@ -537,12 +540,8 @@ int lib_vsscanf(FAR struct lib_instream_s *obj, FAR int *lastc,
}
if (fwidth != width)
{
if (lastc != NULL)
{
*lastc = c;
}
return assigncount;
}
@ -874,12 +873,8 @@ int lib_vsscanf(FAR struct lib_instream_s *obj, FAR int *lastc,
/* Check if the number was successfully converted */
if (tmp == endptr || get_errno() == ERANGE)
{
if (lastc != NULL)
{
*lastc = c;
}
return assigncount;
}
@ -1027,6 +1022,7 @@ int lib_vsscanf(FAR struct lib_instream_s *obj, FAR int *lastc,
if (!dot)
{
dot = true;
sign = true;
}
else
{
@ -1049,6 +1045,10 @@ int lib_vsscanf(FAR struct lib_instream_s *obj, FAR int *lastc,
{
stopconv = true;
}
else
{
sign = true;
}
if (!stopconv)
{
@ -1083,12 +1083,8 @@ int lib_vsscanf(FAR struct lib_instream_s *obj, FAR int *lastc,
/* Check if the number was successfully converted */
if (tmp == endptr || get_errno() == ERANGE)
{
if (lastc != NULL)
{
*lastc = c;
}
return assigncount;
}
@ -1235,10 +1231,6 @@ int lib_vsscanf(FAR struct lib_instream_s *obj, FAR int *lastc,
* matching failure or conversion.
*/
if (lastc != NULL)
{
*lastc = c;
}
return (count || !conv) ? assigncount : EOF;
}