diff options
author | James McCoy <jamessan@jamessan.com> | 2021-12-08 21:35:14 -0500 |
---|---|---|
committer | James McCoy <jamessan@jamessan.com> | 2021-12-08 21:48:00 -0500 |
commit | f3fb77c40262f47e30ebefec547f5c6f83ff58e6 (patch) | |
tree | a1e77a6bd4a4f2034e1c2286e741c77a5ba80cd7 /src/nvim/syntax.c | |
parent | ed35e20640ca1d5412550a2df5930b090acee57c (diff) | |
download | rneovim-f3fb77c40262f47e30ebefec547f5c6f83ff58e6.tar.gz rneovim-f3fb77c40262f47e30ebefec547f5c6f83ff58e6.tar.bz2 rneovim-f3fb77c40262f47e30ebefec547f5c6f83ff58e6.zip |
vim-patch:8.2.3757: an overlong highlight group name is silently truncated
Problem: An overlong highlight group name is silently truncated.
Solution: Give an error if the name is too long. (closes vim/vim#9289)
https://github.com/vim/vim/commit/f7f7aaf8aaad34a38d3f159e031c5bcf3394f8f1
Diffstat (limited to 'src/nvim/syntax.c')
-rw-r--r-- | src/nvim/syntax.c | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/src/nvim/syntax.c b/src/nvim/syntax.c index 7eb33d8fdc..9a133eeadf 100644 --- a/src/nvim/syntax.c +++ b/src/nvim/syntax.c @@ -115,6 +115,8 @@ static int include_none = 0; // when 1 include "nvim/None" static int include_default = 0; // when 1 include "nvim/default" static int include_link = 0; // when 2 include "nvim/link" and "clear" +#define MAX_SYN_NAME 200 + /// The "term", "cterm" and "gui" arguments can be any combination of the /// following names, separated by commas (but no spaces!). static char *(hl_name_table[]) = @@ -7625,10 +7627,9 @@ int syn_name2id(const char *name) int syn_name2id_len(const char_u *name, size_t len) FUNC_ATTR_NONNULL_ALL { - char name_u[201]; + char name_u[MAX_SYN_NAME + 1]; - if (len == 0 || len > 200) { - // ID names over 200 chars don't deserve to be found! + if (len == 0 || len > MAX_SYN_NAME) { return 0; } @@ -7686,6 +7687,10 @@ char_u *syn_id2name(int id) /// @return 0 for failure else the id of the group int syn_check_group(const char *name, int len) { + if (len > MAX_SYN_NAME) { + emsg(_(e_highlight_group_name_too_long)); + return 0; + } int id = syn_name2id_len((char_u *)name, len); if (id == 0) { // doesn't exist yet return syn_add_group(vim_strnsave((char_u *)name, len)); |