aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/OpenSim/Region
diff options
context:
space:
mode:
authorMelanie Thielker2010-06-11 17:04:54 +0200
committerMelanie Thielker2010-06-11 17:04:54 +0200
commitb3cf5ccf6d7fcfa2cb4a1405962b8fba73ae0119 (patch)
treead84273af9732e0f2ca8e4ad4d9b648e90f3c8e8 /OpenSim/Region
parentMerge branch 'master' into careminster-presence-refactor (diff)
downloadopensim-SC-b3cf5ccf6d7fcfa2cb4a1405962b8fba73ae0119.zip
opensim-SC-b3cf5ccf6d7fcfa2cb4a1405962b8fba73ae0119.tar.gz
opensim-SC-b3cf5ccf6d7fcfa2cb4a1405962b8fba73ae0119.tar.bz2
opensim-SC-b3cf5ccf6d7fcfa2cb4a1405962b8fba73ae0119.tar.xz
Clone cmGetAvatarList into osGetAvatarList for more generic use.
Diffstat (limited to 'OpenSim/Region')
-rw-r--r--OpenSim/Region/ScriptEngine/Shared/Api/Implementation/OSSL_Api.cs27
-rw-r--r--OpenSim/Region/ScriptEngine/Shared/Api/Interface/IOSSL_Api.cs1
-rw-r--r--OpenSim/Region/ScriptEngine/Shared/Api/Runtime/OSSL_Stub.cs5
3 files changed, 33 insertions, 0 deletions
diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/OSSL_Api.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/OSSL_Api.cs
index f2a2f32..0e86c86 100644
--- a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/OSSL_Api.cs
+++ b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/OSSL_Api.cs
@@ -2206,5 +2206,32 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api
2206 2206
2207 m_LSL_Api.SetPrimitiveParamsEx(prim, rules); 2207 m_LSL_Api.SetPrimitiveParamsEx(prim, rules);
2208 } 2208 }
2209
2210 /// <summary>
2211 /// Like osGetAgents but returns enough info for a radar
2212 /// </summary>
2213 /// <returns>Strided list of the UUID, position and name of each avatar in the region</returns>
2214 public LSL_List osGetAvatarList()
2215 {
2216 CheckThreatLevel(ThreatLevel.None, "osGetAvatarList");
2217
2218 LSL_List result = new LSL_List();
2219 World.ForEachScenePresence(delegate (ScenePresence avatar)
2220 {
2221 if (avatar != null && avatar.UUID != m_host.OwnerID)
2222 {
2223 if (avatar.IsChildAgent == false)
2224 {
2225 if (avatar.PhysicsActor != null && avatar.PhysicsActor.Position != null)
2226 {
2227 result.Add(avatar.UUID);
2228 result.Add(avatar.PhysicsActor.Position);
2229 result.Add(avatar.Name);
2230 }
2231 }
2232 }
2233 });
2234 return result;
2235 }
2209 } 2236 }
2210} 2237}
diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Interface/IOSSL_Api.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Interface/IOSSL_Api.cs
index 1ab7f10..c8f3623 100644
--- a/OpenSim/Region/ScriptEngine/Shared/Api/Interface/IOSSL_Api.cs
+++ b/OpenSim/Region/ScriptEngine/Shared/Api/Interface/IOSSL_Api.cs
@@ -176,6 +176,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api.Interfaces
176 void osCauseDamage(string avatar, double damage); 176 void osCauseDamage(string avatar, double damage);
177 LSL_List osGetPrimitiveParams(LSL_Key prim, LSL_List rules); 177 LSL_List osGetPrimitiveParams(LSL_Key prim, LSL_List rules);
178 void osSetPrimitiveParams(LSL_Key prim, LSL_List rules); 178 void osSetPrimitiveParams(LSL_Key prim, LSL_List rules);
179 LSL_List osGetAvatarList();
179 180
180 } 181 }
181} 182}
diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Runtime/OSSL_Stub.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Runtime/OSSL_Stub.cs
index 7af5d43..6cc5f51 100644
--- a/OpenSim/Region/ScriptEngine/Shared/Api/Runtime/OSSL_Stub.cs
+++ b/OpenSim/Region/ScriptEngine/Shared/Api/Runtime/OSSL_Stub.cs
@@ -687,5 +687,10 @@ namespace OpenSim.Region.ScriptEngine.Shared.ScriptBase
687 { 687 {
688 m_OSSL_Functions.osSetPrimitiveParams(prim, rules); 688 m_OSSL_Functions.osSetPrimitiveParams(prim, rules);
689 } 689 }
690
691 public LSL_List osGetAvatarList()
692 {
693 return m_OSSL_Functions.osGetAvatarList();
694 }
690 } 695 }
691} 696}