aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region/ClientStack/Linden/UDP
diff options
context:
space:
mode:
Diffstat (limited to 'OpenSim/Region/ClientStack/Linden/UDP')
-rw-r--r--OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs27
-rw-r--r--OpenSim/Region/ClientStack/Linden/UDP/LLUDPServer.cs49
2 files changed, 76 insertions, 0 deletions
diff --git a/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs b/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
index 9d6085d..15a90af 100644
--- a/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
+++ b/OpenSim/Region/ClientStack/Linden/UDP/LLClientView.cs
@@ -12341,6 +12341,10 @@ namespace OpenSim.Region.ClientStack.LindenUDP
12341 /// provide your own method.</param> 12341 /// provide your own method.</param>
12342 protected void OutPacket(Packet packet, ThrottleOutPacketType throttlePacketType, bool doAutomaticSplitting, UnackedPacketMethod method) 12342 protected void OutPacket(Packet packet, ThrottleOutPacketType throttlePacketType, bool doAutomaticSplitting, UnackedPacketMethod method)
12343 { 12343 {
12344 if (m_outPacketsToDrop != null)
12345 if (m_outPacketsToDrop.Contains(packet.Type.ToString()))
12346 return;
12347
12344 if (DebugPacketLevel > 0) 12348 if (DebugPacketLevel > 0)
12345 { 12349 {
12346 bool logPacket = true; 12350 bool logPacket = true;
@@ -13123,5 +13127,28 @@ namespace OpenSim.Region.ClientStack.LindenUDP
13123 eq.Enqueue(BuildEvent("BulkUpdateInventory", 13127 eq.Enqueue(BuildEvent("BulkUpdateInventory",
13124 llsd), AgentId); 13128 llsd), AgentId);
13125 } 13129 }
13130
13131 private HashSet<string> m_outPacketsToDrop;
13132
13133 public bool AddOutPacketToDropSet(string packetName)
13134 {
13135 if (m_outPacketsToDrop == null)
13136 m_outPacketsToDrop = new HashSet<string>();
13137
13138 return m_outPacketsToDrop.Add(packetName);
13139 }
13140
13141 public bool RemoveOutPacketFromDropSet(string packetName)
13142 {
13143 if (m_outPacketsToDrop == null)
13144 return false;
13145
13146 return m_outPacketsToDrop.Remove(packetName);
13147 }
13148
13149 public HashSet<string> GetOutPacketDropSet()
13150 {
13151 return new HashSet<string>(m_outPacketsToDrop);
13152 }
13126 } 13153 }
13127} 13154}
diff --git a/OpenSim/Region/ClientStack/Linden/UDP/LLUDPServer.cs b/OpenSim/Region/ClientStack/Linden/UDP/LLUDPServer.cs
index 3c9bb1b..549573b 100644
--- a/OpenSim/Region/ClientStack/Linden/UDP/LLUDPServer.cs
+++ b/OpenSim/Region/ClientStack/Linden/UDP/LLUDPServer.cs
@@ -698,6 +698,13 @@ namespace OpenSim.Region.ClientStack.LindenUDP
698 HandlePacketCommand); 698 HandlePacketCommand);
699 699
700 MainConsole.Instance.Commands.AddCommand( 700 MainConsole.Instance.Commands.AddCommand(
701 "Debug", false, "debug lludp drop out",
702 "debug lludp drop out <add|remove> <packet-name>",
703 "Drop all outbound packets that match the given name",
704 "For test purposes.",
705 HandleDropCommand);
706
707 MainConsole.Instance.Commands.AddCommand(
701 "Debug", 708 "Debug",
702 false, 709 false,
703 "debug lludp start", 710 "debug lludp start",
@@ -820,6 +827,48 @@ namespace OpenSim.Region.ClientStack.LindenUDP
820 } 827 }
821 } 828 }
822 829
830 private void HandleDropCommand(string module, string[] args)
831 {
832 if (SceneManager.Instance.CurrentScene != null && SceneManager.Instance.CurrentScene != Scene)
833 return;
834
835 if (args.Length != 6)
836 {
837 MainConsole.Instance.Output("Usage: debug lludp drop out <add|remove> <packet-name>");
838 return;
839 }
840
841 string subCommand = args[4];
842 string packetName = args[5];
843
844 if (subCommand == "add")
845 {
846 MainConsole.Instance.OutputFormat(
847 "Adding packet {0} to out drop list for all connections in {1}", packetName, Scene.Name);
848
849 Scene.ForEachScenePresence(
850 sp =>
851 {
852 LLClientView llcv = (LLClientView)sp.ControllingClient;
853 llcv.AddOutPacketToDropSet(packetName);
854 }
855 );
856 }
857 else if (subCommand == "remove")
858 {
859 MainConsole.Instance.OutputFormat(
860 "Removing packet {0} from out drop list for all connections in {1}", packetName, Scene.Name);
861
862 Scene.ForEachScenePresence(
863 sp =>
864 {
865 LLClientView llcv = (LLClientView)sp.ControllingClient;
866 llcv.RemoveOutPacketFromDropSet(packetName);
867 }
868 );
869 }
870 }
871
823 private void HandleStartCommand(string module, string[] args) 872 private void HandleStartCommand(string module, string[] args)
824 { 873 {
825 if (SceneManager.Instance.CurrentScene != null && SceneManager.Instance.CurrentScene != Scene) 874 if (SceneManager.Instance.CurrentScene != null && SceneManager.Instance.CurrentScene != Scene)