Planes updated to hopefully address out of range exceptions.

This commit is contained in:
barelyprofessional
2025-10-08 20:48:42 -05:00
parent bf18fe1de6
commit d6bac6706d
+31 -12
View File
@@ -221,8 +221,8 @@ public class KenoCommand : ICommand
if (displayMessage.Length <= 79 && displayMessage.Contains(BlankSpaceDisplay) && if (displayMessage.Length <= 79 && displayMessage.Contains(BlankSpaceDisplay) &&
(displayMessage.Contains(CasinoNumberDisplay) || displayMessage.Contains(MatchRevealDisplay) || (displayMessage.Contains(CasinoNumberDisplay) || displayMessage.Contains(MatchRevealDisplay) ||
frame == 9)) continue; //every board should have blank spaces and casino numbers or matches. player numbers might be hidden by matches frame == 9)) continue; //every board should have blank spaces and casino numbers or matches. player numbers might be hidden by matches
logger.Info($"Casino numbers: {string.Join(",", casinoNumbers)} | Player Numbers: {string.Join(",", playerNumbers)} | Matches: {string.Join(",", matches)} | Frame: {frame - 1} | Display Board:"); logger.Error($"Casino numbers: {string.Join(",", casinoNumbers)} | Player Numbers: {string.Join(",", playerNumbers)} | Matches: {string.Join(",", matches)} | Frame: {frame - 1} | Display Board:");
logger.Info(displayMessage); logger.Error(displayMessage);
await botInstance.SendChatMessageAsync($"Keno is bugged dewd, died on frame {frame} :bossman:", true); await botInstance.SendChatMessageAsync($"Keno is bugged dewd, died on frame {frame} :bossman:", true);
} }
} }
@@ -276,6 +276,7 @@ public class Planes : ICommand
public async Task RunCommand(ChatBot botInstance, MessageModel message, UserDbModel user, GroupCollection arguments, public async Task RunCommand(ChatBot botInstance, MessageModel message, UserDbModel user, GroupCollection arguments,
CancellationToken ctx) CancellationToken ctx)
{ {
var logger = LogManager.GetCurrentClassLogger();
if (!arguments.TryGetValue("amount", out var amount)) if (!arguments.TryGetValue("amount", out var amount))
{ {
await botInstance.SendChatMessageAsync($"{user.FormatUsername()}, not enough arguments. !planes <wager>", true); await botInstance.SendChatMessageAsync($"{user.FormatUsername()}, not enough arguments. !planes <wager>", true);
@@ -314,36 +315,52 @@ public class Planes : ICommand
await Task.Delay(TimeSpan.FromMilliseconds(frameLength / 3), ctx); await Task.Delay(TimeSpan.FromMilliseconds(frameLength / 3), ctx);
var neutral = false; var neutral = false;
var frameCounter = 0; var frameCounter = 0;
while (counter % 28 < 3) if (counter % 23 < 3)
{
while (counter % 23 < 3)
{ {
planesDisplay = GetGameBoard(counter, planesBoard, plane, carrierCount, noseUp); planesDisplay = GetGameBoard(counter, planesBoard, plane, carrierCount, noseUp);
await botInstance.KfClient.EditMessageAsync(msgId.ChatMessageId!.Value, planesDisplay); await botInstance.KfClient.EditMessageAsync(msgId.ChatMessageId!.Value, planesDisplay);
await Task.Delay(TimeSpan.FromMilliseconds(frameLength), ctx); await Task.Delay(TimeSpan.FromMilliseconds(frameLength), ctx);
counter++; counter++;
} }
logger.Info("Pregame frames successfully generated.");
}
else
{
while (!neutral) while (!neutral)
{ {
frameCounter++; frameCounter++;
switch (planesBoard[plane.Height, counter%28 - 3]) try
{
switch (planesBoard[plane.Height, counter % 23 - 3])
{ {
case 0: //do nothing plane hit neutral space case 0: //do nothing plane hit neutral space
plane.Gravity();
neutral = true; neutral = true;
break; break;
case 1: //hit rocket case 1: //hit rocket
plane.HitRocket(); plane.HitRocket();
noseUp = false; noseUp = false;
planesBoard[plane.Height, counter%28 - 3] = 0; //plane consumes rocket planesBoard[plane.Height, counter % 23 - 3] = 0; //plane consumes rocket
break; break;
case 2: //hit multi case 2: //hit multi
plane.HitMulti(); plane.HitMulti();
noseUp = true; noseUp = true;
planesBoard[plane.Height, counter%28 - 3] = 0; //plane consumes multi planesBoard[plane.Height, counter % 23 - 3] = 0; //plane consumes multi
break; break;
default: default:
await botInstance.SendChatMessageAsync("Something went wrong, error code 1.", true); await botInstance.SendChatMessageAsync("Something went wrong, error code 1.", true);
return; return;
} }
}
catch (IndexOutOfRangeException e)
{
await botInstance.SendChatMessageAsync($"Something went wrong, error code 2. Counter: {counter} Counter%: {counter % 23 - 3} Height: {plane.Height}", true);
logger.Error(
$"Something went wrong, error code 2. Counter: {counter} Counter%: {counter % 23 - 3} Height: {plane.Height}");
return;
}
if (neutral) //this will be the last frame so use all the remaining frame time left if (neutral) //this will be the last frame so use all the remaining frame time left
{ {
@@ -367,8 +384,10 @@ public class Planes : ICommand
} }
//maybe fuckery around here //maybe fuckery around here
} }
plane.Gravity();
}
counter++; counter++;
if (counter % 28 != 0) continue; if (counter % 23 != 0) continue;
planesBoard = planesBoard2; planesBoard = planesBoard2;
planesBoard2 = CreatePlanesBoard(gambler); planesBoard2 = CreatePlanesBoard(gambler);
} while (plane.Height < 6); } while (plane.Height < 6);
@@ -378,7 +397,7 @@ public class Planes : ICommand
BuiltIn.Keys.KiwiFarmsGreenColor, BuiltIn.Keys.KiwiFarmsRedColor BuiltIn.Keys.KiwiFarmsGreenColor, BuiltIn.Keys.KiwiFarmsRedColor
]); ]);
var newBalance = gambler.Balance - wager; var newBalance = gambler.Balance - wager;
if (counter % 28 % carrierCount == 0) //if you landed on the carrier if (((counter % 23) - 3) % carrierCount == 0) //if you landed on the carrier
{ {
var win = plane.MultiTracker * wager; var win = plane.MultiTracker * wager;
newBalance = gambler.Balance + win; newBalance = gambler.Balance + win;
@@ -397,7 +416,7 @@ public class Planes : ICommand
var output = ""; var output = "";
for (var row = 0; row < 8; row++) for (var row = 0; row < 8; row++)
{ {
for (var column = -3; column < 25; column++) //plane starts out 3 space behind to give some space to the view, for (var column = -3; column < 20; column++) //plane starts out 3 space behind to give some space to the view,
{ {
if (row == plane.Height && column == counter && noseUp) if (row == plane.Height && column == counter && noseUp)
{ {
@@ -445,10 +464,10 @@ public class Planes : ICommand
private int[,] CreatePlanesBoard(GamblerDbModel gambler) private int[,] CreatePlanesBoard(GamblerDbModel gambler)
{ {
var board = new int [6, 25]; var board = new int [6, 20];
for (var row = 0; row < 6; row++) for (var row = 0; row < 6; row++)
{ {
for (var column = 0; column < 25; column++) for (var column = 0; column < 20; column++)
{ {
var randomNum = Money.GetRandomNumber(gambler, 1, 100); var randomNum = Money.GetRandomNumber(gambler, 1, 100);
if (randomNum < 35) if (randomNum < 35)