diff options
author | Damien Miller <djm@mindrot.org> | 2018-05-14 14:40:08 +1000 |
---|---|---|
committer | Damien Miller <djm@mindrot.org> | 2018-05-14 14:40:08 +1000 |
commit | 32e4e94e1511fe0020fbfbb62399d31b2d22a801 (patch) | |
tree | b8b5f7c6dd41e6eabe185c8d637f69b40e9d807b | |
parent | 54268d589e85ecc43d3eba8d83f327bdada9d696 (diff) |
sync fmt_scaled.c
revision 1.17
date: 2018/05/14 04:39:04; author: djm; state: Exp; lines: +5 -2;
commitid: 53zY8GjViUBnWo8Z;
constrain fractional part to [0-9] (less confusing to static analysis); ok ian@
-rw-r--r-- | openbsd-compat/fmt_scaled.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/openbsd-compat/fmt_scaled.c b/openbsd-compat/fmt_scaled.c index f68f24123..2f76ef931 100644 --- a/openbsd-compat/fmt_scaled.c +++ b/openbsd-compat/fmt_scaled.c | |||
@@ -1,4 +1,4 @@ | |||
1 | /* $OpenBSD: fmt_scaled.c,v 1.16 2017/03/16 02:40:46 dtucker Exp $ */ | 1 | /* $OpenBSD: fmt_scaled.c,v 1.17 2018/05/14 04:39:04 djm Exp $ */ |
2 | 2 | ||
3 | /* | 3 | /* |
4 | * Copyright (c) 2001, 2002, 2003 Ian F. Darwin. All rights reserved. | 4 | * Copyright (c) 2001, 2002, 2003 Ian F. Darwin. All rights reserved. |
@@ -246,12 +246,15 @@ fmt_scaled(long long number, char *result) | |||
246 | 246 | ||
247 | fract = (10 * fract + 512) / 1024; | 247 | fract = (10 * fract + 512) / 1024; |
248 | /* if the result would be >= 10, round main number */ | 248 | /* if the result would be >= 10, round main number */ |
249 | if (fract == 10) { | 249 | if (fract >= 10) { |
250 | if (number >= 0) | 250 | if (number >= 0) |
251 | number++; | 251 | number++; |
252 | else | 252 | else |
253 | number--; | 253 | number--; |
254 | fract = 0; | 254 | fract = 0; |
255 | } else if (fract < 0) { | ||
256 | /* shouldn't happen */ | ||
257 | fract = 0; | ||
255 | } | 258 | } |
256 | 259 | ||
257 | if (number == 0) | 260 | if (number == 0) |