summaryrefslogtreecommitdiffstats
path: root/stream.c
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2017-07-16 16:02:41 -0700
committerKaz Kylheku <kaz@kylheku.com>2017-07-16 16:02:41 -0700
commit0359aa22e83881d7686144145fe42920fe943fa0 (patch)
treebdc828dd40d1b9ccace99ec130f5260f6082ca2b /stream.c
parentd83e611d58441f546babd1d742926c191d416e58 (diff)
downloadtxr-0359aa22e83881d7686144145fe42920fe943fa0.tar.gz
txr-0359aa22e83881d7686144145fe42920fe943fa0.tar.bz2
txr-0359aa22e83881d7686144145fe42920fe943fa0.zip
format: support leading zero printing for floats.
For a floating-point argument, the following behavior is supported by the ~a, ~s and ~f format directives: if the precision has a leading zero, then leading zeros are added, up to one less than the field width. * stream.c (formatv): Set the precision to one less than the field width when rendering floats, rather than to zero. The output_num code takes the precision as the cue for padding zeros. * txr.1: Updated format documentation, and clarified a few things also.
Diffstat (limited to 'stream.c')
-rw-r--r--stream.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/stream.c b/stream.c
index 48738bb7..d5886336 100644
--- a/stream.c
+++ b/stream.c
@@ -3259,7 +3259,7 @@ val formatv(val stream_in, val fmtstr, struct args *al)
vformat_str(stream, lit("#<bad-float>"), width, align, 0);
continue;
}
- precision = 0;
+ precision = (width ? width - 1 : 0);
goto output_num;
}
case 'd':
@@ -3348,7 +3348,7 @@ val formatv(val stream_in, val fmtstr, struct args *al)
continue;
}
- precision = 0;
+ precision = (width ? width - 1 : 0);
goto output_num;
default:
if (width != 0 || precision_p) {