3 Date of creation : 05/12/2022
5 Copyright : Soft'n'design
6 Author : Laurent Mazet <mazet@softndesign.org>
8 Description : This file contains embedded printf
20 int stdfdin
= STDIN_FILENO
;
21 int stdfdout
= STDOUT_FILENO
;
22 int stdfderr
= STDERR_FILENO
;
24 unsigned int nextpow (unsigned int x
, int base
) {
30 return (n
== 0) ? 1 : n
;
33 char *itoa (char *str
, unsigned u
, unsigned int sz
)
35 unsigned int i
= (sz
== 0 ) ? nextpow (u
, 10) : sz
;
38 str
[i
- 1] = '0' + (u
% 10);
46 /* simple fprintf function */
48 int fdprintf (int fd
, const char *fmt
, ...)
50 char buffer
[1024 + 1] = { 0 };
62 /* copy standard char */
72 if ((*fmt
== ' ') || (*fmt
== '0')) {
77 if ((*fmt
>= '1') && (*fmt
<= '9')) {
81 /* process format char */
84 c
= (char) va_arg (ap
, int);
95 case 'u': /* unsigned int */
96 str
= itoa (str
, (t
) ? (unsigned int)d
: va_arg (ap
, unsigned int), 0);
99 f
= va_arg (ap
, double);
123 str
= itoa (str
, u
, 0);
124 d
= (int)((f
- u
) * 1e6
);
127 str
= itoa (str
, d
, 6);
135 str
= itoa (str
, t
, 0);
138 case 'p': /* pointer */
142 sz
= sizeof (void *) * 2;
143 p
= va_arg (ap
, void *);
145 case 'x': /* integer hexa */
147 u
= va_arg (ap
, unsigned int);
149 sz
= nextpow (u
, 16);
154 for (i
= sz
, t
= 1; i
> 0; i
--) {
155 char x
= (char)((u
>> (i
* 4 - 4)) & 0xf);
156 if ((t
== 1) && (x
== 0)) {
159 *str
++ = (x
> 9) ? 'a' + x
- 10 : '0' + x
;
164 case 's': /* string */
165 s
= va_arg (ap
, char *);
177 int n
= str
- buffer
;
178 if (n
< (int)sizeof (buffer
) - 1) {
179 return write (fd
, buffer
, n
);
184 /* vim: set ts=4 sw=4 et: */