aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJurica Bradaric <jurica.bradaric@avl.com>2017-03-07 19:20:07 +0100
committerJurica Bradaric <jbradaric@gmail.com>2017-03-20 21:40:41 +0100
commitb4cb5fa610903492f89a70d0ae2d4565ddcd1228 (patch)
tree9544a40910656950dcde49955a676c176f12af37
parentdf1e7b7edaf6c2ab9435d3734488c74a278f64a1 (diff)
downloadrneovim-b4cb5fa610903492f89a70d0ae2d4565ddcd1228.tar.gz
rneovim-b4cb5fa610903492f89a70d0ae2d4565ddcd1228.tar.bz2
rneovim-b4cb5fa610903492f89a70d0ae2d4565ddcd1228.zip
vim-patch:7.4.2266
Problem: printf() test fails on Windows. "-inf" is not used. Solution: Check for Windows-specific values for "nan". Add sign to "inf" when appropriate. https://github.com/vim/vim/commit/9992237a3e791fbc0c1ebf743ece1b75e1488410
-rw-r--r--src/nvim/strings.c22
-rw-r--r--src/nvim/testdir/test_expr.vim8
-rw-r--r--src/nvim/version.c2
3 files changed, 24 insertions, 8 deletions
diff --git a/src/nvim/strings.c b/src/nvim/strings.c
index d03970108b..47ee311bd4 100644
--- a/src/nvim/strings.c
+++ b/src/nvim/strings.c
@@ -1209,9 +1209,10 @@ int vim_vsnprintf(char *str, size_t str_m, const char *fmt, va_list ap,
}
if (fmt_spec == 'f' && abs_f > 1.0e307) {
+ const char inf_str[] = f < 0 ? "-inf" : "inf";
// avoid a buffer overflow
- memmove(tmp, "inf", sizeof("inf"));
- str_arg_l = sizeof("inf") - 1;
+ memmove(tmp, inf_str, sizeof(inf_str) - 1);
+ str_arg_l = sizeof(inf_str) - 1;
} else {
format[0] = '%';
int l = 1;
@@ -1234,6 +1235,23 @@ int vim_vsnprintf(char *str, size_t str_m, const char *fmt, va_list ap,
str_arg_l = (size_t)snprintf(tmp, sizeof(tmp), format, f);
assert(str_arg_l < sizeof(tmp));
+ // Be consistent: Change "1.#IND" to "nan" and
+ // "1.#INF" to "inf".
+ char *s = *tmp == '-' ? tmp + 1 : tmp;
+ if (STRNCMP(s, "1.#INF", 6) == 0) {
+ STRCPY(s, "inf");
+ } else if (STRNCMP(s, "1.#IND", 6) == 0) {
+ STRCPY(s, "nan");
+ }
+ // Remove sign before "nan"
+ if (STRNCMP(tmp, "-nan", 4) == 0) {
+ STRCPY(tmp, "nan");
+ }
+ // Add sign before "inf" if needed.
+ if (isinf(f) == -1 && STRNCMP(tmp, "inf", 3) == 0) {
+ STRCPY(tmp, "-inf");
+ }
+
if (remove_trailing_zeroes) {
int i;
char *tp;
diff --git a/src/nvim/testdir/test_expr.vim b/src/nvim/testdir/test_expr.vim
index 7f7811dc7a..fc804f3a15 100644
--- a/src/nvim/testdir/test_expr.vim
+++ b/src/nvim/testdir/test_expr.vim
@@ -201,12 +201,10 @@ function Test_printf_float()
call assert_equal('inf', printf('%f', 1.0/0.0))
- " This prints inf but shouldn't it print -inf instead?
- call assert_match('^-\?inf$', printf('%f', -1.0/0.0))
+ call assert_match('^-inf$', printf('%f', -1.0/0.0))
- " This prints -nan but shouldn't it print nan instead?
- call assert_match('^-\?nan$', printf('%f', sqrt(-1.0)))
- call assert_match('^-\?nan$', printf('%f', 0.0/0.0))
+ call assert_match('^nan$', printf('%f', sqrt(-1.0)))
+ call assert_match('^nan$', printf('%f', 0.0/0.0))
call assert_fails('echo printf("%f", "a")', 'E807:')
endfunc
diff --git a/src/nvim/version.c b/src/nvim/version.c
index 8fd0fce329..5479e9f91f 100644
--- a/src/nvim/version.c
+++ b/src/nvim/version.c
@@ -175,7 +175,7 @@ static int included_patches[] = {
// 2269,
// 2268,
// 2267 NA
- // 2266,
+ 2266,
2265,
2264,
// 2263,