From 7f630cebddcf6d0b8a31632af7ed617f4173a6e1 Mon Sep 17 00:00:00 2001 From: ailurux Date: Fri, 19 Apr 2024 02:06:37 +0000 Subject: daniel/recycler-list (#66) @cooljqln should be good to merge to main, give it a look over though please? :) Reviewed-on: https://codeberg.org/cool-tech-zone/tangara-fw/pulls/66 Co-authored-by: ailurux Co-committed-by: ailurux --- src/lua/lua_database.cpp | 14 ++++++++++++++ 1 file changed, 14 insertions(+) (limited to 'src/lua') diff --git a/src/lua/lua_database.cpp b/src/lua/lua_database.cpp index 57cefbbc..d0612fdd 100644 --- a/src/lua/lua_database.cpp +++ b/src/lua/lua_database.cpp @@ -160,6 +160,19 @@ static auto push_iterator(lua_State* state, const database::Iterator& it) luaL_setmetatable(state, kDbIteratorMetatable); } +static auto db_iterate_prev(lua_State* state) -> int { + database::Iterator* it = db_check_iterator(state, 1); + std::optional res = (*it)--; + + if (res) { + push_lua_record(state, *res); + } else { + lua_pushnil(state); + } + + return 1; +} + static auto db_iterate(lua_State* state) -> int { database::Iterator* it = db_check_iterator(state, 1); std::optional res = (*it)++; @@ -186,6 +199,7 @@ static auto db_iterator_gc(lua_State* state) -> int { } static const struct luaL_Reg kDbIteratorFuncs[] = {{"next", db_iterate}, + {"prev", db_iterate_prev}, {"clone", db_iterator_clone}, {"__call", db_iterate}, {"__gc", db_iterator_gc}, -- cgit v1.2.3