diff options
author | James McCoy <jamessan@jamessan.com> | 2025-02-26 04:23:52 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2025-02-26 04:23:52 -0700 |
commit | c619d1da619b362217112d8165e2495860c5b056 (patch) | |
tree | 807d32c739703e18fa3ea5a5eb3fdf867ac7911f /src | |
parent | 7ead328a48589f31b15bd6e84be5a0ab9386e620 (diff) | |
parent | 453f2c52d29143af71436c7c7add52edc9af3bf3 (diff) | |
download | rneovim-c619d1da619b362217112d8165e2495860c5b056.tar.gz rneovim-c619d1da619b362217112d8165e2495860c5b056.tar.bz2 rneovim-c619d1da619b362217112d8165e2495860c5b056.zip |
Merge pull request #32631 from jamessan/snprintf-binary
fix(vim_snprintf): special-case handling of binary format
Diffstat (limited to 'src')
-rw-r--r-- | src/nvim/strings.c | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/src/nvim/strings.c b/src/nvim/strings.c index 818e67b32d..322b97d6bf 100644 --- a/src/nvim/strings.c +++ b/src/nvim/strings.c @@ -1668,8 +1668,6 @@ int vim_vsnprintf_typval(char *str, size_t str_m, const char *fmt, va_list ap_st } switch (fmt_spec) { - case 'b': - case 'B': case 'd': case 'u': case 'o': @@ -1793,6 +1791,13 @@ int vim_vsnprintf_typval(char *str, size_t str_m, const char *fmt, va_list ap_st if (ptr_arg) { arg_sign = 1; } + } else if (fmt_spec == 'b' || fmt_spec == 'B') { + uarg = (tvs + ? (unsigned long long)tv_nr(tvs, &arg_idx) // NOLINT(runtime/int) + : (skip_to_arg(ap_types, ap_start, &ap, &arg_idx, + &arg_cur, fmt), + va_arg(ap, unsigned long long))); // NOLINT(runtime/int) + arg_sign = (uarg != 0); } else if (fmt_spec == 'd') { // signed switch (length_modifier) { |