mirror of
https://github.com/ashinn/chibi-scheme.git
synced 2025-07-16 17:37:34 +02:00
increasing numeric output buffer size
This commit is contained in:
parent
aa0af80993
commit
147686a452
1 changed files with 6 additions and 4 deletions
10
sexp.c
10
sexp.c
|
@ -1080,6 +1080,8 @@ sexp sexp_make_output_port (sexp ctx, FILE* out, sexp name) {
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define NUMBUF_LEN 32
|
||||||
|
|
||||||
sexp sexp_write_one (sexp ctx, sexp obj, sexp out) {
|
sexp sexp_write_one (sexp ctx, sexp obj, sexp out) {
|
||||||
#if SEXP_USE_HUFF_SYMS
|
#if SEXP_USE_HUFF_SYMS
|
||||||
unsigned long res, c;
|
unsigned long res, c;
|
||||||
|
@ -1088,7 +1090,7 @@ sexp sexp_write_one (sexp ctx, sexp obj, sexp out) {
|
||||||
long i=0;
|
long i=0;
|
||||||
double f;
|
double f;
|
||||||
sexp x, *elts;
|
sexp x, *elts;
|
||||||
char *str=NULL, numbuf[20];
|
char *str=NULL, numbuf[NUMBUF_LEN];
|
||||||
|
|
||||||
if (! obj) {
|
if (! obj) {
|
||||||
sexp_write_string(ctx, "#<null>", out); /* shouldn't happen */
|
sexp_write_string(ctx, "#<null>", out); /* shouldn't happen */
|
||||||
|
@ -1132,7 +1134,7 @@ sexp sexp_write_one (sexp ctx, sexp obj, sexp out) {
|
||||||
} else
|
} else
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
i = snprintf(numbuf, 20, "%.15g", f);
|
i = snprintf(numbuf, NUMBUF_LEN, "%.15g", f);
|
||||||
if (f == trunc(f) && ! strchr(numbuf, '.')) {
|
if (f == trunc(f) && ! strchr(numbuf, '.')) {
|
||||||
numbuf[i++] = '.'; numbuf[i++] = '0'; numbuf[i++] = '\0';
|
numbuf[i++] = '.'; numbuf[i++] = '0'; numbuf[i++] = '\0';
|
||||||
}
|
}
|
||||||
|
@ -1191,7 +1193,7 @@ sexp sexp_write_one (sexp ctx, sexp obj, sexp out) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
} else if (sexp_fixnump(obj)) {
|
} else if (sexp_fixnump(obj)) {
|
||||||
snprintf(numbuf, 20, "%ld", sexp_unbox_fixnum(obj));
|
snprintf(numbuf, NUMBUF_LEN, "%ld", sexp_unbox_fixnum(obj));
|
||||||
sexp_write_string(ctx, numbuf, out);
|
sexp_write_string(ctx, numbuf, out);
|
||||||
#if SEXP_USE_IMMEDIATE_FLONUMS
|
#if SEXP_USE_IMMEDIATE_FLONUMS
|
||||||
} else if (sexp_flonump(obj)) {
|
} else if (sexp_flonump(obj)) {
|
||||||
|
@ -1203,7 +1205,7 @@ sexp sexp_write_one (sexp ctx, sexp obj, sexp out) {
|
||||||
} else
|
} else
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
i = snprintf(numbuf, 20, "%.8g", f);
|
i = snprintf(numbuf, NUMBUF_LEN, "%.8g", f);
|
||||||
if (f == trunc(f) && ! strchr(numbuf, '.')) {
|
if (f == trunc(f) && ! strchr(numbuf, '.')) {
|
||||||
numbuf[i++] = '.'; numbuf[i++] = '0'; numbuf[i++] = '\0';
|
numbuf[i++] = '.'; numbuf[i++] = '0'; numbuf[i++] = '\0';
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue