mirror of
https://github.com/neovim/neovim.git
synced 2025-09-29 22:48:34 +00:00
fix(highlight): allow globals to be cleared
- and reduce heap allocations Fixes #17420
This commit is contained in:
@@ -904,15 +904,13 @@ HlAttrs dict2hlattrs(Dict(highlight) *dict, bool use_rgb, int *link_id, Error *e
|
||||
hlattrs.rgb_bg_color = bg;
|
||||
hlattrs.rgb_fg_color = fg;
|
||||
hlattrs.rgb_sp_color = sp;
|
||||
hlattrs.cterm_bg_color =
|
||||
ctermbg == -1 ? cterm_normal_bg_color : ctermbg + 1;
|
||||
hlattrs.cterm_fg_color =
|
||||
ctermfg == -1 ? cterm_normal_fg_color : ctermfg + 1;
|
||||
hlattrs.cterm_bg_color = ctermbg == -1 ? 0 : ctermbg + 1;
|
||||
hlattrs.cterm_fg_color = ctermfg == -1 ? 0 : ctermfg + 1;
|
||||
hlattrs.cterm_ae_attr = cterm_mask;
|
||||
} else {
|
||||
hlattrs.cterm_ae_attr = cterm_mask;
|
||||
hlattrs.cterm_bg_color = bg == -1 ? cterm_normal_bg_color : bg + 1;
|
||||
hlattrs.cterm_fg_color = fg == -1 ? cterm_normal_fg_color : fg + 1;
|
||||
hlattrs.cterm_bg_color = bg == -1 ? 0 : bg + 1;
|
||||
hlattrs.cterm_fg_color = fg == -1 ? 0 : fg + 1;
|
||||
}
|
||||
|
||||
return hlattrs;
|
||||
|
@@ -6758,16 +6758,26 @@ void set_hl_group(int id, HlAttrs attrs, Dict(highlight) *dict, int link_id)
|
||||
{ NULL, -1, NIL },
|
||||
};
|
||||
|
||||
char hex_name[8];
|
||||
char *name;
|
||||
|
||||
for (int j = 0; cattrs[j].dest; j++) {
|
||||
if (cattrs[j].val != -1) {
|
||||
if (cattrs[j].val < 0) {
|
||||
XFREE_CLEAR(*cattrs[j].dest);
|
||||
continue;
|
||||
}
|
||||
|
||||
if (cattrs[j].name.type == kObjectTypeString && cattrs[j].name.data.string.size) {
|
||||
name = cattrs[j].name.data.string.data;
|
||||
} else {
|
||||
snprintf(hex_name, sizeof(hex_name), "#%06x", cattrs[j].val);
|
||||
name = hex_name;
|
||||
}
|
||||
|
||||
if (!*cattrs[j].dest
|
||||
|| STRCMP(*cattrs[j].dest, name) != 0) {
|
||||
xfree(*cattrs[j].dest);
|
||||
if (cattrs[j].name.type == kObjectTypeString && cattrs[j].name.data.string.size) {
|
||||
*cattrs[j].dest = xstrdup(cattrs[j].name.data.string.data);
|
||||
} else {
|
||||
char hex_name[8];
|
||||
snprintf(hex_name, sizeof(hex_name), "#%06x", cattrs[j].val);
|
||||
*cattrs[j].dest = xstrdup(hex_name);
|
||||
}
|
||||
*cattrs[j].dest = xstrdup(name);
|
||||
}
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user