From 3c326aae997c2250f1a9704f993b6a988a8efe89 Mon Sep 17 00:00:00 2001
From: MW
Date: Sun, 15 Jul 2007 18:05:41 +0000
Subject: Removed the reference to ClientManager from scene, as scene really
shouldn't have a direct reference to the UDP/Packet server's clientmanager,
instead it should send all data through the ScenePresences. For those
functions that was using the clientManager's foreachClient(delegate) method,
there is now a ForEachScenePresence(delegate) in scene. This change helps
with the decoupling of client packet functions from the scene functions.
---
.../Environment/Scenes/Scene.PacketHandlers.cs | 16 +++++-------
OpenSim/Region/Environment/Scenes/Scene.cs | 30 ++++++++++++++--------
OpenSim/Region/Environment/Scenes/SceneBase.cs | 1 -
3 files changed, 26 insertions(+), 21 deletions(-)
(limited to 'OpenSim/Region/Environment/Scenes')
diff --git a/OpenSim/Region/Environment/Scenes/Scene.PacketHandlers.cs b/OpenSim/Region/Environment/Scenes/Scene.PacketHandlers.cs
index bf98b0d..1445edf 100644
--- a/OpenSim/Region/Environment/Scenes/Scene.PacketHandlers.cs
+++ b/OpenSim/Region/Environment/Scenes/Scene.PacketHandlers.cs
@@ -149,15 +149,13 @@ namespace OpenSim.Region.Environment.Scenes
avatar = null;
}
- m_clientManager.ForEachClient(delegate(IClientAPI client)
+ this.ForEachScenePresence(delegate(ScenePresence presence)
{
int dis = -1000;
- if (this.Avatars.ContainsKey(client.AgentId))
+ if (this.Avatars.ContainsKey(presence.ControllingClient.AgentId))
{
- avatar = this.Avatars[client.AgentId];
- // int dis = Util.fast_distance2d((int)(client.ClientAvatar.Pos.X - simClient.ClientAvatar.Pos.X), (int)(client.ClientAvatar.Pos.Y - simClient.ClientAvatar.Pos.Y));
+ avatar = this.Avatars[presence.ControllingClient.AgentId];
dis = (int)avatar.Pos.GetDistanceTo(fromPos);
- //Console.WriteLine("found avatar at " +dis);
}
switch (type)
@@ -166,7 +164,7 @@ namespace OpenSim.Region.Environment.Scenes
if ((dis < 10) && (dis > -10))
{
//should change so the message is sent through the avatar rather than direct to the ClientView
- client.SendChatMessage(message, type, fromPos, fromName,
+ presence.ControllingClient.SendChatMessage(message, type, fromPos, fromName,
fromAgentID);
}
break;
@@ -174,20 +172,20 @@ namespace OpenSim.Region.Environment.Scenes
if ((dis < 30) && (dis > -30))
{
//Console.WriteLine("sending chat");
- client.SendChatMessage(message, type, fromPos, fromName,
+ presence.ControllingClient.SendChatMessage(message, type, fromPos, fromName,
fromAgentID);
}
break;
case 2: // Shout
if ((dis < 100) && (dis > -100))
{
- client.SendChatMessage(message, type, fromPos, fromName,
+ presence.ControllingClient.SendChatMessage(message, type, fromPos, fromName,
fromAgentID);
}
break;
case 0xff: // Broadcast
- client.SendChatMessage(message, type, fromPos, fromName,
+ presence.ControllingClient.SendChatMessage(message, type, fromPos, fromName,
fromAgentID);
break;
}
diff --git a/OpenSim/Region/Environment/Scenes/Scene.cs b/OpenSim/Region/Environment/Scenes/Scene.cs
index ad46322..d9b630e 100644
--- a/OpenSim/Region/Environment/Scenes/Scene.cs
+++ b/OpenSim/Region/Environment/Scenes/Scene.cs
@@ -48,6 +48,7 @@ using Timer = System.Timers.Timer;
namespace OpenSim.Region.Environment.Scenes
{
public delegate bool FilterAvatarList(ScenePresence avatar);
+ public delegate void ForEachScenePresenceDelegate(ScenePresence presence);
public partial class Scene : SceneBase, ILocalStorageReceiver
{
@@ -120,14 +121,13 @@ namespace OpenSim.Region.Environment.Scenes
/// Dictionary to contain client threads
/// Region Handle for this region
/// Region Name for this region
- public Scene(ClientManager clientManager, RegionInfo regInfo, AuthenticateSessionsBase authen, CommunicationsManager commsMan, AssetCache assetCach, StorageManager storeManager, BaseHttpServer httpServer)
+ public Scene(RegionInfo regInfo, AuthenticateSessionsBase authen, CommunicationsManager commsMan, AssetCache assetCach, StorageManager storeManager, BaseHttpServer httpServer)
{
updateLock = new Mutex(false);
this.authenticateHandler = authen;
this.commsManager = commsMan;
this.storageManager = storeManager;
this.assetCache = assetCach;
- m_clientManager = clientManager;
m_regInfo = regInfo;
m_regionHandle = m_regInfo.RegionHandle;
m_regionName = m_regInfo.RegionName;
@@ -268,9 +268,9 @@ namespace OpenSim.Region.Environment.Scenes
this.storageManager.DataStore.StoreTerrain(Terrain.getHeights2DD());
- m_clientManager.ForEachClient(delegate(IClientAPI client)
+ this.ForEachScenePresence(delegate(ScenePresence presence)
{
- this.SendLayerData(client);
+ this.SendLayerData(presence.ControllingClient);
});
foreach (LLUUID UUID in Entities.Keys)
@@ -299,9 +299,9 @@ namespace OpenSim.Region.Environment.Scenes
}
this.storageManager.DataStore.StoreTerrain(Terrain.getHeights2DD());
- m_clientManager.ForEachClient(delegate(IClientAPI client)
+ this.ForEachScenePresence(delegate(ScenePresence presence)
{
- this.SendLayerData(client);
+ this.SendLayerData(presence.ControllingClient);
});
foreach (LLUUID UUID in Entities.Keys)
@@ -329,9 +329,9 @@ namespace OpenSim.Region.Environment.Scenes
{
/* Dont save here, rely on tainting system instead */
- m_clientManager.ForEachClient(delegate(IClientAPI client)
+ this.ForEachScenePresence(delegate(ScenePresence presence)
{
- this.SendLayerData(pointx, pointy, client);
+ this.SendLayerData(pointx, pointy, presence.ControllingClient);
});
}
}
@@ -581,10 +581,10 @@ namespace OpenSim.Region.Environment.Scenes
ScenePresence avatar = this.RequestAvatar(agentID);
- m_clientManager.ForEachClient(
- delegate(IClientAPI client)
+ this.ForEachScenePresence(
+ delegate(ScenePresence presence)
{
- client.SendKillObject(avatar.RegionHandle, avatar.LocalId);
+ presence.ControllingClient.SendKillObject(avatar.RegionHandle, avatar.LocalId);
});
lock (Avatars)
@@ -661,6 +661,14 @@ namespace OpenSim.Region.Environment.Scenes
}
return null;
}
+
+ public void ForEachScenePresence(ForEachScenePresenceDelegate whatToDo)
+ {
+ foreach (ScenePresence presence in this.Avatars.Values)
+ {
+ whatToDo(presence);
+ }
+ }
#endregion
diff --git a/OpenSim/Region/Environment/Scenes/SceneBase.cs b/OpenSim/Region/Environment/Scenes/SceneBase.cs
index c852499..161a5cf 100644
--- a/OpenSim/Region/Environment/Scenes/SceneBase.cs
+++ b/OpenSim/Region/Environment/Scenes/SceneBase.cs
@@ -41,7 +41,6 @@ namespace OpenSim.Region.Environment.Scenes
public abstract class SceneBase : IWorld
{
public Dictionary Entities;
- protected ClientManager m_clientManager;
protected ulong m_regionHandle;
protected string m_regionName;
protected RegionInfo m_regInfo;
--
cgit v1.1