diff options
-rw-r--r-- | OpenSim/Tools/pCampBot/BotManager.cs | 78 |
1 files changed, 55 insertions, 23 deletions
diff --git a/OpenSim/Tools/pCampBot/BotManager.cs b/OpenSim/Tools/pCampBot/BotManager.cs index 29739dc..c7d8f05 100644 --- a/OpenSim/Tools/pCampBot/BotManager.cs +++ b/OpenSim/Tools/pCampBot/BotManager.cs | |||
@@ -43,6 +43,14 @@ using pCampBot.Interfaces; | |||
43 | 43 | ||
44 | namespace pCampBot | 44 | namespace pCampBot |
45 | { | 45 | { |
46 | public enum BotManagerBotConnectingState | ||
47 | { | ||
48 | Initializing, | ||
49 | Ready, | ||
50 | Connecting, | ||
51 | Disconnecting | ||
52 | } | ||
53 | |||
46 | /// <summary> | 54 | /// <summary> |
47 | /// Thread/Bot manager for the application | 55 | /// Thread/Bot manager for the application |
48 | /// </summary> | 56 | /// </summary> |
@@ -53,14 +61,14 @@ namespace pCampBot | |||
53 | public const int DefaultLoginDelay = 5000; | 61 | public const int DefaultLoginDelay = 5000; |
54 | 62 | ||
55 | /// <summary> | 63 | /// <summary> |
56 | /// Is pCampbot in the process of connecting bots? | 64 | /// Is pCampbot ready to connect or currently in the process of connecting or disconnecting bots? |
57 | /// </summary> | 65 | /// </summary> |
58 | public bool ConnectingBots { get; private set; } | 66 | public BotManagerBotConnectingState BotConnectingState { get; private set; } |
59 | 67 | ||
60 | /// <summary> | 68 | /// <summary> |
61 | /// Is pCampbot in the process of disconnecting bots? | 69 | /// Used to control locking as we can't lock an enum. |
62 | /// </summary> | 70 | /// </summary> |
63 | public bool DisconnectingBots { get; private set; } | 71 | private object BotConnectingStateChangeObject = new object(); |
64 | 72 | ||
65 | /// <summary> | 73 | /// <summary> |
66 | /// Delay between logins of multiple bots. | 74 | /// Delay between logins of multiple bots. |
@@ -239,12 +247,15 @@ namespace pCampBot | |||
239 | "Bots", false, "show regions", "show regions", "Show regions known to bots", HandleShowRegions); | 247 | "Bots", false, "show regions", "show regions", "Show regions known to bots", HandleShowRegions); |
240 | 248 | ||
241 | m_console.Commands.AddCommand( | 249 | m_console.Commands.AddCommand( |
242 | "Bots", false, "show bots", "show bots", "Shows the status of all bots", HandleShowBotsStatus); | 250 | "Bots", false, "show bots", "show bots", "Shows the status of all bots.", HandleShowBotsStatus); |
243 | 251 | ||
244 | m_console.Commands.AddCommand( | 252 | m_console.Commands.AddCommand( |
245 | "Bots", false, "show bot", "show bot <bot-number>", | 253 | "Bots", false, "show bot", "show bot <bot-number>", |
246 | "Shows the detailed status and settings of a particular bot.", HandleShowBotStatus); | 254 | "Shows the detailed status and settings of a particular bot.", HandleShowBotStatus); |
247 | 255 | ||
256 | m_console.Commands.AddCommand( | ||
257 | "Bots", false, "show status", "show status", "Shows pCampbot status.", HandleShowStatus); | ||
258 | |||
248 | m_bots = new List<Bot>(); | 259 | m_bots = new List<Bot>(); |
249 | 260 | ||
250 | Watchdog.Enabled = true; | 261 | Watchdog.Enabled = true; |
@@ -254,6 +265,8 @@ namespace pCampBot | |||
254 | m_serverStatsCollector.Initialise(null); | 265 | m_serverStatsCollector.Initialise(null); |
255 | m_serverStatsCollector.Enabled = true; | 266 | m_serverStatsCollector.Enabled = true; |
256 | m_serverStatsCollector.Start(); | 267 | m_serverStatsCollector.Start(); |
268 | |||
269 | BotConnectingState = BotManagerBotConnectingState.Ready; | ||
257 | } | 270 | } |
258 | 271 | ||
259 | /// <summary> | 272 | /// <summary> |
@@ -335,7 +348,17 @@ namespace pCampBot | |||
335 | 348 | ||
336 | public void ConnectBots(int botcount) | 349 | public void ConnectBots(int botcount) |
337 | { | 350 | { |
338 | ConnectingBots = true; | 351 | lock (BotConnectingStateChangeObject) |
352 | { | ||
353 | if (BotConnectingState != BotManagerBotConnectingState.Ready) | ||
354 | { | ||
355 | MainConsole.Instance.OutputFormat( | ||
356 | "Bot connecting status is {0}. Please wait for previous process to complete.", BotConnectingState); | ||
357 | return; | ||
358 | } | ||
359 | |||
360 | BotConnectingState = BotManagerBotConnectingState.Connecting; | ||
361 | } | ||
339 | 362 | ||
340 | Thread connectBotThread = new Thread(o => ConnectBotsInternal(botcount)); | 363 | Thread connectBotThread = new Thread(o => ConnectBotsInternal(botcount)); |
341 | 364 | ||
@@ -373,11 +396,14 @@ namespace pCampBot | |||
373 | 396 | ||
374 | foreach (Bot bot in botsToConnect) | 397 | foreach (Bot bot in botsToConnect) |
375 | { | 398 | { |
376 | if (!ConnectingBots) | 399 | lock (BotConnectingStateChangeObject) |
377 | { | 400 | { |
378 | MainConsole.Instance.Output( | 401 | if (BotConnectingState != BotManagerBotConnectingState.Connecting) |
379 | "[BOT MANAGER]: Aborting bot connection due to user-initiated disconnection"); | 402 | { |
380 | break; | 403 | MainConsole.Instance.Output( |
404 | "[BOT MANAGER]: Aborting bot connection due to user-initiated disconnection"); | ||
405 | return; | ||
406 | } | ||
381 | } | 407 | } |
382 | 408 | ||
383 | bot.Connect(); | 409 | bot.Connect(); |
@@ -386,7 +412,11 @@ namespace pCampBot | |||
386 | Thread.Sleep(LoginDelay); | 412 | Thread.Sleep(LoginDelay); |
387 | } | 413 | } |
388 | 414 | ||
389 | ConnectingBots = false; | 415 | lock (BotConnectingStateChangeObject) |
416 | { | ||
417 | if (BotConnectingState == BotManagerBotConnectingState.Connecting) | ||
418 | BotConnectingState = BotManagerBotConnectingState.Ready; | ||
419 | } | ||
390 | } | 420 | } |
391 | 421 | ||
392 | /// <summary> | 422 | /// <summary> |
@@ -491,13 +521,7 @@ namespace pCampBot | |||
491 | } | 521 | } |
492 | 522 | ||
493 | private void HandleConnect(string module, string[] cmd) | 523 | private void HandleConnect(string module, string[] cmd) |
494 | { | 524 | { |
495 | if (ConnectingBots) | ||
496 | { | ||
497 | MainConsole.Instance.Output("Still connecting bots. Please wait for previous process to complete."); | ||
498 | return; | ||
499 | } | ||
500 | |||
501 | lock (m_bots) | 525 | lock (m_bots) |
502 | { | 526 | { |
503 | int botsToConnect; | 527 | int botsToConnect; |
@@ -653,7 +677,8 @@ namespace pCampBot | |||
653 | botsToDisconnectCount = Math.Min(botsToDisconnectCount, connectedBots.Count); | 677 | botsToDisconnectCount = Math.Min(botsToDisconnectCount, connectedBots.Count); |
654 | } | 678 | } |
655 | 679 | ||
656 | DisconnectingBots = true; | 680 | lock (BotConnectingStateChangeObject) |
681 | BotConnectingState = BotManagerBotConnectingState.Disconnecting; | ||
657 | 682 | ||
658 | Thread disconnectBotThread = new Thread(o => DisconnectBotsInternal(connectedBots, botsToDisconnectCount)); | 683 | Thread disconnectBotThread = new Thread(o => DisconnectBotsInternal(connectedBots, botsToDisconnectCount)); |
659 | 684 | ||
@@ -662,9 +687,7 @@ namespace pCampBot | |||
662 | } | 687 | } |
663 | 688 | ||
664 | private void DisconnectBotsInternal(List<Bot> connectedBots, int disconnectCount) | 689 | private void DisconnectBotsInternal(List<Bot> connectedBots, int disconnectCount) |
665 | { | 690 | { |
666 | ConnectingBots = false; | ||
667 | |||
668 | MainConsole.Instance.OutputFormat("Disconnecting {0} bots", disconnectCount); | 691 | MainConsole.Instance.OutputFormat("Disconnecting {0} bots", disconnectCount); |
669 | 692 | ||
670 | int disconnectedBots = 0; | 693 | int disconnectedBots = 0; |
@@ -683,7 +706,8 @@ namespace pCampBot | |||
683 | } | 706 | } |
684 | } | 707 | } |
685 | 708 | ||
686 | DisconnectingBots = false; | 709 | lock (BotConnectingStateChangeObject) |
710 | BotConnectingState = BotManagerBotConnectingState.Ready; | ||
687 | } | 711 | } |
688 | 712 | ||
689 | private void HandleSit(string module, string[] cmd) | 713 | private void HandleSit(string module, string[] cmd) |
@@ -775,6 +799,14 @@ namespace pCampBot | |||
775 | } | 799 | } |
776 | } | 800 | } |
777 | 801 | ||
802 | private void HandleShowStatus(string module, string[] cmd) | ||
803 | { | ||
804 | ConsoleDisplayList cdl = new ConsoleDisplayList(); | ||
805 | cdl.AddRow("Bot connecting state", BotConnectingState); | ||
806 | |||
807 | MainConsole.Instance.Output(cdl.ToString()); | ||
808 | } | ||
809 | |||
778 | private void HandleShowBotsStatus(string module, string[] cmd) | 810 | private void HandleShowBotsStatus(string module, string[] cmd) |
779 | { | 811 | { |
780 | ConsoleDisplayTable cdt = new ConsoleDisplayTable(); | 812 | ConsoleDisplayTable cdt = new ConsoleDisplayTable(); |