skalibs

Mirror/fork of https://skarnet.org/software/skalibs/
git clone https://ccx.te2000.cz/git/skalibs
Log | Files | Refs | README | LICENSE

commit 7e1e6cf1584c5f1c0d6c892d013ed522fb8a8bc1
parent 9ec6602c9d3c1a8801d996aa3a56c779ce1c5f70
Author: Laurent Bercot <ska-skaware@skarnet.org>
Date:   Thu, 11 Jul 2019 17:46:58 +0000

 Better with the new files added >.>

Diffstat:
Asrc/headers/uint64-defs | 8++++++++
Asrc/headers/uint64-include | 1+
Asrc/headers/uint64-macros | 25+++++++++++++++++++++++++
Asrc/libstddjb/int64_scan_base_max.c | 20++++++++++++++++++++
Asrc/libstddjb/uint640_fmt_generic.c | 21+++++++++++++++++++++
Asrc/libstddjb/uint64_fmt_generic.c | 17+++++++++++++++++
Asrc/libstddjb/uint64_scan_base_max.c | 21+++++++++++++++++++++
7 files changed, 113 insertions(+), 0 deletions(-)

diff --git a/src/headers/uint64-defs b/src/headers/uint64-defs @@ -0,0 +1,8 @@ + +extern size_t uint64_fmt_generic (char *, uint64_t, uint8_t) ; +extern size_t uint640_fmt_generic (char *, uint64_t, size_t, uint8_t) ; +extern size_t int64_fmt_generic (char *, int64_t, uint8_t) ; + +extern size_t uint64_scan_base_max (char const *, uint64_t *, uint8_t, uint64_t) ; +extern size_t int64_scan_base_max (char const *, int64_t *, uint8_t, uint64_t) ; + diff --git a/src/headers/uint64-include b/src/headers/uint64-include @@ -0,0 +1 @@ +#include <skalibs/uint64.h> diff --git a/src/headers/uint64-macros b/src/headers/uint64-macros @@ -0,0 +1,25 @@ + +#ifndef INT_LEAST64_MIN +# define INT_LEAST64_MIN INT64_MIN +#endif + +#ifndef INT_FAST64_MIN +# define INT_FAST64_MIN INT64_MIN +#endif + +#ifndef INT_LEAST64_MAX +# define INT_LEAST64_MAX INT64_MAX +#endif + +#ifndef INT_FAST64_MAX +# define INT_FAST64_MAX INT64_MAX +#endif + +#ifndef UINT_LEAST64_MAX +# define UINT_LEAST64_MAX UINT64_MAX +#endif + +#ifndef UINT_FAST64_MAX +# define UINT_FAST64_MAX UINT64_MAX +#endif + diff --git a/src/libstddjb/int64_scan_base_max.c b/src/libstddjb/int64_scan_base_max.c @@ -0,0 +1,20 @@ +/* ISC license. */ + +#include <skalibs/uint64.h> +#include "fmtscan-internal.h" + +size_t int64_scan_base_max (char const *s, int64_t *d, uint8_t base, uint64_t max) +{ + if (s[0] == '-') + { + uint64_t u ; + size_t pos = uint64_scan_base_max(s+1, &u, base, max+1) ; + return pos ? (*d = -u, 1 + pos) : 0 ; + } + else if (s[0] == '+') + { + size_t pos = uint64_scan_base_max(s+1, (uint64_t *)d, base, max) ; + return pos ? 1 + pos : 0 ; + } + else return uint64_scan_base_max(s, (uint64_t *)d, base, max) ; +} diff --git a/src/libstddjb/uint640_fmt_generic.c b/src/libstddjb/uint640_fmt_generic.c @@ -0,0 +1,21 @@ +/* ISC license. */ + +#include <string.h> + +#include <skalibs/uint64.h> +#include <skalibs/fmtscan.h> + +size_t uint640_fmt_generic (char *s, uint64_t x, size_t n, uint8_t base) +{ + size_t len = uint64_fmt_generic(0, x, base) ; + if (s) + { + if (len < n) + { + memset(s, '0', n - len) ; + s += n - len ; + } + uint64_fmt_generic(s, x, base) ; + } + return len > n ? len : n ; +} diff --git a/src/libstddjb/uint64_fmt_generic.c b/src/libstddjb/uint64_fmt_generic.c @@ -0,0 +1,17 @@ +/* ISC license. */ + +#include <skalibs/uint64.h> +#include <skalibs/fmtscan.h> + +size_t uint64_fmt_generic (char *s, uint64_t x, uint8_t base) +{ + size_t len = 1 ; + uint64_t q = x ; + while (q >= base) { len++ ; q /= base ; } + if (s) + { + s += len ; + do { *--s = fmtscan_asc(x % base) ; x /= base ; } while (x) ; + } + return len ; +} diff --git a/src/libstddjb/uint64_scan_base_max.c b/src/libstddjb/uint64_scan_base_max.c @@ -0,0 +1,21 @@ +/* ISC license. */ + +#include <stddef.h> +#include <stdint.h> + +#include <skalibs/uint64.h> +#include <skalibs/fmtscan.h> + +size_t uint64_scan_base_max (char const *s, uint64_t *u, uint8_t base, uint64_t max) +{ + uint64_t result = 0 ; + size_t pos = 0 ; + for (;; pos++) + { + uint8_t c = fmtscan_num(s[pos], base) ; + if (c >= base || result > ((max - c) / base)) break ; + result = result * base + c ; + } + if (pos) *u = result ; + return pos ; +}