From beabe14c92c7b27158616070aad03739b96e8955 Mon Sep 17 00:00:00 2001 From: Anon Date: Fri, 31 Mar 2023 17:27:19 +0200 Subject: [PATCH 1/2] Updated Farm Bot for 1.19.3 and 1.19.4 --- MinecraftClient/ChatBots/Farmer.cs | 87 ++++++++++++++++++++++++++---- 1 file changed, 78 insertions(+), 9 deletions(-) diff --git a/MinecraftClient/ChatBots/Farmer.cs b/MinecraftClient/ChatBots/Farmer.cs index b035e22c..24d03e31 100644 --- a/MinecraftClient/ChatBots/Farmer.cs +++ b/MinecraftClient/ChatBots/Farmer.cs @@ -571,7 +571,17 @@ namespace MinecraftClient.ChatBots switch (cropType) { case CropType.Beetroot: - if (protocolVersion >= Protocol18Handler.MC_1_19_Version && protocolVersion <= Protocol18Handler.MC_1_19_2_Version) + if (protocolVersion == Protocol18Handler.MC_1_19_4_Version) + { + if (block.BlockId == 12356) + return true; + } + else if (protocolVersion == Protocol18Handler.MC_1_19_3_Version) + { + if (block.BlockId == 11887) + return true; + } + else if (protocolVersion >= Protocol18Handler.MC_1_19_Version && protocolVersion <= Protocol18Handler.MC_1_19_2_Version) { if (block.BlockId == 10103) return true; @@ -600,7 +610,17 @@ namespace MinecraftClient.ChatBots break; case CropType.Carrot: - if (protocolVersion >= Protocol18Handler.MC_1_19_Version && protocolVersion <= Protocol18Handler.MC_1_19_2_Version) + if (protocolVersion == Protocol18Handler.MC_1_19_4_Version) + { + if (block.BlockId == 8598) + return true; + } + else if (protocolVersion == Protocol18Handler.MC_1_19_3_Version) + { + if (block.BlockId == 8370) + return true; + } + else if (protocolVersion >= Protocol18Handler.MC_1_19_Version && protocolVersion <= Protocol18Handler.MC_1_19_2_Version) { if (block.BlockId == 6930) return true; @@ -630,7 +650,17 @@ namespace MinecraftClient.ChatBots // Checkin for stems and attached stems instead of Melons themselves case CropType.Melon: - if (protocolVersion >= Protocol18Handler.MC_1_19_Version && protocolVersion <= Protocol18Handler.MC_1_19_2_Version) + if (protocolVersion == Protocol18Handler.MC_1_19_4_Version) + { + if (block.BlockId == 6808 || block.BlockId == 6606) + return true; + } + else if (protocolVersion == Protocol18Handler.MC_1_19_3_Version) + { + if (block.BlockId == 6582 || block.BlockId == 6832) + return true; + } + else if (protocolVersion >= Protocol18Handler.MC_1_19_Version && protocolVersion <= Protocol18Handler.MC_1_19_2_Version) { if (block.BlockId == 5166 || block.BlockId == 5150) return true; @@ -656,10 +686,19 @@ namespace MinecraftClient.ChatBots return true; } break; - - // Checkin for stems and attached stems instead of Melons themselves + case CropType.Netherwart: - if (protocolVersion >= Protocol18Handler.MC_1_19_Version && protocolVersion <= Protocol18Handler.MC_1_19_2_Version) + if (protocolVersion == Protocol18Handler.MC_1_19_4_Version) + { + if (block.BlockId == 7384) + return true; + } + else if (protocolVersion == Protocol18Handler.MC_1_19_3_Version) + { + if (block.BlockId == 7158) + return true; + } + else if (protocolVersion >= Protocol18Handler.MC_1_19_Version && protocolVersion <= Protocol18Handler.MC_1_19_2_Version) { if (block.BlockId == 5718) return true; @@ -688,7 +727,17 @@ namespace MinecraftClient.ChatBots // Checkin for stems and attached stems instead of Pumpkins themselves case CropType.Pumpkin: - if (protocolVersion >= Protocol18Handler.MC_1_19_Version && protocolVersion <= Protocol18Handler.MC_1_19_2_Version) + if (protocolVersion == Protocol18Handler.MC_1_19_4_Version) + { + if (block.BlockId == 5845 || block.BlockId == 6824) + return true; + } + else if (protocolVersion == Protocol18Handler.MC_1_19_3_Version) + { + if (block.BlockId == 5683 || block.BlockId == 6598) + return true; + } + else if (protocolVersion >= Protocol18Handler.MC_1_19_Version && protocolVersion <= Protocol18Handler.MC_1_19_2_Version) { if (block.BlockId == 5158 || block.BlockId == 5146) return true; @@ -716,7 +765,17 @@ namespace MinecraftClient.ChatBots break; case CropType.Potato: - if (protocolVersion >= Protocol18Handler.MC_1_19_Version && protocolVersion <= Protocol18Handler.MC_1_19_2_Version) + if (protocolVersion == Protocol18Handler.MC_1_19_4_Version) + { + if (block.BlockId == 8606) + return true; + } + else if (protocolVersion == Protocol18Handler.MC_1_19_3_Version) + { + if (block.BlockId == 8378) + return true; + } + else if (protocolVersion >= Protocol18Handler.MC_1_19_Version && protocolVersion <= Protocol18Handler.MC_1_19_2_Version) { if (block.BlockId == 6938) return true; @@ -745,7 +804,17 @@ namespace MinecraftClient.ChatBots break; case CropType.Wheat: - if (protocolVersion >= Protocol18Handler.MC_1_19_Version && protocolVersion <= Protocol18Handler.MC_1_19_2_Version) + if (protocolVersion == Protocol18Handler.MC_1_19_4_Version) + { + if (block.BlockId == 4281) + return true; + } + else if (protocolVersion == Protocol18Handler.MC_1_19_3_Version) + { + if (block.BlockId == 4233) + return true; + } + else if (protocolVersion >= Protocol18Handler.MC_1_19_Version && protocolVersion <= Protocol18Handler.MC_1_19_2_Version) { if (block.BlockId == 3619) return true; From 0a57c927d7322888b04a7e8b1125fdf46489e520 Mon Sep 17 00:00:00 2001 From: Anon Date: Fri, 31 Mar 2023 18:17:03 +0200 Subject: [PATCH 2/2] Added access to App Vars inside the Chat Bot API via 3 new methods. Added access to Random class inside the execif command --- MinecraftClient/Commands/ExecIf.cs | 24 ++------------------- MinecraftClient/Scripting/ChatBot.cs | 31 ++++++++++++++++++++++++++++ 2 files changed, 33 insertions(+), 22 deletions(-) diff --git a/MinecraftClient/Commands/ExecIf.cs b/MinecraftClient/Commands/ExecIf.cs index 1e441794..ca985bf4 100644 --- a/MinecraftClient/Commands/ExecIf.cs +++ b/MinecraftClient/Commands/ExecIf.cs @@ -45,35 +45,15 @@ namespace MinecraftClient.Commands { var interpreter = new Interpreter(); interpreter.SetVariable("MCC", handler); + interpreter.SetVariable("random", new Random()); foreach (KeyValuePair entry in Settings.Config.AppVar.GetVariables()) interpreter.SetVariable(entry.Key, entry.Value); var result = interpreter.Eval(expressionText); - - bool shouldExec = result; - - /*if (result is bool) - shouldExec = (bool)result; - else if (result is string) - shouldExec = !string.IsNullOrEmpty((string)result) && ((string)result).Trim().Contains("true", StringComparison.OrdinalIgnoreCase); - else if (result is int) - shouldExec = (int)result > 0; - else if (result is double) - shouldExec = (double)result > 0; - else if (result is float) - shouldExec = (float)result > 0; - else if (result is Int16) - shouldExec = (Int16)result > 0; - else if (result is Int32) - shouldExec = (Int32)result > 0; - else if (result is Int64) - shouldExec = (Int64)result > 0; - */ - handler.Log.Debug("[Execif] Result Type: " + result.GetType().Name); - if (shouldExec) + if (result) { CmdResult output = new(); handler.PerformInternalCommand(resultCommand, ref output); diff --git a/MinecraftClient/Scripting/ChatBot.cs b/MinecraftClient/Scripting/ChatBot.cs index 67bc3cb5..f8ca97cd 100644 --- a/MinecraftClient/Scripting/ChatBot.cs +++ b/MinecraftClient/Scripting/ChatBot.cs @@ -977,6 +977,37 @@ namespace MinecraftClient.Scripting { Handler.BotLoad(chatBot); } + + /// + /// Set an App Variable + /// + /// App variable name + /// App variable value + /// void + protected void SetAppVar(string name, object value) + { + Config.AppVar.SetVar(name, value); + } + + /// + /// Get a value from an App Variable + /// + /// App variable name + /// App Variable value + protected object? GetAppVar(string name) + { + return Config.AppVar.GetVar(name); + } + + /// + /// Replaces variables in text with their values from the App Var registry + /// + /// Your text with variables + /// text with variables replaced with their values + protected string ExpandAppVars(string text) + { + return Config.AppVar.ExpandVars(text); + } /// /// Check whether Terrain and Movements is enabled.