mescc: Tinycc support: strtoull.
* mlibc/include/mlibc.h (_atoi): Declare. * mlibc/include/ctype.h (isxdigit): Declare. * mlibc/libc-gcc.c (isxdigit, _atoi): New function. (atoi): Use it. * mlibc/libc-mes.c (isxdigit, _atoi): New function. (atoi): Use it. * scaffold/tests/7j-strtoull.c (test): Test it. * make.scm (add-scaffold-test): Build it.
This commit is contained in:
parent
70e3e83581
commit
93714ad0a4
3
make.scm
3
make.scm
|
@ -168,7 +168,8 @@ exec ${GUILE-guile} --no-auto-compile -L . -L guile -C . -C guile -s "$0" ${1+"$
|
|||
"7f-struct-pointer-arithmetic"
|
||||
"7g-struct-byte-word-field"
|
||||
"7h-struct-assign"
|
||||
"7i-struct-struct"))
|
||||
"7i-struct-struct"
|
||||
"7j-strtoull"))
|
||||
|
||||
(add-target (group "check-scaffold-tests/7" #:dependencies (filter (target-prefix? "check-scaffold/tests/7") %targets)))
|
||||
|
||||
|
|
|
@ -29,6 +29,7 @@
|
|||
|
||||
#else // ! (__GNUC__ && POSIX)
|
||||
int isdigit (int);
|
||||
int isxdigit (int);
|
||||
#endif // ! (__GNUC__ && POSIX)
|
||||
|
||||
#endif // __MES_CTYPE_H
|
||||
|
|
|
@ -22,5 +22,8 @@
|
|||
#define __MES_MLIBC_H
|
||||
|
||||
char const* itoa (int);
|
||||
int _atoi (char const**, int base);
|
||||
int eputc (int c);
|
||||
int eputs (char const* s);
|
||||
|
||||
#endif //__MLIBC_H
|
||||
#endif //__MES_MLIBC_H
|
||||
|
|
|
@ -331,24 +331,53 @@ isdigit (int c)
|
|||
}
|
||||
|
||||
int
|
||||
atoi (char const *s)
|
||||
isxdigit (int c)
|
||||
{
|
||||
return isdigit (c) || (c>='a') && (c<='f');
|
||||
}
|
||||
|
||||
int
|
||||
isnumber (int c, int base)
|
||||
{
|
||||
if (base == 2)
|
||||
return (c>='0') && (c<='1');
|
||||
if (base == 8)
|
||||
return (c>='0') && (c<='7');
|
||||
if (base == 10)
|
||||
return isdigit (c);
|
||||
if (base == 16)
|
||||
return isxdigit (c);
|
||||
}
|
||||
|
||||
int
|
||||
_atoi (char const **p, int base)
|
||||
{
|
||||
char const *s = *p;
|
||||
int i = 0;
|
||||
int sign = 1;
|
||||
if (!base) base = 10;
|
||||
if (*s && *s == '-')
|
||||
{
|
||||
sign = -1;
|
||||
s++;
|
||||
}
|
||||
while (isdigit (*s))
|
||||
while (isnumber (*s, base))
|
||||
{
|
||||
i *= 10;
|
||||
i += (*s - '0');
|
||||
i *= base;
|
||||
int m = *s > '9' ? 'a' - 10 : '0';
|
||||
i += *s - m;
|
||||
s++;
|
||||
}
|
||||
*p = s;
|
||||
return i * sign;
|
||||
}
|
||||
|
||||
int
|
||||
atoi (char const *s)
|
||||
{
|
||||
char const *p = s;
|
||||
return _atoi (&p, 0);
|
||||
}
|
||||
|
||||
// FIXME: copied from libc-mes.c now
|
||||
#include <stdarg.h>
|
||||
|
|
|
@ -326,10 +326,10 @@ strtoul (char const *nptr, char **endptr, int base)
|
|||
}
|
||||
|
||||
unsigned long long
|
||||
strtoull (char const *nptr, char **endptr, int base)
|
||||
strtoull (char const *p, char **end, int base)
|
||||
{
|
||||
eputs ("strtoull stub\n");
|
||||
return 0;
|
||||
*end = p;
|
||||
return _atoi (end, base);
|
||||
}
|
||||
|
||||
time_t time (time_t *tloc)
|
||||
|
|
|
@ -299,32 +299,60 @@ itoa (int x)
|
|||
}
|
||||
|
||||
int
|
||||
isdigit (char c)
|
||||
isdigit (int c)
|
||||
{
|
||||
//return (c>='0') && (c<='9');
|
||||
if (c>='0' && c<='9') return 1;
|
||||
return 0;
|
||||
return (c>='0') && (c<='9');
|
||||
}
|
||||
|
||||
int
|
||||
atoi (char const *s)
|
||||
isxdigit (int c)
|
||||
{
|
||||
return isdigit (c) || (c>='a') && (c<='f');
|
||||
}
|
||||
|
||||
int
|
||||
isnumber (int c, int base)
|
||||
{
|
||||
if (base == 2)
|
||||
return (c>='0') && (c<='1');
|
||||
if (base == 8)
|
||||
return (c>='0') && (c<='7');
|
||||
if (base == 10)
|
||||
return isdigit (c);
|
||||
if (base == 16)
|
||||
return isxdigit (c);
|
||||
}
|
||||
|
||||
int
|
||||
_atoi (char const **p, int base)
|
||||
{
|
||||
char const *s = *p;
|
||||
int i = 0;
|
||||
int sign = 1;
|
||||
if (!base) base = 10;
|
||||
if (*s && *s == '-')
|
||||
{
|
||||
sign = -1;
|
||||
s++;
|
||||
}
|
||||
while (isdigit (*s))
|
||||
while (isnumber (*s, base))
|
||||
{
|
||||
i *= 10;
|
||||
i += (*s - '0');
|
||||
i *= base;
|
||||
int m = *s > '9' ? 'a' - 10 : '0';
|
||||
i += *s - m;
|
||||
s++;
|
||||
}
|
||||
*p = s;
|
||||
return i * sign;
|
||||
}
|
||||
|
||||
int
|
||||
atoi (char const *s)
|
||||
{
|
||||
char const *p = s;
|
||||
return _atoi (&p, 0);
|
||||
}
|
||||
|
||||
char *g_brk = 0;
|
||||
|
||||
void *
|
||||
|
|
50
scaffold/tests/7j-strtoull.c
Normal file
50
scaffold/tests/7j-strtoull.c
Normal file
|
@ -0,0 +1,50 @@
|
|||
/* -*-comment-start: "//";comment-end:""-*-
|
||||
* Mes --- Maxwell Equations of Software
|
||||
* Copyright © 2017 Jan Nieuwenhuizen <janneke@gnu.org>
|
||||
*
|
||||
* This file is part of Mes.
|
||||
*
|
||||
* Mes is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU General Public License as published by
|
||||
* the Free Software Foundation; either version 3 of the License, or (at
|
||||
* your option) any later version.
|
||||
*
|
||||
* Mes is distributed in the hope that it will be useful, but
|
||||
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU General Public License
|
||||
* along with Mes. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#include "30-test.i"
|
||||
#include <mlibc.h>
|
||||
#include <stdio.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
|
||||
unsigned long long
|
||||
strtoull (char const *p, char **end, int base)
|
||||
{
|
||||
*end = p;
|
||||
return _atoi (end, base);
|
||||
}
|
||||
|
||||
int
|
||||
test ()
|
||||
{
|
||||
char *p = "42foo\n";
|
||||
int n = _atoi (&p, 0);
|
||||
if (n != 42) return 1;
|
||||
eputs (p);
|
||||
if (strcmp (p, "foo\n")) return 2;
|
||||
|
||||
p = "2azar\n";
|
||||
n = strtoull (p, (char**)&p, 16);
|
||||
if (n != 42) return 3;
|
||||
eputs (p);
|
||||
if (strcmp (p, "zar\n")) return 4;
|
||||
|
||||
return 0;
|
||||
}
|
Loading…
Reference in a new issue