diff options
Diffstat (limited to '')
-rw-r--r-- | OpenSim/Region/ScriptEngine/YEngine/XMRInstBackend.cs (renamed from OpenSim/Region/ScriptEngine/XMREngine/XMRInstBackend.cs) | 407 |
1 files changed, 201 insertions, 206 deletions
diff --git a/OpenSim/Region/ScriptEngine/XMREngine/XMRInstBackend.cs b/OpenSim/Region/ScriptEngine/YEngine/XMRInstBackend.cs index a24036a..fb5c75e 100644 --- a/OpenSim/Region/ScriptEngine/XMREngine/XMRInstBackend.cs +++ b/OpenSim/Region/ScriptEngine/YEngine/XMRInstBackend.cs | |||
@@ -42,13 +42,13 @@ using LSL_Rotation = OpenSim.Region.ScriptEngine.Shared.LSL_Types.Quaternion; | |||
42 | using LSL_String = OpenSim.Region.ScriptEngine.Shared.LSL_Types.LSLString; | 42 | using LSL_String = OpenSim.Region.ScriptEngine.Shared.LSL_Types.LSLString; |
43 | using LSL_Vector = OpenSim.Region.ScriptEngine.Shared.LSL_Types.Vector3; | 43 | using LSL_Vector = OpenSim.Region.ScriptEngine.Shared.LSL_Types.Vector3; |
44 | 44 | ||
45 | namespace OpenSim.Region.ScriptEngine.XMREngine | 45 | namespace OpenSim.Region.ScriptEngine.Yengine |
46 | { | 46 | { |
47 | /****************************************************\ | 47 | /****************************************************\ |
48 | * This file contains routines called by scripts. * | 48 | * This file contains routines called by scripts. * |
49 | \****************************************************/ | 49 | \****************************************************/ |
50 | 50 | ||
51 | public class XMRLSL_Api : LSL_Api | 51 | public class XMRLSL_Api: LSL_Api |
52 | { | 52 | { |
53 | public AsyncCommandManager acm; | 53 | public AsyncCommandManager acm; |
54 | private XMRInstance inst; | 54 | private XMRInstance inst; |
@@ -83,38 +83,38 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
83 | * -2: no av granted perms | 83 | * -2: no av granted perms |
84 | * -3: av not in region | 84 | * -3: av not in region |
85 | */ | 85 | */ |
86 | /* engines should not have own API | 86 | /* engines should not have own API |
87 | public int xmrSeatAvatar (bool owner) | 87 | public int xmrSeatAvatar (bool owner) |
88 | { | 88 | { |
89 | // Get avatar to be seated and make sure they have given us ANIMATION permission | 89 | // Get avatar to be seated and make sure they have given us ANIMATION permission |
90 | 90 | ||
91 | UUID avuuid; | 91 | UUID avuuid; |
92 | if (owner) { | 92 | if (owner) { |
93 | avuuid = inst.m_Part.OwnerID; | 93 | avuuid = inst.m_Part.OwnerID; |
94 | } else { | 94 | } else { |
95 | if ((m_item.PermsMask & ScriptBaseClass.PERMISSION_TRIGGER_ANIMATION) == 0) { | 95 | if ((m_item.PermsMask & ScriptBaseClass.PERMISSION_TRIGGER_ANIMATION) == 0) { |
96 | return -1; | 96 | return -1; |
97 | } | 97 | } |
98 | avuuid = m_item.PermsGranter; | 98 | avuuid = m_item.PermsGranter; |
99 | } | 99 | } |
100 | if (avuuid == UUID.Zero) { | 100 | if (avuuid == UUID.Zero) { |
101 | return -2; | 101 | return -2; |
102 | } | 102 | } |
103 | 103 | ||
104 | ScenePresence presence = World.GetScenePresence (avuuid); | 104 | ScenePresence presence = World.GetScenePresence (avuuid); |
105 | if (presence == null) { | 105 | if (presence == null) { |
106 | return -3; | 106 | return -3; |
107 | } | 107 | } |
108 | 108 | ||
109 | // remoteClient = not used by ScenePresence.HandleAgentRequestSit() | 109 | // remoteClient = not used by ScenePresence.HandleAgentRequestSit() |
110 | // agentID = not used by ScenePresence.HandleAgentRequestSit() | 110 | // agentID = not used by ScenePresence.HandleAgentRequestSit() |
111 | // targetID = UUID of prim to sit on | 111 | // targetID = UUID of prim to sit on |
112 | // offset = offset of sitting position | 112 | // offset = offset of sitting position |
113 | 113 | ||
114 | presence.HandleAgentRequestSit (null, UUID.Zero, m_host.UUID, OpenMetaverse.Vector3.Zero); | 114 | presence.HandleAgentRequestSit (null, UUID.Zero, m_host.UUID, OpenMetaverse.Vector3.Zero); |
115 | return 0; | 115 | return 0; |
116 | } | 116 | } |
117 | */ | 117 | */ |
118 | /** | 118 | /** |
119 | * @brief llTeleportAgent() is broken in that if you pass it a landmark, | 119 | * @brief llTeleportAgent() is broken in that if you pass it a landmark, |
120 | * it still subjects the position to spawn points, as it always | 120 | * it still subjects the position to spawn points, as it always |
@@ -125,80 +125,80 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
125 | * @param landmark = inventory name or UUID of a landmark object | 125 | * @param landmark = inventory name or UUID of a landmark object |
126 | * @param lookat = looking direction after teleport | 126 | * @param lookat = looking direction after teleport |
127 | */ | 127 | */ |
128 | /* engines should not have own API | 128 | /* engines should not have own API |
129 | public void xmrTeleportAgent2Landmark (string agent, string landmark, LSL_Vector lookat) | 129 | public void xmrTeleportAgent2Landmark (string agent, string landmark, LSL_Vector lookat) |
130 | { | 130 | { |
131 | // find out about agent to be teleported | 131 | // find out about agent to be teleported |
132 | UUID agentId; | 132 | UUID agentId; |
133 | if (!UUID.TryParse (agent, out agentId)) throw new ApplicationException ("bad agent uuid"); | 133 | if (!UUID.TryParse (agent, out agentId)) throw new ApplicationException ("bad agent uuid"); |
134 | 134 | ||
135 | ScenePresence presence = World.GetScenePresence (agentId); | 135 | ScenePresence presence = World.GetScenePresence (agentId); |
136 | if (presence == null) throw new ApplicationException ("agent not present in scene"); | 136 | if (presence == null) throw new ApplicationException ("agent not present in scene"); |
137 | if (presence.IsNPC) throw new ApplicationException ("agent is an NPC"); | 137 | if (presence.IsNPC) throw new ApplicationException ("agent is an NPC"); |
138 | if (presence.IsGod) throw new ApplicationException ("agent is a god"); | 138 | if (presence.IsGod) throw new ApplicationException ("agent is a god"); |
139 | 139 | ||
140 | // prim must be owned by land owner or prim must be attached to agent | 140 | // prim must be owned by land owner or prim must be attached to agent |
141 | if (m_host.ParentGroup.AttachmentPoint == 0) { | 141 | if (m_host.ParentGroup.AttachmentPoint == 0) { |
142 | if (m_host.OwnerID != World.LandChannel.GetLandObject (presence.AbsolutePosition).LandData.OwnerID) { | 142 | if (m_host.OwnerID != World.LandChannel.GetLandObject (presence.AbsolutePosition).LandData.OwnerID) { |
143 | throw new ApplicationException ("prim not owned by land's owner"); | 143 | throw new ApplicationException ("prim not owned by land's owner"); |
144 | } | 144 | } |
145 | } else { | 145 | } else { |
146 | if (m_host.OwnerID != presence.UUID) throw new ApplicationException ("prim not attached to agent"); | 146 | if (m_host.OwnerID != presence.UUID) throw new ApplicationException ("prim not attached to agent"); |
147 | } | 147 | } |
148 | 148 | ||
149 | // find landmark in inventory or by UUID | 149 | // find landmark in inventory or by UUID |
150 | UUID assetID = ScriptUtils.GetAssetIdFromKeyOrItemName (m_host, landmark); | 150 | UUID assetID = ScriptUtils.GetAssetIdFromKeyOrItemName (m_host, landmark); |
151 | if (assetID == UUID.Zero) throw new ApplicationException ("no such landmark"); | 151 | if (assetID == UUID.Zero) throw new ApplicationException ("no such landmark"); |
152 | 152 | ||
153 | // read it in and make sure it is a landmark | 153 | // read it in and make sure it is a landmark |
154 | AssetBase lma = World.AssetService.Get (assetID.ToString ()); | 154 | AssetBase lma = World.AssetService.Get (assetID.ToString ()); |
155 | if ((lma == null) || (lma.Type != (sbyte)AssetType.Landmark)) throw new ApplicationException ("not a landmark"); | 155 | if ((lma == null) || (lma.Type != (sbyte)AssetType.Landmark)) throw new ApplicationException ("not a landmark"); |
156 | 156 | ||
157 | // parse the record | 157 | // parse the record |
158 | AssetLandmark lm = new AssetLandmark (lma); | 158 | AssetLandmark lm = new AssetLandmark (lma); |
159 | 159 | ||
160 | // the regionhandle (based on region's world X,Y) might be out of date | 160 | // the regionhandle (based on region's world X,Y) might be out of date |
161 | // re-read the handle so we can pass it to RequestTeleportLocation() | 161 | // re-read the handle so we can pass it to RequestTeleportLocation() |
162 | var region = World.GridService.GetRegionByUUID (World.RegionInfo.ScopeID, lm.RegionID); | 162 | var region = World.GridService.GetRegionByUUID (World.RegionInfo.ScopeID, lm.RegionID); |
163 | if (region == null) throw new ApplicationException ("no such region"); | 163 | if (region == null) throw new ApplicationException ("no such region"); |
164 | 164 | ||
165 | // finally ready to teleport | 165 | // finally ready to teleport |
166 | World.RequestTeleportLocation (presence.ControllingClient, | 166 | World.RequestTeleportLocation (presence.ControllingClient, |
167 | region.RegionHandle, | 167 | region.RegionHandle, |
168 | lm.Position, | 168 | lm.Position, |
169 | lookat, | 169 | lookat, |
170 | (uint)TeleportFlags.ViaLandmark); | 170 | (uint)TeleportFlags.ViaLandmark); |
171 | } | 171 | } |
172 | */ | 172 | */ |
173 | /** | 173 | /** |
174 | * @brief Allow any member of group given by config SetParcelMusicURLGroup to set music URL. | 174 | * @brief Allow any member of group given by config SetParcelMusicURLGroup to set music URL. |
175 | * Code modelled after llSetParcelMusicURL(). | 175 | * Code modelled after llSetParcelMusicURL(). |
176 | * @param newurl = new URL to set (or "" to leave it alone) | 176 | * @param newurl = new URL to set (or "" to leave it alone) |
177 | * @returns previous URL string | 177 | * @returns previous URL string |
178 | */ | 178 | */ |
179 | /* engines should not have own API | 179 | /* engines should not have own API |
180 | public string xmrSetParcelMusicURLGroup (string newurl) | 180 | public string xmrSetParcelMusicURLGroup (string newurl) |
181 | { | 181 | { |
182 | string groupname = m_ScriptEngine.Config.GetString ("SetParcelMusicURLGroup", ""); | 182 | string groupname = m_ScriptEngine.Config.GetString ("SetParcelMusicURLGroup", ""); |
183 | if (groupname == "") throw new ApplicationException ("no SetParcelMusicURLGroup config param set"); | 183 | if (groupname == "") throw new ApplicationException ("no SetParcelMusicURLGroup config param set"); |
184 | 184 | ||
185 | IGroupsModule igm = World.RequestModuleInterface<IGroupsModule> (); | 185 | IGroupsModule igm = World.RequestModuleInterface<IGroupsModule> (); |
186 | if (igm == null) throw new ApplicationException ("no GroupsModule loaded"); | 186 | if (igm == null) throw new ApplicationException ("no GroupsModule loaded"); |
187 | 187 | ||
188 | GroupRecord grouprec = igm.GetGroupRecord (groupname); | 188 | GroupRecord grouprec = igm.GetGroupRecord (groupname); |
189 | if (grouprec == null) throw new ApplicationException ("no such group " + groupname); | 189 | if (grouprec == null) throw new ApplicationException ("no such group " + groupname); |
190 | 190 | ||
191 | GroupMembershipData gmd = igm.GetMembershipData (grouprec.GroupID, m_host.OwnerID); | 191 | GroupMembershipData gmd = igm.GetMembershipData (grouprec.GroupID, m_host.OwnerID); |
192 | if (gmd == null) throw new ApplicationException ("not a member of group " + groupname); | 192 | if (gmd == null) throw new ApplicationException ("not a member of group " + groupname); |
193 | 193 | ||
194 | ILandObject land = World.LandChannel.GetLandObject (m_host.AbsolutePosition); | 194 | ILandObject land = World.LandChannel.GetLandObject (m_host.AbsolutePosition); |
195 | if (land == null) throw new ApplicationException ("no land at " + m_host.AbsolutePosition.ToString ()); | 195 | if (land == null) throw new ApplicationException ("no land at " + m_host.AbsolutePosition.ToString ()); |
196 | string oldurl = land.GetMusicUrl (); | 196 | string oldurl = land.GetMusicUrl (); |
197 | if (oldurl == null) oldurl = ""; | 197 | if (oldurl == null) oldurl = ""; |
198 | if ((newurl != null) && (newurl != "")) land.SetMusicUrl (newurl); | 198 | if ((newurl != null) && (newurl != "")) land.SetMusicUrl (newurl); |
199 | return oldurl; | 199 | return oldurl; |
200 | } | 200 | } |
201 | */ | 201 | */ |
202 | } | 202 | } |
203 | 203 | ||
204 | public partial class XMRInstance | 204 | public partial class XMRInstance |
@@ -222,9 +222,9 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
222 | public DetectParams GetDetectParams(int number) | 222 | public DetectParams GetDetectParams(int number) |
223 | { | 223 | { |
224 | DetectParams dp = null; | 224 | DetectParams dp = null; |
225 | if ((number >= 0) && (m_DetectParams != null) && (number < m_DetectParams.Length)) { | 225 | if((number >= 0) && (m_DetectParams != null) && (number < m_DetectParams.Length)) |
226 | dp = m_DetectParams[number]; | 226 | dp = m_DetectParams[number]; |
227 | } | 227 | |
228 | return dp; | 228 | return dp; |
229 | } | 229 | } |
230 | 230 | ||
@@ -236,7 +236,7 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
236 | public void Die() | 236 | public void Die() |
237 | { | 237 | { |
238 | // llDie doesn't work in attachments! | 238 | // llDie doesn't work in attachments! |
239 | if (m_Part.ParentGroup.IsAttachment || m_DetachQuantum > 0) | 239 | if(m_Part.ParentGroup.IsAttachment || m_DetachQuantum > 0) |
240 | return; | 240 | return; |
241 | 241 | ||
242 | throw new ScriptDieException(); | 242 | throw new ScriptDieException(); |
@@ -247,8 +247,8 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
247 | */ | 247 | */ |
248 | public void Sleep(int ms) | 248 | public void Sleep(int ms) |
249 | { | 249 | { |
250 | lock (m_QueueLock) { | 250 | lock(m_QueueLock) |
251 | 251 | { | |
252 | /* | 252 | /* |
253 | * Say how long to sleep. | 253 | * Say how long to sleep. |
254 | */ | 254 | */ |
@@ -306,12 +306,12 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
306 | * be returned by xmrEventDequeue, to let the runtime know that the script is capable | 306 | * be returned by xmrEventDequeue, to let the runtime know that the script is capable |
307 | * of processing that event type. Otherwise, the event may not be queued to the script. | 307 | * of processing that event type. Otherwise, the event may not be queued to the script. |
308 | */ | 308 | */ |
309 | private static LSL_List emptyList = new LSL_List (new object[0]); | 309 | private static LSL_List emptyList = new LSL_List(new object[0]); |
310 | 310 | ||
311 | public override LSL_List xmrEventDequeue (double timeout, int returnMask1, int returnMask2, | 311 | public override LSL_List xmrEventDequeue(double timeout, int returnMask1, int returnMask2, |
312 | int backgroundMask1, int backgroundMask2) | 312 | int backgroundMask1, int backgroundMask2) |
313 | { | 313 | { |
314 | DateTime sleepUntil = DateTime.UtcNow + TimeSpan.FromMilliseconds (timeout * 1000.0); | 314 | DateTime sleepUntil = DateTime.UtcNow + TimeSpan.FromMilliseconds(timeout * 1000.0); |
315 | EventParams evt = null; | 315 | EventParams evt = null; |
316 | int callNo, evc2; | 316 | int callNo, evc2; |
317 | int evc1 = 0; | 317 | int evc1 = 0; |
@@ -324,45 +324,47 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
324 | callNo = -1; | 324 | callNo = -1; |
325 | try | 325 | try |
326 | { | 326 | { |
327 | if (callMode == CallMode_NORMAL) goto findevent; | 327 | if(callMode == CallMode_NORMAL) |
328 | goto findevent; | ||
328 | 329 | ||
329 | /* | 330 | /* |
330 | * Stack frame is being restored as saved via CheckRun...(). | 331 | * Stack frame is being restored as saved via CheckRun...(). |
331 | * Restore necessary values then jump to __call<n> label to resume processing. | 332 | * Restore necessary values then jump to __call<n> label to resume processing. |
332 | */ | 333 | */ |
333 | sv = RestoreStackFrame ("xmrEventDequeue", out callNo); | 334 | sv = RestoreStackFrame("xmrEventDequeue", out callNo); |
334 | sleepUntil = DateTime.Parse ((string)sv[0]); | 335 | sleepUntil = DateTime.Parse((string)sv[0]); |
335 | returnMask1 = (int)sv[1]; | 336 | returnMask1 = (int)sv[1]; |
336 | returnMask2 = (int)sv[2]; | 337 | returnMask2 = (int)sv[2]; |
337 | mask1 = (int)sv[3]; | 338 | mask1 = (int)sv[3]; |
338 | mask2 = (int)sv[4]; | 339 | mask2 = (int)sv[4]; |
339 | switch (callNo) | 340 | switch(callNo) |
340 | { | 341 | { |
341 | case 0: goto __call0; | 342 | case 0: |
343 | goto __call0; | ||
342 | case 1: | 344 | case 1: |
343 | { | 345 | { |
344 | evc1 = (int)sv[5]; | 346 | evc1 = (int)sv[5]; |
345 | evc = (ScriptEventCode)(int)sv[6]; | 347 | evc = (ScriptEventCode)(int)sv[6]; |
346 | DetectParams[] detprms = ObjArrToDetPrms ((object[])sv[7]); | 348 | DetectParams[] detprms = ObjArrToDetPrms((object[])sv[7]); |
347 | object[] ehargs = (object[])sv[8]; | 349 | object[] ehargs = (object[])sv[8]; |
348 | evt = new EventParams (evc.ToString (), ehargs, detprms); | 350 | evt = new EventParams(evc.ToString(), ehargs, detprms); |
349 | goto __call1; | 351 | goto __call1; |
350 | } | 352 | } |
351 | } | 353 | } |
352 | throw new ScriptBadCallNoException (callNo); | 354 | throw new ScriptBadCallNoException(callNo); |
353 | 355 | ||
354 | /* | 356 | /* |
355 | * Find first event that matches either the return or background masks. | 357 | * Find first event that matches either the return or background masks. |
356 | */ | 358 | */ |
357 | findevent: | 359 | findevent: |
358 | Monitor.Enter (m_QueueLock); | 360 | Monitor.Enter(m_QueueLock); |
359 | for (lln = m_EventQueue.First; lln != null; lln = lln.Next) | 361 | for(lln = m_EventQueue.First; lln != null; lln = lln.Next) |
360 | { | 362 | { |
361 | evt = lln.Value; | 363 | evt = lln.Value; |
362 | evc = (ScriptEventCode)Enum.Parse (typeof (ScriptEventCode), evt.EventName); | 364 | evc = (ScriptEventCode)Enum.Parse(typeof(ScriptEventCode), evt.EventName); |
363 | evc1 = (int)evc; | 365 | evc1 = (int)evc; |
364 | evc2 = evc1 - 32; | 366 | evc2 = evc1 - 32; |
365 | if ((((uint)evc1 < (uint)32) && (((mask1 >> evc1) & 1) != 0)) || | 367 | if((((uint)evc1 < (uint)32) && (((mask1 >> evc1) & 1) != 0)) || |
366 | (((uint)evc2 < (uint)32) && (((mask2 >> evc2) & 1) != 0))) | 368 | (((uint)evc2 < (uint)32) && (((mask2 >> evc2) & 1) != 0))) |
367 | goto remfromq; | 369 | goto remfromq; |
368 | } | 370 | } |
@@ -373,51 +375,50 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
373 | m_SleepUntil = sleepUntil; | 375 | m_SleepUntil = sleepUntil; |
374 | m_SleepEventMask1 = mask1; | 376 | m_SleepEventMask1 = mask1; |
375 | m_SleepEventMask2 = mask2; | 377 | m_SleepEventMask2 = mask2; |
376 | Monitor.Exit (m_QueueLock); | 378 | Monitor.Exit(m_QueueLock); |
377 | suspendOnCheckRunTemp = true; | 379 | suspendOnCheckRunTemp = true; |
378 | callNo = 0; | 380 | callNo = 0; |
379 | __call0: | 381 | __call0: |
380 | CheckRunQuick (); | 382 | CheckRunQuick(); |
381 | goto checktmo; | 383 | goto checktmo; |
382 | 384 | ||
383 | /* | 385 | /* |
384 | * Found one, remove it from queue. | 386 | * Found one, remove it from queue. |
385 | */ | 387 | */ |
386 | remfromq: | 388 | remfromq: |
387 | m_EventQueue.Remove (lln); | 389 | m_EventQueue.Remove(lln); |
388 | if ((uint)evc1 < (uint)m_EventCounts.Length) | 390 | if((uint)evc1 < (uint)m_EventCounts.Length) |
389 | m_EventCounts[evc1] --; | 391 | m_EventCounts[evc1]--; |
390 | 392 | ||
391 | Monitor.Exit (m_QueueLock); | 393 | Monitor.Exit(m_QueueLock); |
392 | m_InstEHEvent ++; | 394 | m_InstEHEvent++; |
393 | 395 | ||
394 | /* | 396 | /* |
395 | * See if returnable or background event. | 397 | * See if returnable or background event. |
396 | */ | 398 | */ |
397 | if ((((uint)evc1 < (uint)32) && (((returnMask1 >> evc1) & 1) != 0)) || | 399 | if((((uint)evc1 < (uint)32) && (((returnMask1 >> evc1) & 1) != 0)) || |
398 | (((uint)evc2 < (uint)32) && (((returnMask2 >> evc2) & 1) != 0))) | 400 | (((uint)evc2 < (uint)32) && (((returnMask2 >> evc2) & 1) != 0))) |
399 | { | 401 | { |
400 | |||
401 | /* | 402 | /* |
402 | * Returnable event, return its parameters in a list. | 403 | * Returnable event, return its parameters in a list. |
403 | * Also set the detect parameters to what the event has. | 404 | * Also set the detect parameters to what the event has. |
404 | */ | 405 | */ |
405 | int plen = evt.Params.Length; | 406 | int plen = evt.Params.Length; |
406 | object[] plist = new object[plen+1]; | 407 | object[] plist = new object[plen + 1]; |
407 | plist[0] = (LSL_Integer)evc1; | 408 | plist[0] = (LSL_Integer)evc1; |
408 | for (int i = 0; i < plen;) | 409 | for(int i = 0; i < plen;) |
409 | { | 410 | { |
410 | object ob = evt.Params[i]; | 411 | object ob = evt.Params[i]; |
411 | if (ob is int) | 412 | if(ob is int) |
412 | ob = (LSL_Integer)(int)ob; | 413 | ob = (LSL_Integer)(int)ob; |
413 | else if (ob is double) | 414 | else if(ob is double) |
414 | ob = (LSL_Float)(double)ob; | 415 | ob = (LSL_Float)(double)ob; |
415 | else if (ob is string) | 416 | else if(ob is string) |
416 | ob = (LSL_String)(string)ob; | 417 | ob = (LSL_String)(string)ob; |
417 | plist[++i] = ob; | 418 | plist[++i] = ob; |
418 | } | 419 | } |
419 | m_DetectParams = evt.DetectParams; | 420 | m_DetectParams = evt.DetectParams; |
420 | return new LSL_List (plist); | 421 | return new LSL_List(plist); |
421 | } | 422 | } |
422 | 423 | ||
423 | /* | 424 | /* |
@@ -425,35 +426,35 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
425 | * then check event queue again. | 426 | * then check event queue again. |
426 | */ | 427 | */ |
427 | callNo = 1; | 428 | callNo = 1; |
428 | __call1: | 429 | __call1: |
429 | ScriptEventHandler seh = m_ObjCode.scriptEventHandlerTable[stateCode,evc1]; | 430 | ScriptEventHandler seh = m_ObjCode.scriptEventHandlerTable[stateCode, evc1]; |
430 | if (seh == null) | 431 | if(seh == null) |
431 | goto checktmo; | 432 | goto checktmo; |
432 | 433 | ||
433 | DetectParams[] saveDetParams = this.m_DetectParams; | 434 | DetectParams[] saveDetParams = this.m_DetectParams; |
434 | object[] saveEHArgs = this.ehArgs; | 435 | object[] saveEHArgs = this.ehArgs; |
435 | ScriptEventCode saveEventCode = this.eventCode; | 436 | ScriptEventCode saveEventCode = this.eventCode; |
436 | 437 | ||
437 | this.m_DetectParams = evt.DetectParams; | 438 | this.m_DetectParams = evt.DetectParams; |
438 | this.ehArgs = evt.Params; | 439 | this.ehArgs = evt.Params; |
439 | this.eventCode = evc; | 440 | this.eventCode = evc; |
440 | 441 | ||
441 | try | 442 | try |
442 | { | 443 | { |
443 | seh (this); | 444 | seh(this); |
444 | } | 445 | } |
445 | finally | 446 | finally |
446 | { | 447 | { |
447 | m_DetectParams = saveDetParams; | 448 | this.m_DetectParams = saveDetParams; |
448 | ehArgs = saveEHArgs; | 449 | this.ehArgs = saveEHArgs; |
449 | eventCode = saveEventCode; | 450 | this.eventCode = saveEventCode; |
450 | } | 451 | } |
451 | 452 | ||
452 | /* | 453 | /* |
453 | * Keep waiting until we find a returnable event or timeout. | 454 | * Keep waiting until we find a returnable event or timeout. |
454 | */ | 455 | */ |
455 | checktmo: | 456 | checktmo: |
456 | if (DateTime.UtcNow < sleepUntil) | 457 | if(DateTime.UtcNow < sleepUntil) |
457 | goto findevent; | 458 | goto findevent; |
458 | 459 | ||
459 | /* | 460 | /* |
@@ -463,7 +464,7 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
463 | } | 464 | } |
464 | finally | 465 | finally |
465 | { | 466 | { |
466 | if (callMode != CallMode_NORMAL) | 467 | if(callMode != CallMode_NORMAL) |
467 | { | 468 | { |
468 | 469 | ||
469 | /* | 470 | /* |
@@ -471,17 +472,17 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
471 | * Save everything we need at the __call<n> labels so we can restore it | 472 | * Save everything we need at the __call<n> labels so we can restore it |
472 | * when we need to. | 473 | * when we need to. |
473 | */ | 474 | */ |
474 | sv = CaptureStackFrame ("xmrEventDequeue", callNo, 9); | 475 | sv = CaptureStackFrame("xmrEventDequeue", callNo, 9); |
475 | sv[0] = sleepUntil.ToString (); // needed at __call0,__call1 | 476 | sv[0] = sleepUntil.ToString(); // needed at __call0,__call1 |
476 | sv[1] = returnMask1; // needed at __call0,__call1 | 477 | sv[1] = returnMask1; // needed at __call0,__call1 |
477 | sv[2] = returnMask2; // needed at __call0,__call1 | 478 | sv[2] = returnMask2; // needed at __call0,__call1 |
478 | sv[3] = mask1; // needed at __call0,__call1 | 479 | sv[3] = mask1; // needed at __call0,__call1 |
479 | sv[4] = mask2; // needed at __call0,__call1 | 480 | sv[4] = mask2; // needed at __call0,__call1 |
480 | if (callNo == 1) | 481 | if(callNo == 1) |
481 | { | 482 | { |
482 | sv[5] = evc1; // needed at __call1 | 483 | sv[5] = evc1; // needed at __call1 |
483 | sv[6] = (int)evc; // needed at __call1 | 484 | sv[6] = (int)evc; // needed at __call1 |
484 | sv[7] = DetPrmsToObjArr (evt.DetectParams); // needed at __call1 | 485 | sv[7] = DetPrmsToObjArr(evt.DetectParams); // needed at __call1 |
485 | sv[8] = evt.Params; // needed at __call1 | 486 | sv[8] = evt.Params; // needed at __call1 |
486 | } | 487 | } |
487 | } | 488 | } |
@@ -495,16 +496,16 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
495 | * are as currently set for the script (use xmrEventLoadDets to set how | 496 | * are as currently set for the script (use xmrEventLoadDets to set how |
496 | * you want them to be different). | 497 | * you want them to be different). |
497 | */ | 498 | */ |
498 | public override void xmrEventEnqueue (LSL_List ev) | 499 | public override void xmrEventEnqueue(LSL_List ev) |
499 | { | 500 | { |
500 | object[] data = ev.Data; | 501 | object[] data = ev.Data; |
501 | ScriptEventCode evc = (ScriptEventCode)ListInt (data[0]); | 502 | ScriptEventCode evc = (ScriptEventCode)ListInt(data[0]); |
502 | 503 | ||
503 | int nargs = data.Length - 1; | 504 | int nargs = data.Length - 1; |
504 | object[] args = new object[nargs]; | 505 | object[] args = new object[nargs]; |
505 | Array.Copy (data, 1, args, 0, nargs); | 506 | Array.Copy(data, 1, args, 0, nargs); |
506 | 507 | ||
507 | PostEvent (new EventParams (evc.ToString (), args, m_DetectParams)); | 508 | PostEvent(new EventParams(evc.ToString(), args, m_DetectParams)); |
508 | } | 509 | } |
509 | 510 | ||
510 | /** | 511 | /** |
@@ -513,19 +514,19 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
513 | */ | 514 | */ |
514 | private const int saveDPVer = 1; | 515 | private const int saveDPVer = 1; |
515 | 516 | ||
516 | public override LSL_List xmrEventSaveDets () | 517 | public override LSL_List xmrEventSaveDets() |
517 | { | 518 | { |
518 | object[] obs = DetPrmsToObjArr (m_DetectParams); | 519 | object[] obs = DetPrmsToObjArr(m_DetectParams); |
519 | return new LSL_List (obs); | 520 | return new LSL_List(obs); |
520 | } | 521 | } |
521 | 522 | ||
522 | private static object[] DetPrmsToObjArr (DetectParams[] dps) | 523 | private static object[] DetPrmsToObjArr(DetectParams[] dps) |
523 | { | 524 | { |
524 | int len = dps.Length; | 525 | int len = dps.Length; |
525 | object[] obs = new object[len*16+1]; | 526 | object[] obs = new object[len * 16 + 1]; |
526 | int j = 0; | 527 | int j = 0; |
527 | obs[j++] = (LSL_Integer)saveDPVer; | 528 | obs[j++] = (LSL_Integer)saveDPVer; |
528 | for (int i = 0; i < len; i ++) | 529 | for(int i = 0; i < len; i++) |
529 | { | 530 | { |
530 | DetectParams dp = dps[i]; | 531 | DetectParams dp = dps[i]; |
531 | obs[j++] = (LSL_String)dp.Key.ToString(); // UUID | 532 | obs[j++] = (LSL_String)dp.Key.ToString(); // UUID |
@@ -548,54 +549,52 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
548 | return obs; | 549 | return obs; |
549 | } | 550 | } |
550 | 551 | ||
551 | |||
552 | /** | 552 | /** |
553 | * @brief Load current detect params from a list | 553 | * @brief Load current detect params from a list |
554 | * @param dpList = as returned by xmrEventSaveDets() | 554 | * @param dpList = as returned by xmrEventSaveDets() |
555 | */ | 555 | */ |
556 | public override void xmrEventLoadDets (LSL_List dpList) | 556 | public override void xmrEventLoadDets(LSL_List dpList) |
557 | { | 557 | { |
558 | m_DetectParams = ObjArrToDetPrms (dpList.Data); | 558 | m_DetectParams = ObjArrToDetPrms(dpList.Data); |
559 | } | 559 | } |
560 | 560 | ||
561 | private static DetectParams[] ObjArrToDetPrms (object[] objs) | 561 | private static DetectParams[] ObjArrToDetPrms(object[] objs) |
562 | { | 562 | { |
563 | int j = 0; | 563 | int j = 0; |
564 | if ((objs.Length % 16 != 1) || (ListInt (objs[j++]) != saveDPVer)) | 564 | if((objs.Length % 16 != 1) || (ListInt(objs[j++]) != saveDPVer)) |
565 | throw new Exception ("invalid detect param format"); | 565 | throw new Exception("invalid detect param format"); |
566 | 566 | ||
567 | int len = objs.Length / 16; | 567 | int len = objs.Length / 16; |
568 | DetectParams[] dps = new DetectParams[len]; | 568 | DetectParams[] dps = new DetectParams[len]; |
569 | 569 | ||
570 | for (int i = 0; i < len; i ++) | 570 | for(int i = 0; i < len; i++) |
571 | { | 571 | { |
572 | DetectParams dp = new DetectParams (); | 572 | DetectParams dp = new DetectParams(); |
573 | 573 | ||
574 | dp.Key = new UUID (ListStr (objs[j++])); | 574 | dp.Key = new UUID(ListStr(objs[j++])); |
575 | dp.OffsetPos = (LSL_Vector)objs[j++]; | 575 | dp.OffsetPos = (LSL_Vector)objs[j++]; |
576 | dp.LinkNum = ListInt (objs[j++]); | 576 | dp.LinkNum = ListInt(objs[j++]); |
577 | dp.Group = new UUID (ListStr (objs[j++])); | 577 | dp.Group = new UUID(ListStr(objs[j++])); |
578 | dp.Name = ListStr (objs[j++]); | 578 | dp.Name = ListStr(objs[j++]); |
579 | dp.Owner = new UUID (ListStr (objs[j++])); | 579 | dp.Owner = new UUID(ListStr(objs[j++])); |
580 | dp.Position = (LSL_Vector)objs[j++]; | 580 | dp.Position = (LSL_Vector)objs[j++]; |
581 | dp.Rotation = (LSL_Rotation)objs[j++]; | 581 | dp.Rotation = (LSL_Rotation)objs[j++]; |
582 | dp.Type = ListInt (objs[j++]); | 582 | dp.Type = ListInt(objs[j++]); |
583 | dp.Velocity = (LSL_Vector)objs[j++]; | 583 | dp.Velocity = (LSL_Vector)objs[j++]; |
584 | 584 | ||
585 | SurfaceTouchEventArgs stea = new SurfaceTouchEventArgs (); | 585 | SurfaceTouchEventArgs stea = new SurfaceTouchEventArgs(); |
586 | 586 | ||
587 | stea.STCoord = LSLVec2OMVec ((LSL_Vector)objs[j++]); | 587 | stea.STCoord = LSLVec2OMVec((LSL_Vector)objs[j++]); |
588 | stea.Normal = LSLVec2OMVec ((LSL_Vector)objs[j++]); | 588 | stea.Normal = LSLVec2OMVec((LSL_Vector)objs[j++]); |
589 | stea.Binormal = LSLVec2OMVec ((LSL_Vector)objs[j++]); | 589 | stea.Binormal = LSLVec2OMVec((LSL_Vector)objs[j++]); |
590 | stea.Position = LSLVec2OMVec ((LSL_Vector)objs[j++]); | 590 | stea.Position = LSLVec2OMVec((LSL_Vector)objs[j++]); |
591 | stea.UVCoord = LSLVec2OMVec ((LSL_Vector)objs[j++]); | 591 | stea.UVCoord = LSLVec2OMVec((LSL_Vector)objs[j++]); |
592 | stea.FaceIndex = ListInt (objs[j++]); | 592 | stea.FaceIndex = ListInt(objs[j++]); |
593 | 593 | ||
594 | dp.SurfaceTouchArgs = stea; | 594 | dp.SurfaceTouchArgs = stea; |
595 | 595 | ||
596 | dps[i] = dp; | 596 | dps[i] = dp; |
597 | } | 597 | } |
598 | |||
599 | return dps; | 598 | return dps; |
600 | } | 599 | } |
601 | 600 | ||
@@ -623,21 +622,13 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
623 | /* | 622 | /* |
624 | * Clear out any old events from the queue. | 623 | * Clear out any old events from the queue. |
625 | */ | 624 | */ |
626 | lock (m_QueueLock) | 625 | lock(m_QueueLock) |
627 | { | 626 | { |
628 | m_EventQueue.Clear(); | 627 | m_EventQueue.Clear(); |
629 | for (int i = m_EventCounts.Length; -- i >= 0;) | 628 | for(int i = m_EventCounts.Length; --i >= 0;) |
630 | m_EventCounts[i] = 0; | 629 | m_EventCounts[i] = 0; |
631 | } | 630 | } |
632 | } | 631 | } |
633 | |||
634 | /** | ||
635 | * @brief Script is calling xmrStackLeft(). | ||
636 | */ | ||
637 | public override int xmrStackLeft () | ||
638 | { | ||
639 | return microthread.StackLeft (); | ||
640 | } | ||
641 | } | 632 | } |
642 | 633 | ||
643 | /** | 634 | /** |
@@ -646,12 +637,16 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
646 | * handler. We don't want script-level try/catch to intercept | 637 | * handler. We don't want script-level try/catch to intercept |
647 | * these so scripts can't interfere with the behavior. | 638 | * these so scripts can't interfere with the behavior. |
648 | */ | 639 | */ |
649 | public class ScriptResetException : Exception, IXMRUncatchable { } | 640 | public class ScriptResetException: Exception, IXMRUncatchable |
641 | { | ||
642 | } | ||
650 | 643 | ||
651 | /** | 644 | /** |
652 | * @brief Thrown by things like llDie() to unconditionally unwind as | 645 | * @brief Thrown by things like llDie() to unconditionally unwind as |
653 | * script. We don't want script-level try/catch to intercept | 646 | * script. We don't want script-level try/catch to intercept |
654 | * these so scripts can't interfere with the behavior. | 647 | * these so scripts can't interfere with the behavior. |
655 | */ | 648 | */ |
656 | public class ScriptDieException : Exception, IXMRUncatchable { } | 649 | public class ScriptDieException: Exception, IXMRUncatchable |
650 | { | ||
651 | } | ||
657 | } | 652 | } |