vis

a vi-like editor based on Plan 9's structural regular expressions

git clone https://9o.is/git/vis.git

commit 144492710c21827ad762a62675ec7462c834e325
parent f6109002fa95a11df04aab5897af79682434e7a9
Author: Marc André Tanner <mat@brain-dump.org>
Date:   Thu, 17 Sep 2020 14:52:50 +0200

vis-lua: use utility function to translate mark names

Diffstat:
Mvis-lua.c | 16+++++++---------
1 file changed, 7 insertions(+), 9 deletions(-)

diff --git a/vis-lua.c b/vis-lua.c @@ -683,22 +683,20 @@ static int files_iter(lua_State *L) { */ static int mark_names_iter(lua_State *L); static int mark_names(lua_State *L) { + Vis *vis = obj_ref_check(L, 1, "vis"); + lua_pushlightuserdata(L, vis); enum VisMark *handle = lua_newuserdata(L, sizeof *handle); *handle = 0; - lua_pushcclosure(L, mark_names_iter, 1); + lua_pushcclosure(L, mark_names_iter, 2); return 1; } static int mark_names_iter(lua_State *L) { - char mark = '\0'; - enum VisMark *handle = lua_touserdata(L, lua_upvalueindex(1)); - if (*handle < LENGTH(vis_marks)) - mark = vis_marks[*handle].name; - else if (VIS_MARK_a <= *handle && *handle <= VIS_MARK_z) - mark = 'a' + *handle - VIS_MARK_a; + Vis *vis = lua_touserdata(L, lua_upvalueindex(1)); + enum VisMark *handle = lua_touserdata(L, lua_upvalueindex(2)); + char mark = vis_mark_to(vis, *handle); if (mark) { - char name[2] = { mark, '\0' }; - lua_pushstring(L, name); + lua_pushlstring(L, &mark, 1); (*handle)++; return 1; }