aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJustin M. Keyes <justinkz@gmail.com>2017-10-22 16:43:43 +0200
committerGitHub <noreply@github.com>2017-10-22 16:43:43 +0200
commite35a66d39670d19d50bf732b3058c12e33c77440 (patch)
tree18d59f4cae60977f1c4deba7d405b9fbc032a3b0
parent42b80c3acfbb0f813a62c382b947d7d0d5477009 (diff)
parenta3134bc4809dff52cc9a635103a48b48d7c2d148 (diff)
downloadrneovim-e35a66d39670d19d50bf732b3058c12e33c77440.tar.gz
rneovim-e35a66d39670d19d50bf732b3058c12e33c77440.tar.bz2
rneovim-e35a66d39670d19d50bf732b3058c12e33c77440.zip
Merge #7430 'Ignore virtcols after 32000'
-rw-r--r--src/nvim/misc1.c4
-rw-r--r--test/functional/options/tabstop_spec.lua23
2 files changed, 25 insertions, 2 deletions
diff --git a/src/nvim/misc1.c b/src/nvim/misc1.c
index 5270687a4d..137de84953 100644
--- a/src/nvim/misc1.c
+++ b/src/nvim/misc1.c
@@ -1273,8 +1273,8 @@ int plines_win_nofold(win_T *wp, linenr_T lnum)
* Add column offset for 'number', 'relativenumber' and 'foldcolumn'.
*/
width = wp->w_width - win_col_off(wp);
- if (width <= 0) {
- return 32000; // bigger than the number of lines of the screen
+ if (width <= 0 || col > 32000) {
+ return 32000; // bigger than the number of screen columns
}
if (col <= (unsigned int)width) {
return 1;
diff --git a/test/functional/options/tabstop_spec.lua b/test/functional/options/tabstop_spec.lua
new file mode 100644
index 0000000000..dc3ba38438
--- /dev/null
+++ b/test/functional/options/tabstop_spec.lua
@@ -0,0 +1,23 @@
+local helpers = require('test.functional.helpers')(after_each)
+
+local clear = helpers.clear
+local feed = helpers.feed
+local eq = helpers.eq
+local eval = helpers.eval
+
+describe("'tabstop' option", function()
+ before_each(function()
+ clear()
+ end)
+
+ -- NOTE: Setting 'tabstop' to a big number reproduces crash #2838.
+ -- Disallowing big 'tabstop' would not fix #2838, only hide it.
+ it("tabstop=<big-number> does not crash #2838", function()
+ -- Insert a <Tab> character for 'tabstop' to work with.
+ feed('i<Tab><Esc>')
+ -- Set 'tabstop' to a very high value.
+ -- Use feed(), not command(), to provoke crash.
+ feed(':set tabstop=3000000000<CR>')
+ eq(2, eval("1+1")) -- Still alive?
+ end)
+end)