]> git.lizzy.rs Git - dragonfireclient.git/blobdiff - src/script/lua_api/l_rollback.cpp
Merge branch 'master' of https://github.com/minetest/minetest
[dragonfireclient.git] / src / script / lua_api / l_rollback.cpp
index d5abe176e4e551c6bcf20cc04acb2bfdd10d3fea..482b0cbf58929774eb11d4e8a95dea74b503cf53 100644 (file)
@@ -21,60 +21,97 @@ with this program; if not, write to the Free Software Foundation, Inc.,
 #include "lua_api/l_internal.h"
 #include "common/c_converter.h"
 #include "server.h"
-#include "rollback.h"
+#include "rollback_interface.h"
 
 
-// rollback_get_last_node_actor(p, range, seconds) -> actor, p, seconds
-int ModApiRollback::l_rollback_get_last_node_actor(lua_State *L)
+void push_RollbackNode(lua_State *L, RollbackNode &node)
 {
-       v3s16 p = read_v3s16(L, 1);
+       lua_createtable(L, 0, 3);
+       lua_pushstring(L, node.name.c_str());
+       lua_setfield(L, -2, "name");
+       lua_pushnumber(L, node.param1);
+       lua_setfield(L, -2, "param1");
+       lua_pushnumber(L, node.param2);
+       lua_setfield(L, -2, "param2");
+}
+
+// rollback_get_node_actions(pos, range, seconds, limit) -> {{actor, pos, time, oldnode, newnode}, ...}
+int ModApiRollback::l_rollback_get_node_actions(lua_State *L)
+{
+       NO_MAP_LOCK_REQUIRED;
+
+       v3s16 pos = read_v3s16(L, 1);
        int range = luaL_checknumber(L, 2);
-       int seconds = luaL_checknumber(L, 3);
+       time_t seconds = (time_t) luaL_checknumber(L, 3);
+       int limit = luaL_checknumber(L, 4);
        Server *server = getServer(L);
        IRollbackManager *rollback = server->getRollbackManager();
-       v3s16 act_p;
-       int act_seconds = 0;
-       std::string actor = rollback->getLastNodeActor(p, range, seconds, &act_p, &act_seconds);
-       lua_pushstring(L, actor.c_str());
-       push_v3s16(L, act_p);
-       lua_pushnumber(L, act_seconds);
-       return 3;
+       if (rollback == NULL) {
+               return 0;
+       }
+
+       std::list<RollbackAction> actions = rollback->getNodeActors(pos, range, seconds, limit);
+       std::list<RollbackAction>::iterator iter = actions.begin();
+
+       lua_createtable(L, actions.size(), 0);
+       for (unsigned int i = 1; iter != actions.end(); ++iter, ++i) {
+               lua_createtable(L, 0, 5); // Make a table with enough space pre-allocated
+
+               lua_pushstring(L, iter->actor.c_str());
+               lua_setfield(L, -2, "actor");
+
+               push_v3s16(L, iter->p);
+               lua_setfield(L, -2, "pos");
+
+               lua_pushnumber(L, iter->unix_time);
+               lua_setfield(L, -2, "time");
+
+               push_RollbackNode(L, iter->n_old);
+               lua_setfield(L, -2, "oldnode");
+
+               push_RollbackNode(L, iter->n_new);
+               lua_setfield(L, -2, "newnode");
+
+               lua_rawseti(L, -2, i); // Add action table to main table
+       }
+
+       return 1;
 }
 
 // rollback_revert_actions_by(actor, seconds) -> bool, log messages
 int ModApiRollback::l_rollback_revert_actions_by(lua_State *L)
 {
+       MAP_LOCK_REQUIRED;
+
        std::string actor = luaL_checkstring(L, 1);
        int seconds = luaL_checknumber(L, 2);
        Server *server = getServer(L);
        IRollbackManager *rollback = server->getRollbackManager();
+
+       // If rollback is disabled, tell it's not a success.
+       if (rollback == NULL) {
+               lua_pushboolean(L, false);
+               lua_newtable(L);
+               return 2;
+       }
        std::list<RollbackAction> actions = rollback->getRevertActions(actor, seconds);
        std::list<std::string> log;
        bool success = server->rollbackRevertActions(actions, &log);
        // Push boolean result
        lua_pushboolean(L, success);
-       // Get the table insert function and push the log table
-       lua_getglobal(L, "table");
-       lua_getfield(L, -1, "insert");
-       int table_insert = lua_gettop(L);
-       lua_newtable(L);
-       int table = lua_gettop(L);
-       for(std::list<std::string>::const_iterator i = log.begin();
-                       i != log.end(); i++)
-       {
-               lua_pushvalue(L, table_insert);
-               lua_pushvalue(L, table);
-               lua_pushstring(L, i->c_str());
-               if(lua_pcall(L, 2, 0, 0))
-                       script_error(L);
+       lua_createtable(L, log.size(), 0);
+       unsigned long i = 0;
+       for(std::list<std::string>::const_iterator iter = log.begin();
+                       iter != log.end(); ++i, ++iter) {
+               lua_pushnumber(L, i);
+               lua_pushstring(L, iter->c_str());
+               lua_settable(L, -3);
        }
-       lua_remove(L, -2); // Remove table
-       lua_remove(L, -2); // Remove insert
        return 2;
 }
 
 void ModApiRollback::Initialize(lua_State *L, int top)
 {
-       API_FCT(rollback_get_last_node_actor);
+       API_FCT(rollback_get_node_actions);
        API_FCT(rollback_revert_actions_by);
 }