From beb3660c42d93ef7386bb5158a65cb9b4fa62549 Mon Sep 17 00:00:00 2001 From: Mattes D Date: Thu, 2 Jun 2016 14:43:19 +0200 Subject: Debuggers: Added the forgotten Inject.lua file. This works as a test for inter-plugin calls, the "testcall" command injects this file into the Core plugin. --- Server/Plugins/Debuggers/Inject.lua | 57 +++++++++++++++++++++++++++++++++++++ 1 file changed, 57 insertions(+) create mode 100644 Server/Plugins/Debuggers/Inject.lua diff --git a/Server/Plugins/Debuggers/Inject.lua b/Server/Plugins/Debuggers/Inject.lua new file mode 100644 index 000000000..d707f95e5 --- /dev/null +++ b/Server/Plugins/Debuggers/Inject.lua @@ -0,0 +1,57 @@ +-- Inject.lua + +-- This file gets injected into the Core plugin when testing the inter-plugin calls with the "testcall" command +-- However, since this is a .lua file, it also gets loaded into the Debuggers plugin, so we need to distinguish the two + + + + + +--- Prints the specified table to the log, using the specified indent +-- Assumes there are no cycles in the table and all keys and values can be turned to strings +local function printTable(a_Table, a_Indent) + for k, v in pairs(a_Table) do + LOG(a_Indent .. "k = " .. tostring(k)) + if (type(k) == "table") then + printTable(k, a_Indent .. " ") + end + LOG(a_Indent .. "v = " .. tostring(v)) + if (type(v) == "table") then + printTable(v, a_Indent .. " ") + end + end +end + + + + + +local function printParams(...) + LOG("printParams:") + for idx, param in ipairs({...}) do + LOG(" param" .. idx .. ": " .. tostring(param)) + if (type(param) == "table") then + printTable(param, " ") + end + end + LOG("done") + return true +end + + + + + +local pluginName = cPluginManager:Get():GetCurrentPlugin():GetName() +if (pluginName ~= "Debuggers") then + -- We're in the destination plugin + LOG("Loaded Inject.lua into " .. pluginName) + injectedPrintParams = printParams + return true +else + -- We're in the Debuggers plugin, do nothing +end + + + + -- cgit v1.2.3