aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/api/vim.c
diff options
context:
space:
mode:
authorbfredl <bjorn.linse@gmail.com>2023-09-19 12:32:41 +0200
committerGitHub <noreply@github.com>2023-09-19 12:32:41 +0200
commit1db45a9c1fd68e57611829a9363212a39f3c55d6 (patch)
tree512daeff103353e06d8c82deaad4d5040b99d468 /src/nvim/api/vim.c
parent2de5cddeb197502c8b3ecf5e7eb1ac929cc2307f (diff)
parent8da986ea877b07a5eb117446f410f2a7fc8cd9cb (diff)
downloadrneovim-1db45a9c1fd68e57611829a9363212a39f3c55d6.tar.gz
rneovim-1db45a9c1fd68e57611829a9363212a39f3c55d6.tar.bz2
rneovim-1db45a9c1fd68e57611829a9363212a39f3c55d6.zip
Merge pull request #25214 from bfredl/glyphcache
refactor(grid): change schar_T representation to be more compact
Diffstat (limited to 'src/nvim/api/vim.c')
-rw-r--r--src/nvim/api/vim.c9
1 files changed, 8 insertions, 1 deletions
diff --git a/src/nvim/api/vim.c b/src/nvim/api/vim.c
index 916409b973..0a94b8aafc 100644
--- a/src/nvim/api/vim.c
+++ b/src/nvim/api/vim.c
@@ -1947,7 +1947,9 @@ Array nvim__inspect_cell(Integer grid, Integer row, Integer col, Arena *arena, E
}
ret = arena_array(arena, 3);
size_t off = g->line_offset[(size_t)row] + (size_t)col;
- ADD_C(ret, CSTR_AS_OBJ((char *)g->chars[off]));
+ char *sc_buf = arena_alloc(arena, MAX_SCHAR_SIZE, false);
+ schar_get(sc_buf, g->chars[off]);
+ ADD_C(ret, CSTR_AS_OBJ(sc_buf));
int attr = g->attrs[off];
ADD_C(ret, DICTIONARY_OBJ(hl_get_attr_by_id(attr, true, arena, err)));
// will not work first time
@@ -1963,6 +1965,11 @@ void nvim__screenshot(String path)
ui_call_screenshot(path);
}
+void nvim__invalidate_glyph_cache(void)
+{
+ schar_cache_clear_force();
+}
+
Object nvim__unpack(String str, Error *err)
FUNC_API_FAST
{