diff --git a/MCServer/Plugins/ChunkWorx/chunkworx_main.lua b/MCServer/Plugins/ChunkWorx/chunkworx_main.lua new file mode 100644 index 000000000..26f9ca624 --- /dev/null +++ b/MCServer/Plugins/ChunkWorx/chunkworx_main.lua @@ -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 \ No newline at end of file diff --git a/MCServer/Plugins/ChunkWorx/chunkworx_web.lua b/MCServer/Plugins/ChunkWorx/chunkworx_web.lua new file mode 100644 index 000000000..7bc4bc4e9 --- /dev/null +++ b/MCServer/Plugins/ChunkWorx/chunkworx_web.lua @@ -0,0 +1,210 @@ +local function Buttons_Player( Name ) + return "
" +end + +local function Button_World( Name ) + return "
" +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 .. "

World for operations: " .. WORK_WORLD .. "

" + --Content = Content .. "
" + --Content = Content .. "" + --Content = Content .. "
" + + -- SELECTING WORK_WORLD + Content = Content .. "

World for operations: " .. WORK_WORLD .. "

" + Content = Content .. "" + local WorldNum = 0 + local AddWorldToTable = function(World) + WorldNum = WorldNum + 1 + Content = Content .. "" + Content = Content .. "" + Content = Content .. "" + Content = Content .. "" + Content = Content .. "" + end + cRoot:Get():ForEachWorld(AddWorldToTable) + if( WorldNum == 0 ) then + Content = Content .. "" + end + Content = Content .. "
" .. WorldNum .. "." .. World:GetName() .. "" .. Button_World(World:GetName()) .. "
No worlds! O_O
" + Content = Content .. "
" + + -- SELECTING OPERATION + if (OPERATION_CODE == 0) then + Content = Content .. "

Operation: Generation

" + elseif (OPERATION_CODE == 1) then + Content = Content .. "

Operation: Regeneration

" + end + Content = Content .. "
" + Content = Content .. "" + Content = Content .. "" + Content = Content .. "
" + + -- SELECTING AREA + Content = Content .. "

Area:

Start X, Start Z; End X, End Z" + Content = Content .. "
" + Content = Content .. "" + Content = Content .. "" + Content = Content .. "" + Content = Content .. "
" + + -- SELECTING RADIAL + Content = Content .. "

Radial:

Center X, Center Z, Raduis (0 to any)" + Content = Content .. "
" + Content = Content .. "" + Content = Content .. "" + Content = Content .. "
" + Content = Content .. "
" + Content = Content .. "
" + Content = Content .. "
" + + -- SELECTING POINT + Content = Content .. "

Point regeneration:

X, Z" + Content = Content .. "
" + Content = Content .. "" + Content = Content .. "" + Content = Content .. "" + Content = Content .. "
" + + -- SELECTING PLAYERS + Content = Content .. "

Player-based regeneration:

" + Content = Content .. "" + local PlayerNum = 0 + local AddPlayerToTable = function( Player ) + PlayerNum = PlayerNum + 1 + Content = Content .. "" + Content = Content .. "" + Content = Content .. "" + Content = Content .. "" + Content = Content .. "" + end + if (cRoot:Get():GetWorld(WORK_WORLD) == nil) then + Content = Content .. "" + else + cRoot:Get():GetWorld(WORK_WORLD):ForEachPlayer( AddPlayerToTable ) + if( PlayerNum == 0 ) then + Content = Content .. "" + end + end + Content = Content .. "
" .. PlayerNum .. "." .. Player:GetName() .. "" .. Buttons_Player(Player:GetName()) .. "
Incorrect world selection
No connected players
" + Content = Content .. "
" + + + return Content +end \ No newline at end of file