Skip to content

Commit

Permalink
get xlsxio Lua API working
Browse files Browse the repository at this point in the history
  • Loading branch information
myk002 committed Aug 9, 2020
1 parent 18f4786 commit 8c7fb80
Showing 1 changed file with 31 additions and 13 deletions.
44 changes: 31 additions & 13 deletions library/LuaApi.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2486,39 +2486,57 @@ static const LuaWrapper::FunctionReg dfhack_kitchen_module[] = {
static const LuaWrapper::FunctionReg dfhack_xlsxreader_module[] = {
WRAPM(XlsxReader, open_xlsx_file),
WRAPM(XlsxReader, close_xlsx_file),
WRAPM(XlsxReader, list_sheets),
WRAPM(XlsxReader, open_sheet),
WRAPM(XlsxReader, close_sheet),
WRAPM(XlsxReader, get_next_row),
{NULL, NULL}
};

// takes the sheet handle and returns a string, or nil if there is no next cell
// in the current row.
static int xlsxreader_get_next_cell(lua_State *L)
// internal function to factor out handle extraction
static void * get_xlsxreader_handle(lua_State *L)
{
if (lua_gettop(L) != 1 || lua_isnil(L, 1))
if (lua_gettop(L) < 1 || lua_isnil(L, 1))
{
luaL_error(L, "invalid sheet handle");
luaL_error(L, "invalid xlsxreader handle");
}
luaL_checktype(L, 1, LUA_TUSERDATA);
XlsxReader::xlsx_sheet_handle sheet_handle = lua_touserdata(L, 1);
luaL_checktype(L, 1, LUA_TLIGHTUSERDATA);
return lua_touserdata(L, 1);
}

// takes a file handle and returns a table-list of sheet names
static int xlsxreader_list_sheets(lua_State *L)
{
XlsxReader::xlsx_file_handle file_handle = get_xlsxreader_handle(L);
Lua::PushVector(L, XlsxReader::list_sheets(file_handle), true);
return 1;
}

std::string value;
bool ok = XlsxReader::get_next_cell(sheet_handle, value);
// takes the sheet handle and returns a table-list of strings, or nil if we
// already processed the last row in the file.
static int xlsxreader_get_row(lua_State *L)
{
XlsxReader::xlsx_sheet_handle sheet_handle = get_xlsxreader_handle(L);
bool ok = XlsxReader::get_next_row(sheet_handle);
if (!ok)
{
lua_pushnil(L);
}
else
{
lua_pushstring(L, value.c_str());
std::string value;
auto cells = std::vector<std::string>();
while (XlsxReader::get_next_cell(sheet_handle, value))
{
cells.push_back(value);
}
Lua::PushVector(L, cells, true);
}

return 1;
}

static const luaL_Reg dfhack_xlsxreader_funcs[] = {
{"get_next_cell", xlsxreader_get_next_cell},
{"list_sheets", xlsxreader_list_sheets},
{"get_row", xlsxreader_get_row},
{NULL, NULL}
};

Expand Down

0 comments on commit 8c7fb80

Please sign in to comment.