Update TODO list. Costmetic (only) changes to libs/libc/stdio/lib_libvsprintf.c
This commit is contained in:
parent
055810d9a4
commit
079fedaa3d
19
TODO
19
TODO
@ -22,7 +22,7 @@ nuttx/:
|
|||||||
(18) Network (net/, drivers/net)
|
(18) Network (net/, drivers/net)
|
||||||
(4) USB (drivers/usbdev, drivers/usbhost)
|
(4) USB (drivers/usbdev, drivers/usbhost)
|
||||||
(2) Other drivers (drivers/)
|
(2) Other drivers (drivers/)
|
||||||
(11) Libraries (libs/libc/, libs/libm/)
|
(12) Libraries (libs/libc/, libs/libm/)
|
||||||
(11) File system/Generic drivers (fs/, drivers/)
|
(11) File system/Generic drivers (fs/, drivers/)
|
||||||
(10) Graphics Subsystem (graphics/)
|
(10) Graphics Subsystem (graphics/)
|
||||||
(1) Build system / Toolchains
|
(1) Build system / Toolchains
|
||||||
@ -2044,6 +2044,23 @@ o File system / Generic drivers (fs/, drivers/)
|
|||||||
Priority: Medium. It is certain a file system failure, but I think that
|
Priority: Medium. It is certain a file system failure, but I think that
|
||||||
the exposure in real world uses cases is very small.
|
the exposure in real world uses cases is very small.
|
||||||
|
|
||||||
|
Title: DISCREPANCY IN PRINTF OUTUPUT
|
||||||
|
Description: Under glibc, this printf statment:
|
||||||
|
|
||||||
|
printf("%05.3#x %05.3#x %05.3#x %05.3#x %05.3#x\n",
|
||||||
|
9, 99, 999, 9999, 99999);
|
||||||
|
|
||||||
|
Generates this output:
|
||||||
|
|
||||||
|
0x009 0x063 0x3e7 0x270f 0x1869f
|
||||||
|
|
||||||
|
But under NuttX, the same printf statement generates:
|
||||||
|
|
||||||
|
0x9 0x63 0x3e7 0x270f 0x1869f
|
||||||
|
|
||||||
|
Status: Open
|
||||||
|
Priority: Low. That is a very obscure use to case.
|
||||||
|
|
||||||
o Graphics Subsystem (graphics/)
|
o Graphics Subsystem (graphics/)
|
||||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||||
|
|
||||||
|
@ -360,10 +360,9 @@ static void utoascii(FAR struct lib_outstream_s *obj, uint8_t fmt,
|
|||||||
|
|
||||||
switch (fmt)
|
switch (fmt)
|
||||||
{
|
{
|
||||||
case 'd':
|
case 'd': /* Signed/unsigned base 10 */
|
||||||
case 'i':
|
case 'i':
|
||||||
case 'u':
|
case 'u':
|
||||||
/* Signed/unsigned base 10 */
|
|
||||||
{
|
{
|
||||||
/* Convert the integer value to a string. */
|
/* Convert the integer value to a string. */
|
||||||
|
|
||||||
@ -372,11 +371,10 @@ static void utoascii(FAR struct lib_outstream_s *obj, uint8_t fmt,
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
#ifndef CONFIG_PTR_IS_NOT_INT
|
#ifndef CONFIG_PTR_IS_NOT_INT
|
||||||
case 'p':
|
case 'p': /* Hexadecimal */
|
||||||
#endif
|
#endif
|
||||||
case 'x':
|
case 'x':
|
||||||
case 'X':
|
case 'X':
|
||||||
/* Hexadecimal */
|
|
||||||
{
|
{
|
||||||
/* Check for alternate form */
|
/* Check for alternate form */
|
||||||
|
|
||||||
@ -401,8 +399,7 @@ static void utoascii(FAR struct lib_outstream_s *obj, uint8_t fmt,
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'o':
|
case 'o': /* Octal */
|
||||||
/* Octal */
|
|
||||||
{
|
{
|
||||||
/* Check for alternate form */
|
/* Check for alternate form */
|
||||||
|
|
||||||
@ -419,8 +416,7 @@ static void utoascii(FAR struct lib_outstream_s *obj, uint8_t fmt,
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'b':
|
case 'b': /* Binary */
|
||||||
/* Binary */
|
|
||||||
{
|
{
|
||||||
/* Convert the unsigned value to a string. */
|
/* Convert the unsigned value to a string. */
|
||||||
|
|
||||||
@ -446,30 +442,24 @@ static void fixup(uint8_t fmt, FAR uint8_t *flags, FAR int *n)
|
|||||||
|
|
||||||
switch (fmt)
|
switch (fmt)
|
||||||
{
|
{
|
||||||
case 'd':
|
case 'd': /* Signed base 10 */
|
||||||
case 'i':
|
case 'i':
|
||||||
/* Signed base 10 */
|
|
||||||
|
|
||||||
if (*n < 0)
|
if (*n < 0)
|
||||||
{
|
{
|
||||||
SET_NEGATE(*flags);
|
SET_NEGATE(*flags);
|
||||||
CLR_SHOWPLUS(*flags);
|
CLR_SHOWPLUS(*flags);
|
||||||
*n = -*n;
|
*n = -*n;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'u':
|
case 'u': /* Unsigned base 10 */
|
||||||
/* Unsigned base 10 */
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'p':
|
case 'p': /* Hexadecimal */
|
||||||
case 'x':
|
case 'x':
|
||||||
case 'X':
|
case 'X':
|
||||||
/* Hexadecimal */
|
case 'o': /* Octal */
|
||||||
case 'o':
|
case 'b': /* Binary */
|
||||||
/* Octal */
|
|
||||||
case 'b':
|
|
||||||
/* Binary */
|
|
||||||
CLR_SIGNED(*flags);
|
CLR_SIGNED(*flags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -604,10 +594,9 @@ static void lutoascii(FAR struct lib_outstream_s *obj, uint8_t fmt,
|
|||||||
|
|
||||||
switch (fmt)
|
switch (fmt)
|
||||||
{
|
{
|
||||||
case 'd':
|
case 'd': /* Signed/unsigned base 10 */
|
||||||
case 'i':
|
case 'i':
|
||||||
case 'u':
|
case 'u':
|
||||||
/* Signed/unsigned base 10 */
|
|
||||||
{
|
{
|
||||||
/* Convert the long integer value to a string. */
|
/* Convert the long integer value to a string. */
|
||||||
|
|
||||||
@ -615,9 +604,8 @@ static void lutoascii(FAR struct lib_outstream_s *obj, uint8_t fmt,
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'x':
|
case 'x': /* Hexadecimal */
|
||||||
case 'X':
|
case 'X':
|
||||||
/* Hexadecimal */
|
|
||||||
{
|
{
|
||||||
/* Check for alternate form */
|
/* Check for alternate form */
|
||||||
|
|
||||||
@ -642,8 +630,7 @@ static void lutoascii(FAR struct lib_outstream_s *obj, uint8_t fmt,
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'o':
|
case 'o': /* Octal */
|
||||||
/* Octal */
|
|
||||||
{
|
{
|
||||||
/* Check for alternate form */
|
/* Check for alternate form */
|
||||||
|
|
||||||
@ -660,8 +647,7 @@ static void lutoascii(FAR struct lib_outstream_s *obj, uint8_t fmt,
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'b':
|
case 'b': /* Binary */
|
||||||
/* Binary */
|
|
||||||
{
|
{
|
||||||
/* Convert the unsigned value to a string. */
|
/* Convert the unsigned value to a string. */
|
||||||
|
|
||||||
@ -685,30 +671,24 @@ static void lfixup(uint8_t fmt, FAR uint8_t *flags, FAR long *ln)
|
|||||||
|
|
||||||
switch (fmt)
|
switch (fmt)
|
||||||
{
|
{
|
||||||
case 'd':
|
case 'd': /* Signed base 10 */
|
||||||
case 'i':
|
case 'i':
|
||||||
/* Signed base 10 */
|
|
||||||
|
|
||||||
if (*ln < 0)
|
if (*ln < 0)
|
||||||
{
|
{
|
||||||
SET_NEGATE(*flags);
|
SET_NEGATE(*flags);
|
||||||
CLR_SHOWPLUS(*flags);
|
CLR_SHOWPLUS(*flags);
|
||||||
*ln = -*ln;
|
*ln = -*ln;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'u':
|
case 'u': /* Unsigned base 10 */
|
||||||
/* Unsigned base 10 */
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'p':
|
case 'p': /* Hexadecimal */
|
||||||
case 'x':
|
case 'x':
|
||||||
case 'X':
|
case 'X':
|
||||||
/* Hexadecimal */
|
case 'o': /* Octal */
|
||||||
case 'o':
|
case 'b': /* Binary */
|
||||||
/* Octal */
|
|
||||||
case 'b':
|
|
||||||
/* Binary */
|
|
||||||
CLR_SIGNED(*flags);
|
CLR_SIGNED(*flags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -829,10 +809,9 @@ static void llutoascii(FAR struct lib_outstream_s *obj, uint8_t fmt,
|
|||||||
|
|
||||||
switch (fmt)
|
switch (fmt)
|
||||||
{
|
{
|
||||||
case 'd':
|
case 'd': /* Signed/unsigned base 10 */
|
||||||
case 'i':
|
case 'i':
|
||||||
case 'u':
|
case 'u':
|
||||||
/* Signed/unsigned base 10 */
|
|
||||||
{
|
{
|
||||||
/* Convert the long long integer value to a string. */
|
/* Convert the long long integer value to a string. */
|
||||||
|
|
||||||
@ -840,9 +819,8 @@ static void llutoascii(FAR struct lib_outstream_s *obj, uint8_t fmt,
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'x':
|
case 'x': /* Hexadecimal */
|
||||||
case 'X':
|
case 'X':
|
||||||
/* Hexadecimal */
|
|
||||||
{
|
{
|
||||||
/* Check for alternate form */
|
/* Check for alternate form */
|
||||||
|
|
||||||
@ -867,8 +845,7 @@ static void llutoascii(FAR struct lib_outstream_s *obj, uint8_t fmt,
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'o':
|
case 'o': /* Octal */
|
||||||
/* Octal */
|
|
||||||
{
|
{
|
||||||
/* Check for alternate form */
|
/* Check for alternate form */
|
||||||
|
|
||||||
@ -885,8 +862,7 @@ static void llutoascii(FAR struct lib_outstream_s *obj, uint8_t fmt,
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'b':
|
case 'b': /* Binary */
|
||||||
/* Binary */
|
|
||||||
{
|
{
|
||||||
/* Convert the unsigned value to a string. */
|
/* Convert the unsigned value to a string. */
|
||||||
|
|
||||||
@ -910,30 +886,24 @@ static void llfixup(uint8_t fmt, FAR uint8_t *flags, FAR long long *lln)
|
|||||||
|
|
||||||
switch (fmt)
|
switch (fmt)
|
||||||
{
|
{
|
||||||
case 'd':
|
case 'd': /* Signed base 10 */
|
||||||
case 'i':
|
case 'i':
|
||||||
/* Signed base 10 */
|
|
||||||
|
|
||||||
if (*lln < 0)
|
if (*lln < 0)
|
||||||
{
|
{
|
||||||
SET_NEGATE(*flags);
|
SET_NEGATE(*flags);
|
||||||
CLR_SHOWPLUS(*flags);
|
CLR_SHOWPLUS(*flags);
|
||||||
*lln = -*lln;
|
*lln = -*lln;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'u':
|
case 'u': /* Unsigned base 10 */
|
||||||
/* Unsigned base 10 */
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 'p':
|
case 'p': /* Hexadecimal */
|
||||||
case 'x':
|
case 'x':
|
||||||
case 'X':
|
case 'X':
|
||||||
/* Hexadecimal */
|
case 'o': /* Octal */
|
||||||
case 'o':
|
case 'b': /* Binary */
|
||||||
/* Octal */
|
|
||||||
case 'b':
|
|
||||||
/* Binary */
|
|
||||||
CLR_SIGNED(*flags);
|
CLR_SIGNED(*flags);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -951,7 +921,6 @@ static int getllusize(uint8_t fmt, uint8_t flags, unsigned long long lln)
|
|||||||
struct lib_outstream_s nulloutstream;
|
struct lib_outstream_s nulloutstream;
|
||||||
lib_nulloutstream(&nulloutstream);
|
lib_nulloutstream(&nulloutstream);
|
||||||
|
|
||||||
|
|
||||||
llutoascii(&nulloutstream, fmt, flags, lln);
|
llutoascii(&nulloutstream, fmt, flags, lln);
|
||||||
return nulloutstream.nput;
|
return nulloutstream.nput;
|
||||||
}
|
}
|
||||||
@ -968,6 +937,8 @@ static void prejustify(FAR struct lib_outstream_s *obj, uint8_t fmt,
|
|||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
/* If there is integer precision, then use FMT_RJUST vs FMT_RJUST0 */
|
||||||
|
|
||||||
if (trunc > 0 && fmt == FMT_RJUST0)
|
if (trunc > 0 && fmt == FMT_RJUST0)
|
||||||
{
|
{
|
||||||
/* Force right justification in the case. Leading zeros application
|
/* Force right justification in the case. Leading zeros application
|
||||||
@ -1371,6 +1342,7 @@ int lib_vsprintf(FAR struct lib_outstream_s *obj, FAR const IPTR char *src,
|
|||||||
{
|
{
|
||||||
long long lln;
|
long long lln;
|
||||||
int lluwidth;
|
int lluwidth;
|
||||||
|
|
||||||
/* Extract the long long value. */
|
/* Extract the long long value. */
|
||||||
|
|
||||||
lln = va_arg(ap, long long);
|
lln = va_arg(ap, long long);
|
||||||
|
Loading…
Reference in New Issue
Block a user