* Refactor: remove code duplication between add ScenePresence methods in InnerScene
parent
73a28a56da
commit
a28ca7b78b
|
@ -488,50 +488,14 @@ namespace OpenSim.Region.Environment.Scenes
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public ScenePresence CreateAndAddScenePresence(IClientAPI client, bool child, AvatarAppearance appearance)
|
protected internal ScenePresence CreateAndAddScenePresence(IClientAPI client, bool child, AvatarAppearance appearance)
|
||||||
{
|
{
|
||||||
ScenePresence newAvatar = null;
|
ScenePresence newAvatar = null;
|
||||||
|
|
||||||
newAvatar = new ScenePresence(client, m_parentScene, m_regInfo, appearance);
|
newAvatar = new ScenePresence(client, m_parentScene, m_regInfo, appearance);
|
||||||
newAvatar.IsChildAgent = child;
|
newAvatar.IsChildAgent = child;
|
||||||
|
|
||||||
if (child)
|
AddScenePresence(newAvatar);
|
||||||
{
|
|
||||||
m_numChildAgents++;
|
|
||||||
m_log.Info("[SCENE]: " + m_regInfo.RegionName + ": Creating new child agent.");
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
m_numRootAgents++;
|
|
||||||
m_log.Info("[SCENE]: " + m_regInfo.RegionName + ": Creating new root agent.");
|
|
||||||
m_log.Info("[SCENE]: " + m_regInfo.RegionName + ": Adding Physical agent.");
|
|
||||||
|
|
||||||
newAvatar.AddToPhysicalScene();
|
|
||||||
}
|
|
||||||
|
|
||||||
lock (Entities)
|
|
||||||
{
|
|
||||||
if (!Entities.ContainsKey(client.AgentId))
|
|
||||||
{
|
|
||||||
Entities.Add(client.AgentId, newAvatar);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
Entities[client.AgentId] = newAvatar;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
lock (ScenePresences)
|
|
||||||
{
|
|
||||||
if (ScenePresences.ContainsKey(client.AgentId))
|
|
||||||
{
|
|
||||||
ScenePresences[client.AgentId] = newAvatar;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
ScenePresences.Add(client.AgentId, newAvatar);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return newAvatar;
|
return newAvatar;
|
||||||
}
|
}
|
||||||
|
@ -540,7 +504,7 @@ namespace OpenSim.Region.Environment.Scenes
|
||||||
/// Add a presence to the scene
|
/// Add a presence to the scene
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name="presence"></param>
|
/// <param name="presence"></param>
|
||||||
internal void AddScenePresence(ScenePresence presence)
|
protected internal void AddScenePresence(ScenePresence presence)
|
||||||
{
|
{
|
||||||
bool child = presence.IsChildAgent;
|
bool child = presence.IsChildAgent;
|
||||||
|
|
||||||
|
@ -572,7 +536,7 @@ namespace OpenSim.Region.Environment.Scenes
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Remove a presence from the scene
|
/// Remove a presence from the scene
|
||||||
/// </summary>
|
/// </summary>
|
||||||
internal void RemoveScenePresence(LLUUID agentID)
|
protected internal void RemoveScenePresence(LLUUID agentID)
|
||||||
{
|
{
|
||||||
lock (Entities)
|
lock (Entities)
|
||||||
{
|
{
|
||||||
|
|
|
@ -1826,7 +1826,6 @@ namespace OpenSim.Region.Environment.Scenes
|
||||||
|
|
||||||
protected virtual ScenePresence CreateAndAddScenePresence(IClientAPI client, bool child)
|
protected virtual ScenePresence CreateAndAddScenePresence(IClientAPI client, bool child)
|
||||||
{
|
{
|
||||||
|
|
||||||
AvatarAppearance appearance = null;
|
AvatarAppearance appearance = null;
|
||||||
GetAvatarAppearance(client, out appearance);
|
GetAvatarAppearance(client, out appearance);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue