From f553d8e29e2de5030ba402cd5622aab50275b1f6 Mon Sep 17 00:00:00 2001 From: madmaxoft Date: Thu, 12 Sep 2013 18:46:37 +0200 Subject: APIDump: Fixed parsing tables with wiki-links. Also added real class name, description and constructor renaming. --- MCServer/Plugins/APIDump/main.lua | 43 ++++++++++++++++++++++++++++++--------- 1 file changed, 33 insertions(+), 10 deletions(-) (limited to 'MCServer/Plugins/APIDump') diff --git a/MCServer/Plugins/APIDump/main.lua b/MCServer/Plugins/APIDump/main.lua index 5025c28f3..c5d251445 100644 --- a/MCServer/Plugins/APIDump/main.lua +++ b/MCServer/Plugins/APIDump/main.lua @@ -18,10 +18,9 @@ g_Plugin = nil; function Initialize(Plugin) g_Plugin = Plugin; - Plugin:SetName("APIDump") - Plugin:SetVersion(1) + Plugin:SetName("APIDump"); + Plugin:SetVersion(1); - PluginManager = cRoot:Get():GetPluginManager() LOG("Initialized " .. Plugin:GetName() .. " v." .. Plugin:GetVersion()) -- dump all available API functions and objects: @@ -349,6 +348,8 @@ function ConvertWikiToDesc() for filename in io.popen([[dir wikipages\\api\\*.txt /b]]):lines() do -- Read file local fin = io.open("wikipages\\api\\" .. filename, "r"); + local ClassName = filename:match("[^\.]*"); + local AddNextTime = ""; if (fin ~= nil) then -- Read and parse the info from the file local state = 0; @@ -358,6 +359,13 @@ function ConvertWikiToDesc() for line in fin:lines() do if (line:find("======") ~= nil) then state = 1; -- The following is the class description + ClassName = line:gsub("======", ""); + ClassName = ClassName:match("%w+"); + if (ClassName == nil) then + -- Reset to default + ClassName = filename:match("[^\.]*"); + end + AddNextTime = ""; elseif (line:find("===== Constants") ~= nil) then state = 2; -- The following is the constants description elseif (line:find("===== Functions") ~= nil) then @@ -365,31 +373,46 @@ function ConvertWikiToDesc() elseif (line:find("=====") ~= nil) then state = 4; -- The following is an unknown text, skip it entirely elseif (state == 1) then + -- Class description: + Desc = Desc .. AddNextTime .. line .. "\n"; if (line == "") then - line = "

\n

"; -- Replace empty lines with paragraph delimiters + AddNextTime = "

\n

"; -- Replace empty lines with paragraph delimiters; add only when there's a followup text on next line + else + AddNextTime = ""; end - Desc = Desc .. line .. "\n"; elseif (state == 2) then + -- Constants: - local Split = StringSplitAndTrim(line, "|"); + line = line:gsub("| ", "\n"); + local Split = StringSplitAndTrim(line, "\n"); if (#Split >= 3) then -- Split[1] is always "", because the line starts with a "|" - table.insert(Constants, {Name = Split[2], Notes = Split[3]}); + local notes = Split[3] or ""; + notes = notes:sub(1, notes:len() - 2); -- Remove the trailing " |" + table.insert(Constants, {Name = Split[2], Notes = notes}); end elseif (state == 3) then + -- Functions: - local Split = StringSplitAndTrim(line, "|"); + line = string.gsub(line, "| ", "\n"); + local Split = StringSplitAndTrim(line, "\n"); if (#Split >= 5) then -- Split[1] is always "", because the line starts with a "|" - table.insert(Functions, {Name = Split[2], Params = Split[3], Return = Split[4], Notes = Split[5]}); + local notes = Split[5] or ""; + notes = notes:sub(1, notes:len() - 2); -- Remove the trailing " |" + local name = (Split[2] or ""); + if ((name == "( )") or (name == "()")) then + name = "constructor"; -- Special name is used for the constructor in the wiki + end + table.insert(Functions, {Name = name, Params = Split[3], Return = Split[4], Notes = notes}); end end end -- for line fin:close(); -- Write the info into the output file: - fout:write(filename:match("[^\.]*") .. " =\n{\n\tFunctions =\n\t{\n"); + fout:write(ClassName .. " =\n{\n\tDesc = [[" .. Desc .. "]]\n\tFunctions =\n\t{\n"); for i, func in ipairs(Functions) do fout:write("\t\t{ " .. func.Name .. " = { Params = \"" .. func.Params .. "\", Return =\"" .. func.Return .. "\", Desc = \"" .. func.Notes .. "\" },\n" -- cgit v1.2.3