diff options
author | Justin Clark-Casey (justincc) | 2014-08-05 01:37:10 +0100 |
---|---|---|
committer | Justin Clark-Casey (justincc) | 2014-08-05 01:37:10 +0100 |
commit | 0e71e3889c4d3b12575fc8d40bde2e70dc7f5e56 (patch) | |
tree | 276870822245e73c8a12129cd5b9e010fb206f2c | |
parent | Put pCampbot "disconnect" command on separate thread like "connect" so that w... (diff) | |
download | opensim-SC_OLD-0e71e3889c4d3b12575fc8d40bde2e70dc7f5e56.zip opensim-SC_OLD-0e71e3889c4d3b12575fc8d40bde2e70dc7f5e56.tar.gz opensim-SC_OLD-0e71e3889c4d3b12575fc8d40bde2e70dc7f5e56.tar.bz2 opensim-SC_OLD-0e71e3889c4d3b12575fc8d40bde2e70dc7f5e56.tar.xz |
Go back to disconnecting bots in parallel since serially is too slow.
However, disconnecting now halts any current connection, with the possible exception of the single currently connecting bot.
-rw-r--r-- | OpenSim/Tools/pCampBot/BotManager.cs | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/OpenSim/Tools/pCampBot/BotManager.cs b/OpenSim/Tools/pCampBot/BotManager.cs index a872dbc..12cde18 100644 --- a/OpenSim/Tools/pCampBot/BotManager.cs +++ b/OpenSim/Tools/pCampBot/BotManager.cs | |||
@@ -349,7 +349,7 @@ namespace pCampBot | |||
349 | 349 | ||
350 | foreach (Bot bot in botsToConnect) | 350 | foreach (Bot bot in botsToConnect) |
351 | { | 351 | { |
352 | if (DisconnectingBots) | 352 | if (!ConnectingBots) |
353 | { | 353 | { |
354 | MainConsole.Instance.Output( | 354 | MainConsole.Instance.Output( |
355 | "[BOT MANAGER]: Aborting bot connection due to user-initiated disconnection"); | 355 | "[BOT MANAGER]: Aborting bot connection due to user-initiated disconnection"); |
@@ -629,6 +629,8 @@ namespace pCampBot | |||
629 | botsToDisconnectCount = Math.Min(botsToDisconnectCount, connectedBots.Count); | 629 | botsToDisconnectCount = Math.Min(botsToDisconnectCount, connectedBots.Count); |
630 | } | 630 | } |
631 | 631 | ||
632 | DisconnectingBots = true; | ||
633 | |||
632 | Thread disconnectBotThread = new Thread(o => DisconnectBotsInternal(connectedBots, botsToDisconnectCount)); | 634 | Thread disconnectBotThread = new Thread(o => DisconnectBotsInternal(connectedBots, botsToDisconnectCount)); |
633 | 635 | ||
634 | disconnectBotThread.Name = "Bots disconnection thread"; | 636 | disconnectBotThread.Name = "Bots disconnection thread"; |
@@ -637,7 +639,7 @@ namespace pCampBot | |||
637 | 639 | ||
638 | private void DisconnectBotsInternal(List<Bot> connectedBots, int disconnectCount) | 640 | private void DisconnectBotsInternal(List<Bot> connectedBots, int disconnectCount) |
639 | { | 641 | { |
640 | DisconnectingBots = true; | 642 | ConnectingBots = false; |
641 | 643 | ||
642 | MainConsole.Instance.OutputFormat("Disconnecting {0} bots", disconnectCount); | 644 | MainConsole.Instance.OutputFormat("Disconnecting {0} bots", disconnectCount); |
643 | 645 | ||
@@ -652,7 +654,7 @@ namespace pCampBot | |||
652 | 654 | ||
653 | if (thisBot.ConnectionState == ConnectionState.Connected) | 655 | if (thisBot.ConnectionState == ConnectionState.Connected) |
654 | { | 656 | { |
655 | thisBot.Disconnect(); | 657 | ThreadPool.QueueUserWorkItem(o => thisBot.Disconnect()); |
656 | disconnectedBots++; | 658 | disconnectedBots++; |
657 | } | 659 | } |
658 | } | 660 | } |