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:
parent
69056d4053
commit
479363ae3b
@ -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;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user