Added the ChunkWorx plugin to SVN (contributed by Taugeshtu)
git-svn-id: http://mc-server.googlecode.com/svn/trunk@797 0a769ca7-a7f5-676a-18bf-c427514a06d6
This commit is contained in:
parent
66f4c9e0c0
commit
66300ea7a6
134
MCServer/Plugins/ChunkWorx/chunkworx_main.lua
Normal file
134
MCServer/Plugins/ChunkWorx/chunkworx_main.lua
Normal file
@ -0,0 +1,134 @@
|
|||||||
|
-- Global variables
|
||||||
|
PLUGIN = {} -- Reference to own plugin object
|
||||||
|
GENERATION_STATE = 0
|
||||||
|
OPERATION_CODE = 0 -- 0 = generation
|
||||||
|
CX = 0
|
||||||
|
CZ = 0
|
||||||
|
CURRENT = 0
|
||||||
|
-- AREA Variables
|
||||||
|
AreaStartX = -10
|
||||||
|
AreaStartZ = -10
|
||||||
|
AreaEndX = 10
|
||||||
|
AreaEndZ = 10
|
||||||
|
-- RADIAL Variables
|
||||||
|
RadialX = 0
|
||||||
|
RadialZ = 0
|
||||||
|
Radius = 1
|
||||||
|
-- WORLD
|
||||||
|
WORK_WORLD = cRoot:Get():GetDefaultWorld():GetName()
|
||||||
|
WW_instance = cRoot:Get():GetDefaultWorld()
|
||||||
|
WORLDS = {}
|
||||||
|
|
||||||
|
function Initialize(Plugin)
|
||||||
|
PLUGIN = Plugin
|
||||||
|
|
||||||
|
PLUGIN:SetName("ChunkWorx")
|
||||||
|
PLUGIN:SetVersion(4)
|
||||||
|
|
||||||
|
PluginManager = cRoot:Get():GetPluginManager()
|
||||||
|
PluginManager:AddHook(PLUGIN, cPluginManager.E_PLUGIN_TICK)
|
||||||
|
|
||||||
|
Plugin:AddWebTab("(Re)Generation", HandleRequest_Generation)
|
||||||
|
|
||||||
|
GENERATION_STATE = 0
|
||||||
|
WW_instance = cRoot:Get():GetWorld(WORK_WORLD)
|
||||||
|
if (WW_instance == nil) then
|
||||||
|
LOG("" .. PLUGIN:GetName() .. " v" .. PLUGIN:GetVersion() .. ": NO WORLD found :(")
|
||||||
|
end
|
||||||
|
|
||||||
|
PLUGIN.IniFile = cIniFile("ChunkWorx.ini")
|
||||||
|
if (PLUGIN.IniFile:ReadFile() == false) then
|
||||||
|
PLUGIN.IniFile:HeaderComment("ChunkWorx Save")
|
||||||
|
PLUGIN.IniFile:AddKeyName("Area data")
|
||||||
|
PLUGIN.IniFile:SetValueI("Area data", "StartX", AreaStartX)
|
||||||
|
PLUGIN.IniFile:SetValueI("Area data", "StartZ", AreaStartZ)
|
||||||
|
PLUGIN.IniFile:SetValueI("Area data", "EndX", AreaEndX)
|
||||||
|
PLUGIN.IniFile:SetValueI("Area data", "EndZ", AreaEndZ)
|
||||||
|
PLUGIN.IniFile:AddKeyName("Radial data")
|
||||||
|
PLUGIN.IniFile:SetValueI("Radial data", "RadialX", RadialX)
|
||||||
|
PLUGIN.IniFile:SetValueI("Radial data", "RadialZ", RadialZ)
|
||||||
|
PLUGIN.IniFile:SetValueI("Radial data", "Radius", Radius)
|
||||||
|
PLUGIN.IniFile:WriteFile()
|
||||||
|
end
|
||||||
|
|
||||||
|
AreaStartX = PLUGIN.IniFile:GetValueI("Area data", "StartX")
|
||||||
|
AreaStartZ = PLUGIN.IniFile:GetValueI("Area data", "StartZ")
|
||||||
|
AreaEndX = PLUGIN.IniFile:GetValueI("Area data", "EndX")
|
||||||
|
AreaEndZ = PLUGIN.IniFile:GetValueI("Area data", "EndZ")
|
||||||
|
|
||||||
|
RadialX = PLUGIN.IniFile:GetValueI("Radial data", "RadialX")
|
||||||
|
RadialZ = PLUGIN.IniFile:GetValueI("Radial data", "RadialZ")
|
||||||
|
Radius = PLUGIN.IniFile:GetValueI("Radial data", "Radius")
|
||||||
|
|
||||||
|
LOG("Initialized " .. PLUGIN:GetName() .. " v" .. PLUGIN:GetVersion())
|
||||||
|
--LOG("Test1: " .. math.fmod(1.5, 1)) - return fractional part!
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
|
||||||
|
function OnDisable()
|
||||||
|
PLUGIN.IniFile:WriteFile()
|
||||||
|
LOG(PLUGIN:GetName() .. " v" .. PLUGIN:GetVersion() .. " is shutting down...")
|
||||||
|
end
|
||||||
|
|
||||||
|
function Tick( DeltaTime )
|
||||||
|
if (GENERATION_STATE == 1 or GENERATION_STATE == 3) then
|
||||||
|
LOGINFO("" .. PLUGIN:GetName() .. " v" .. PLUGIN:GetVersion() .. ": works STARTED!")
|
||||||
|
LOGINFO("" .. PLUGIN:GetName() .. " v" .. PLUGIN:GetVersion() .. ": At world: " .. WORK_WORLD)
|
||||||
|
WW_instance = cRoot:Get():GetWorld(WORK_WORLD)
|
||||||
|
if (GENERATION_STATE == 1) then GENERATION_STATE = 2 end
|
||||||
|
if (GENERATION_STATE == 3) then GENERATION_STATE = 4 end
|
||||||
|
|
||||||
|
-- Changing in case coordinates are flipped
|
||||||
|
local shifter = AreaEndX
|
||||||
|
if (AreaStartX > AreaEndX) then
|
||||||
|
AreaEndX = AreaStartX
|
||||||
|
AreaStartX = shifter
|
||||||
|
end
|
||||||
|
shifter = AreaEndZ
|
||||||
|
if (AreaStartZ > AreaEndZ) then
|
||||||
|
AreaEndZ = AreaStartZ
|
||||||
|
AreaStartZ = shifter
|
||||||
|
end
|
||||||
|
|
||||||
|
CX = AreaStartX
|
||||||
|
CZ = AreaStartZ
|
||||||
|
CURRENT = 0
|
||||||
|
|
||||||
|
if (WW_instance == nil) then
|
||||||
|
LOG("" .. PLUGIN:GetName() .. " v" .. PLUGIN:GetVersion() .. ": works ABORTED")
|
||||||
|
LOG("" .. PLUGIN:GetName() .. " v" .. PLUGIN:GetVersion() .. ": NO WORLD found :(")
|
||||||
|
GENERATION_STATE = 0
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
if (GENERATION_STATE == 2 or GENERATION_STATE == 4) then
|
||||||
|
if (WW_instance:GetGeneratorQueueLength() < 200
|
||||||
|
and WW_instance:GetLightingQueueLength() < 200
|
||||||
|
and (WW_instance:GetStorageSaveQueueLength() + WW_instance:GetStorageLoadQueueLength()) < 80) then
|
||||||
|
local chunk_sum = (1+ AreaEndX - AreaStartX) * (1+ AreaEndZ - AreaStartZ)
|
||||||
|
LOG("" .. PLUGIN:GetName() .. " v" .. PLUGIN:GetVersion() .. ": PROCESSING 100 chunks, (" .. CURRENT .. "/" .. chunk_sum .. ")")
|
||||||
|
for C = 1, 100 do
|
||||||
|
if (GENERATION_STATE == 2) then WW_instance:GenerateChunk(CX, CZ) end
|
||||||
|
if (GENERATION_STATE == 4) then WW_instance:RegenerateChunk(CX, CZ) end
|
||||||
|
|
||||||
|
CX = CX + 1
|
||||||
|
CURRENT = CURRENT + 1
|
||||||
|
if (CX > AreaEndX) then
|
||||||
|
CX = AreaStartX
|
||||||
|
CZ = CZ + 1
|
||||||
|
if (CZ > AreaEndZ) then
|
||||||
|
if (GENERATION_STATE == 2) then LOGINFO("" .. PLUGIN:GetName() .. " v" .. PLUGIN:GetVersion() .. " - generation ENDED!") end
|
||||||
|
if (GENERATION_STATE == 4) then LOGINFO("" .. PLUGIN:GetName() .. " v" .. PLUGIN:GetVersion() .. " - REgeneration ENDED!") end
|
||||||
|
|
||||||
|
GENERATION_STATE = 0
|
||||||
|
break
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
WW_instance:SaveAllChunks()
|
||||||
|
WW_instance:UnloadUnusedChunks()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
210
MCServer/Plugins/ChunkWorx/chunkworx_web.lua
Normal file
210
MCServer/Plugins/ChunkWorx/chunkworx_web.lua
Normal file
@ -0,0 +1,210 @@
|
|||||||
|
local function Buttons_Player( Name )
|
||||||
|
return "<form method='POST'><input type='hidden' name='PlayerName' value='"..Name.."'><input type='submit' name='PlayerExact' value='Exact'><input type='submit' name='Player3x3' value='3x3'></form>"
|
||||||
|
end
|
||||||
|
|
||||||
|
local function Button_World( Name )
|
||||||
|
return "<form method='POST'><input type='hidden' name='WorldName' value='"..Name.."'><input type='submit' name='SelectWorld' value='Select'></form>"
|
||||||
|
end
|
||||||
|
|
||||||
|
function HandleRequest_Generation( Request )
|
||||||
|
local Content = ""
|
||||||
|
|
||||||
|
if ( Request.PostParams["FormSetWorld"] ) then
|
||||||
|
WORK_WORLD = Request.PostParams["FormWorldName"]
|
||||||
|
WW_instance = cRoot:Get():GetWorld(WORK_WORLD)
|
||||||
|
end
|
||||||
|
|
||||||
|
if( Request.PostParams["SelectWorld"] ~= nil
|
||||||
|
and Request.PostParams["WorldName"] ~= nil ) then -- World is selected!
|
||||||
|
WORK_WORLD = Request.PostParams["WorldName"]
|
||||||
|
WW_instance = cRoot:Get():GetWorld(WORK_WORLD)
|
||||||
|
end
|
||||||
|
|
||||||
|
if(Request.PostParams["OperationGenerate"] ~= nil) then
|
||||||
|
OPERATION_CODE = 0
|
||||||
|
end
|
||||||
|
if(Request.PostParams["OperationReGenerate"] ~= nil) then
|
||||||
|
OPERATION_CODE = 1
|
||||||
|
end
|
||||||
|
|
||||||
|
if (GENERATION_STATE == 0) then
|
||||||
|
if( Request.PostParams["FormAreaStartX"] ~= nil
|
||||||
|
and Request.PostParams["FormAreaStartZ"] ~= nil
|
||||||
|
and Request.PostParams["FormAreaEndX"] ~= nil
|
||||||
|
and Request.PostParams["FormAreaEndZ"] ~= nil ) then --(Re)Generation valid!
|
||||||
|
-- COMMON (Re)gen
|
||||||
|
if( Request.PostParams["StartArea"]) then
|
||||||
|
AreaStartX = tonumber(Request.PostParams["FormAreaStartX"])
|
||||||
|
AreaStartZ = tonumber(Request.PostParams["FormAreaStartZ"])
|
||||||
|
AreaEndX = tonumber(Request.PostParams["FormAreaEndX"])
|
||||||
|
AreaEndZ = tonumber(Request.PostParams["FormAreaEndZ"])
|
||||||
|
|
||||||
|
PLUGIN.IniFile:DeleteValue("Area data", "StartX")
|
||||||
|
PLUGIN.IniFile:DeleteValue("Area data", "StartZ")
|
||||||
|
PLUGIN.IniFile:DeleteValue("Area data", "EndX")
|
||||||
|
PLUGIN.IniFile:DeleteValue("Area data", "EndZ")
|
||||||
|
PLUGIN.IniFile:SetValueI("Area data", "StartX", AreaStartX)
|
||||||
|
PLUGIN.IniFile:SetValueI("Area data", "StartZ", AreaStartZ)
|
||||||
|
PLUGIN.IniFile:SetValueI("Area data", "EndX", AreaEndX)
|
||||||
|
PLUGIN.IniFile:SetValueI("Area data", "EndZ", AreaEndZ)
|
||||||
|
if (OPERATION_CODE == 0) then
|
||||||
|
GENERATION_STATE = 1
|
||||||
|
elseif (OPERATION_CODE == 1) then
|
||||||
|
GENERATION_STATE = 3
|
||||||
|
end
|
||||||
|
PLUGIN.IniFile:WriteFile()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if( Request.PostParams["FormRadialX"] ~= nil
|
||||||
|
and Request.PostParams["FormRadialZ"] ~= nil
|
||||||
|
and Request.PostParams["FormRadius"] ~= nil ) then --(Re)Generation valid!
|
||||||
|
-- COMMON (Re)gen
|
||||||
|
if( Request.PostParams["StartRadial"]) then
|
||||||
|
RadialX = tonumber(Request.PostParams["FormRadialX"])
|
||||||
|
RadialZ = tonumber(Request.PostParams["FormRadialZ"])
|
||||||
|
Radius = tonumber(Request.PostParams["FormRadius"])
|
||||||
|
AreaStartX = RadialX - Radius
|
||||||
|
AreaStartZ = RadialZ - Radius
|
||||||
|
AreaEndX = RadialX + Radius
|
||||||
|
AreaEndZ = RadialZ + Radius
|
||||||
|
|
||||||
|
PLUGIN.IniFile:DeleteValue("Radial data", "RadialX")
|
||||||
|
PLUGIN.IniFile:DeleteValue("Radial data", "RadialZ")
|
||||||
|
PLUGIN.IniFile:DeleteValue("Radial data", "Radius")
|
||||||
|
PLUGIN.IniFile:SetValueI("Radial data", "RadialX", RadialX)
|
||||||
|
PLUGIN.IniFile:SetValueI("Radial data", "RadialZ", RadialZ)
|
||||||
|
PLUGIN.IniFile:SetValueI("Radial data", "Radius", Radius)
|
||||||
|
if (OPERATION_CODE == 0) then
|
||||||
|
GENERATION_STATE = 1
|
||||||
|
elseif (OPERATION_CODE == 1) then
|
||||||
|
GENERATION_STATE = 3
|
||||||
|
end
|
||||||
|
PLUGIN.IniFile:WriteFile()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
-- POINT REGEN!
|
||||||
|
if( Request.PostParams["FormPointX"] ~= nil
|
||||||
|
and Request.PostParams["FormPointZ"] ~= nil ) then --ReGeneration valid!
|
||||||
|
-- EXACT
|
||||||
|
if ( Request.PostParams["PointExact"] ~= nil) then
|
||||||
|
AreaStartX = tonumber(Request.PostParams["FormPointX"])
|
||||||
|
AreaStartZ = tonumber(Request.PostParams["FormPointZ"])
|
||||||
|
AreaEndX = AreaStartX
|
||||||
|
AreaEndZ = AreaStartZ
|
||||||
|
GENERATION_STATE = 3
|
||||||
|
end
|
||||||
|
-- 3x3
|
||||||
|
if ( Request.PostParams["Point3x3"] ~= nil) then
|
||||||
|
AreaStartX = tonumber(Request.PostParams["FormPointX"]) - 1
|
||||||
|
AreaStartZ = tonumber(Request.PostParams["FormPointZ"]) - 1
|
||||||
|
AreaEndX = AreaStartX + 2
|
||||||
|
AreaEndZ = AreaStartZ + 2
|
||||||
|
GENERATION_STATE = 3
|
||||||
|
end
|
||||||
|
end
|
||||||
|
-- PLAYERS REGEN!
|
||||||
|
if( Request.PostParams["PlayerExact"] ~= nil
|
||||||
|
and Request.PostParams["PlayerName"] ~= nil ) then -- Making BOOM! I meant, regenereate...
|
||||||
|
AreaStartX = cRoot:Get():GetWorld(WORK_WORLD):GetPlayer(Request.PostParams["PlayerName"]):GetChunkX()
|
||||||
|
AreaStartZ = cRoot:Get():GetWorld(WORK_WORLD):GetPlayer(Request.PostParams["PlayerName"]):GetChunkZ()
|
||||||
|
AreaEndX = AreaStartX
|
||||||
|
AreaEndZ = AreaStartZ
|
||||||
|
GENERATION_STATE = 3
|
||||||
|
end
|
||||||
|
if( Request.PostParams["Player3x3"] ~= nil
|
||||||
|
and Request.PostParams["PlayerName"] ~= nil ) then -- Making BOOM! I meant, regenereate...
|
||||||
|
AreaStartX = cRoot:Get():GetWorld(WORK_WORLD):GetPlayer(Request.PostParams["PlayerName"]):GetChunkX() - 1
|
||||||
|
AreaStartZ = cRoot:Get():GetWorld(WORK_WORLD):GetPlayer(Request.PostParams["PlayerName"]):GetChunkZ() - 1
|
||||||
|
AreaEndX = AreaStartX + 2
|
||||||
|
AreaEndZ = AreaStartZ + 2
|
||||||
|
GENERATION_STATE = 3
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
--Content = Content .. "<h4>World for operations: " .. WORK_WORLD .. "</h4>"
|
||||||
|
--Content = Content .. "<form method='POST'>"
|
||||||
|
--Content = Content .. "<input type='text' name='FormWorldName' value='Input world name here'><input type='submit' name='FormSetWorld' value='Set world'>"
|
||||||
|
--Content = Content .. "</form>"
|
||||||
|
|
||||||
|
-- SELECTING WORK_WORLD
|
||||||
|
Content = Content .. "<h4>World for operations: " .. WORK_WORLD .. "</h4>"
|
||||||
|
Content = Content .. "<table>"
|
||||||
|
local WorldNum = 0
|
||||||
|
local AddWorldToTable = function(World)
|
||||||
|
WorldNum = WorldNum + 1
|
||||||
|
Content = Content .. "<tr>"
|
||||||
|
Content = Content .. "<td style='width: 10px;'>" .. WorldNum .. ".</td>"
|
||||||
|
Content = Content .. "<td>" .. World:GetName() .. "</td>"
|
||||||
|
Content = Content .. "<td>" .. Button_World(World:GetName()) .. "</td>"
|
||||||
|
Content = Content .. "</tr>"
|
||||||
|
end
|
||||||
|
cRoot:Get():ForEachWorld(AddWorldToTable)
|
||||||
|
if( WorldNum == 0 ) then
|
||||||
|
Content = Content .. "<tr><td>No worlds! O_O</td></tr>"
|
||||||
|
end
|
||||||
|
Content = Content .. "</table>"
|
||||||
|
Content = Content .. "<br>"
|
||||||
|
|
||||||
|
-- SELECTING OPERATION
|
||||||
|
if (OPERATION_CODE == 0) then
|
||||||
|
Content = Content .. "<h4>Operation: Generation</h4>"
|
||||||
|
elseif (OPERATION_CODE == 1) then
|
||||||
|
Content = Content .. "<h4>Operation: Regeneration</h4>"
|
||||||
|
end
|
||||||
|
Content = Content .. "<form method='POST'>"
|
||||||
|
Content = Content .. "<input type='submit' name='OperationGenerate' value='Generation'>"
|
||||||
|
Content = Content .. "<input type='submit' name='OperationReGenerate' value='Regeneration'>"
|
||||||
|
Content = Content .. "</form>"
|
||||||
|
|
||||||
|
-- SELECTING AREA
|
||||||
|
Content = Content .. "<h4>Area: </h4>Start X, Start Z; End X, End Z"
|
||||||
|
Content = Content .. "<form method='POST'>"
|
||||||
|
Content = Content .. "<input type='text' name='FormAreaStartX' value='" .. AreaStartX .. "'><input type='text' name='FormAreaStartZ' value='" .. AreaStartZ .. "'>"
|
||||||
|
Content = Content .. "<input type='text' name='FormAreaEndX' value='" .. AreaEndX .. "'><input type='text' name='FormAreaEndZ' value='" .. AreaEndZ .. "'>"
|
||||||
|
Content = Content .. "<input type='submit' name='StartArea' value='Start'>"
|
||||||
|
Content = Content .. "</form>"
|
||||||
|
|
||||||
|
-- SELECTING RADIAL
|
||||||
|
Content = Content .. "<h4>Radial: </h4>Center X, Center Z, Raduis (0 to any)"
|
||||||
|
Content = Content .. "<form method='POST'>"
|
||||||
|
Content = Content .. "<input type='text' name='FormRadialX' value='" .. RadialX .. "'><input type='text' name='FormRadialZ' value='" .. RadialZ .. "'><input type='text' name='FormRadius' value='" .. Radius .. "'>"
|
||||||
|
Content = Content .. "<input type='submit' name='StartRadial' value='Start'>"
|
||||||
|
Content = Content .. "</form>"
|
||||||
|
Content = Content .. "<br>"
|
||||||
|
Content = Content .. "<br>"
|
||||||
|
Content = Content .. "<br>"
|
||||||
|
|
||||||
|
-- SELECTING POINT
|
||||||
|
Content = Content .. "<h4>Point regeneration:</h4> X, Z"
|
||||||
|
Content = Content .. "<form method='POST'>"
|
||||||
|
Content = Content .. "<input type='text' name='FormPointX' value='0'><input type='text' name='FormPointZ' value='0'>"
|
||||||
|
Content = Content .. "<input type='submit' name='PointExact' value='Exact'>"
|
||||||
|
Content = Content .. "<input type='submit' name='Point3x3' value='3x3'>"
|
||||||
|
Content = Content .. "</form>"
|
||||||
|
|
||||||
|
-- SELECTING PLAYERS
|
||||||
|
Content = Content .. "<h4>Player-based regeneration:</h4>"
|
||||||
|
Content = Content .. "<table>"
|
||||||
|
local PlayerNum = 0
|
||||||
|
local AddPlayerToTable = function( Player )
|
||||||
|
PlayerNum = PlayerNum + 1
|
||||||
|
Content = Content .. "<tr>"
|
||||||
|
Content = Content .. "<td style='width: 10px;'>" .. PlayerNum .. ".</td>"
|
||||||
|
Content = Content .. "<td>" .. Player:GetName() .. "</td>"
|
||||||
|
Content = Content .. "<td>" .. Buttons_Player(Player:GetName()) .. "</td>"
|
||||||
|
Content = Content .. "</tr>"
|
||||||
|
end
|
||||||
|
if (cRoot:Get():GetWorld(WORK_WORLD) == nil) then
|
||||||
|
Content = Content .. "<tr><td>Incorrect world selection</td></tr>"
|
||||||
|
else
|
||||||
|
cRoot:Get():GetWorld(WORK_WORLD):ForEachPlayer( AddPlayerToTable )
|
||||||
|
if( PlayerNum == 0 ) then
|
||||||
|
Content = Content .. "<tr><td>No connected players</td></tr>"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
Content = Content .. "</table>"
|
||||||
|
Content = Content .. "<br>"
|
||||||
|
|
||||||
|
|
||||||
|
return Content
|
||||||
|
end
|
Loading…
Reference in New Issue
Block a user