fix(coverity/348300): free memory when overiding sing attribute

Nothing prevent the user from doing `:sign define abc culhl=Normal
culhl=Normal` and thus this leads to an obvious memory leak.
This commit is contained in:
Thomas Vigouroux 2022-06-24 08:29:15 +02:00
parent fd3008a6ae
commit 89f75dcd1f
No known key found for this signature in database
GPG Key ID: 16A6001CD57B9100
2 changed files with 14 additions and 1 deletions

View File

@ -1176,21 +1176,27 @@ static void sign_define_cmd(char_u *sign_name, char_u *cmdline)
p = skiptowhite_esc(arg); p = skiptowhite_esc(arg);
if (STRNCMP(arg, "icon=", 5) == 0) { if (STRNCMP(arg, "icon=", 5) == 0) {
arg += 5; arg += 5;
XFREE_CLEAR(icon);
icon = vim_strnsave(arg, (size_t)(p - arg)); icon = vim_strnsave(arg, (size_t)(p - arg));
} else if (STRNCMP(arg, "text=", 5) == 0) { } else if (STRNCMP(arg, "text=", 5) == 0) {
arg += 5; arg += 5;
XFREE_CLEAR(text);
text = vim_strnsave(arg, (size_t)(p - arg)); text = vim_strnsave(arg, (size_t)(p - arg));
} else if (STRNCMP(arg, "linehl=", 7) == 0) { } else if (STRNCMP(arg, "linehl=", 7) == 0) {
arg += 7; arg += 7;
XFREE_CLEAR(linehl);
linehl = vim_strnsave(arg, (size_t)(p - arg)); linehl = vim_strnsave(arg, (size_t)(p - arg));
} else if (STRNCMP(arg, "texthl=", 7) == 0) { } else if (STRNCMP(arg, "texthl=", 7) == 0) {
arg += 7; arg += 7;
XFREE_CLEAR(texthl);
texthl = vim_strnsave(arg, (size_t)(p - arg)); texthl = vim_strnsave(arg, (size_t)(p - arg));
} else if (STRNCMP(arg, "culhl=", 6) == 0) { } else if (STRNCMP(arg, "culhl=", 6) == 0) {
arg += 6; arg += 6;
XFREE_CLEAR(culhl);
culhl = vim_strnsave(arg, (size_t)(p - arg)); culhl = vim_strnsave(arg, (size_t)(p - arg));
} else if (STRNCMP(arg, "numhl=", 6) == 0) { } else if (STRNCMP(arg, "numhl=", 6) == 0) {
arg += 6; arg += 6;
XFREE_CLEAR(numhl);
numhl = vim_strnsave(arg, (size_t)(p - arg)); numhl = vim_strnsave(arg, (size_t)(p - arg));
} else { } else {
semsg(_(e_invarg2), arg); semsg(_(e_invarg2), arg);

View File

@ -1,5 +1,5 @@
local helpers = require('test.functional.helpers')(after_each) local helpers = require('test.functional.helpers')(after_each)
local clear, nvim, eq = helpers.clear, helpers.nvim, helpers.eq local clear, nvim, eq, assert_alive = helpers.clear, helpers.nvim, helpers.eq, helpers.assert_alive
describe('sign', function() describe('sign', function()
before_each(clear) before_each(clear)
@ -21,4 +21,11 @@ describe('sign', function()
end) end)
end) end)
end) end)
describe('define {id}', function()
it ('does not leak memory when specifying multiple times the same argument', function()
nvim('command', 'sign define Foo culhl=Normal culhl=Normal')
assert_alive()
end)
end)
end) end)