diff options
Diffstat (limited to 'OpenSim/Region/ScriptEngine/Shared')
6 files changed, 481 insertions, 379 deletions
diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs index fbbbfdc..6e5436a 100644 --- a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs +++ b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/LSL_Api.cs | |||
@@ -28,6 +28,7 @@ | |||
28 | using System; | 28 | using System; |
29 | using System.Collections; | 29 | using System.Collections; |
30 | using System.Collections.Generic; | 30 | using System.Collections.Generic; |
31 | using System.Diagnostics; //for [DebuggerNonUserCode] | ||
31 | using System.Runtime.Remoting.Lifetime; | 32 | using System.Runtime.Remoting.Lifetime; |
32 | using System.Text; | 33 | using System.Text; |
33 | using System.Threading; | 34 | using System.Threading; |
@@ -151,6 +152,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
151 | get { return m_ScriptEngine.World; } | 152 | get { return m_ScriptEngine.World; } |
152 | } | 153 | } |
153 | 154 | ||
155 | [DebuggerNonUserCode] | ||
154 | public void state(string newState) | 156 | public void state(string newState) |
155 | { | 157 | { |
156 | m_ScriptEngine.SetState(m_itemID, newState); | 158 | m_ScriptEngine.SetState(m_itemID, newState); |
@@ -160,6 +162,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
160 | /// Reset the named script. The script must be present | 162 | /// Reset the named script. The script must be present |
161 | /// in the same prim. | 163 | /// in the same prim. |
162 | /// </summary> | 164 | /// </summary> |
165 | [DebuggerNonUserCode] | ||
163 | public void llResetScript() | 166 | public void llResetScript() |
164 | { | 167 | { |
165 | m_host.AddScriptLPS(1); | 168 | m_host.AddScriptLPS(1); |
@@ -272,40 +275,48 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
272 | protected UUID InventorySelf() | 275 | protected UUID InventorySelf() |
273 | { | 276 | { |
274 | UUID invItemID = new UUID(); | 277 | UUID invItemID = new UUID(); |
275 | 278 | bool unlock = false; | |
276 | lock (m_host.TaskInventory) | 279 | if (!m_host.TaskInventory.IsReadLockedByMe()) |
280 | { | ||
281 | m_host.TaskInventory.LockItemsForRead(true); | ||
282 | unlock = true; | ||
283 | } | ||
284 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | ||
277 | { | 285 | { |
278 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | 286 | if (inv.Value.Type == 10 && inv.Value.ItemID == m_itemID) |
279 | { | 287 | { |
280 | if (inv.Value.Type == 10 && inv.Value.ItemID == m_itemID) | 288 | invItemID = inv.Key; |
281 | { | 289 | break; |
282 | invItemID = inv.Key; | ||
283 | break; | ||
284 | } | ||
285 | } | 290 | } |
286 | } | 291 | } |
287 | 292 | if (unlock) | |
293 | { | ||
294 | m_host.TaskInventory.LockItemsForRead(false); | ||
295 | } | ||
288 | return invItemID; | 296 | return invItemID; |
289 | } | 297 | } |
290 | 298 | ||
291 | protected UUID InventoryKey(string name, int type) | 299 | protected UUID InventoryKey(string name, int type) |
292 | { | 300 | { |
293 | m_host.AddScriptLPS(1); | 301 | m_host.AddScriptLPS(1); |
294 | 302 | m_host.TaskInventory.LockItemsForRead(true); | |
295 | lock (m_host.TaskInventory) | 303 | |
304 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | ||
296 | { | 305 | { |
297 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | 306 | if (inv.Value.Name == name) |
298 | { | 307 | { |
299 | if (inv.Value.Name == name) | 308 | m_host.TaskInventory.LockItemsForRead(false); |
309 | |||
310 | if (inv.Value.Type != type) | ||
300 | { | 311 | { |
301 | if (inv.Value.Type != type) | 312 | return UUID.Zero; |
302 | return UUID.Zero; | ||
303 | |||
304 | return inv.Value.AssetID; | ||
305 | } | 313 | } |
314 | |||
315 | return inv.Value.AssetID; | ||
306 | } | 316 | } |
307 | } | 317 | } |
308 | 318 | ||
319 | m_host.TaskInventory.LockItemsForRead(false); | ||
309 | return UUID.Zero; | 320 | return UUID.Zero; |
310 | } | 321 | } |
311 | 322 | ||
@@ -313,17 +324,21 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
313 | { | 324 | { |
314 | m_host.AddScriptLPS(1); | 325 | m_host.AddScriptLPS(1); |
315 | 326 | ||
316 | lock (m_host.TaskInventory) | 327 | |
328 | m_host.TaskInventory.LockItemsForRead(true); | ||
329 | |||
330 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | ||
317 | { | 331 | { |
318 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | 332 | if (inv.Value.Name == name) |
319 | { | 333 | { |
320 | if (inv.Value.Name == name) | 334 | m_host.TaskInventory.LockItemsForRead(false); |
321 | { | 335 | return inv.Value.AssetID; |
322 | return inv.Value.AssetID; | ||
323 | } | ||
324 | } | 336 | } |
325 | } | 337 | } |
326 | 338 | ||
339 | m_host.TaskInventory.LockItemsForRead(false); | ||
340 | |||
341 | |||
327 | return UUID.Zero; | 342 | return UUID.Zero; |
328 | } | 343 | } |
329 | 344 | ||
@@ -2546,12 +2561,9 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
2546 | 2561 | ||
2547 | m_host.AddScriptLPS(1); | 2562 | m_host.AddScriptLPS(1); |
2548 | 2563 | ||
2564 | m_host.TaskInventory.LockItemsForRead(true); | ||
2549 | TaskInventoryItem item = m_host.TaskInventory[invItemID]; | 2565 | TaskInventoryItem item = m_host.TaskInventory[invItemID]; |
2550 | 2566 | m_host.TaskInventory.LockItemsForRead(false); | |
2551 | lock (m_host.TaskInventory) | ||
2552 | { | ||
2553 | item = m_host.TaskInventory[invItemID]; | ||
2554 | } | ||
2555 | 2567 | ||
2556 | if (item.PermsGranter == UUID.Zero) | 2568 | if (item.PermsGranter == UUID.Zero) |
2557 | return 0; | 2569 | return 0; |
@@ -2626,6 +2638,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
2626 | if (dist > m_ScriptDistanceFactor * 10.0f) | 2638 | if (dist > m_ScriptDistanceFactor * 10.0f) |
2627 | return; | 2639 | return; |
2628 | 2640 | ||
2641 | //Clone is thread-safe | ||
2629 | TaskInventoryDictionary partInventory = (TaskInventoryDictionary)m_host.TaskInventory.Clone(); | 2642 | TaskInventoryDictionary partInventory = (TaskInventoryDictionary)m_host.TaskInventory.Clone(); |
2630 | 2643 | ||
2631 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in partInventory) | 2644 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in partInventory) |
@@ -2711,11 +2724,21 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
2711 | // Orient the object to the angle calculated | 2724 | // Orient the object to the angle calculated |
2712 | llSetRot(rot); | 2725 | llSetRot(rot); |
2713 | } | 2726 | } |
2727 | |||
2728 | public void llRotLookAt(LSL_Rotation target, double strength, double damping) | ||
2729 | { | ||
2730 | m_host.AddScriptLPS(1); | ||
2731 | // NotImplemented("llRotLookAt"); | ||
2732 | m_host.RotLookAt(Rot2Quaternion(target), (float)strength, (float)damping); | ||
2733 | |||
2734 | } | ||
2735 | |||
2714 | 2736 | ||
2715 | public void llStopLookAt() | 2737 | public void llStopLookAt() |
2716 | { | 2738 | { |
2717 | m_host.AddScriptLPS(1); | 2739 | m_host.AddScriptLPS(1); |
2718 | NotImplemented("llStopLookAt"); | 2740 | // NotImplemented("llStopLookAt"); |
2741 | m_host.StopLookAt(); | ||
2719 | } | 2742 | } |
2720 | 2743 | ||
2721 | public void llSetTimerEvent(double sec) | 2744 | public void llSetTimerEvent(double sec) |
@@ -2749,13 +2772,17 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
2749 | { | 2772 | { |
2750 | TaskInventoryItem item; | 2773 | TaskInventoryItem item; |
2751 | 2774 | ||
2752 | lock (m_host.TaskInventory) | 2775 | m_host.TaskInventory.LockItemsForRead(true); |
2776 | if (!m_host.TaskInventory.ContainsKey(InventorySelf())) | ||
2753 | { | 2777 | { |
2754 | if (!m_host.TaskInventory.ContainsKey(InventorySelf())) | 2778 | m_host.TaskInventory.LockItemsForRead(false); |
2755 | return; | 2779 | return; |
2756 | else | 2780 | } |
2757 | item = m_host.TaskInventory[InventorySelf()]; | 2781 | else |
2782 | { | ||
2783 | item = m_host.TaskInventory[InventorySelf()]; | ||
2758 | } | 2784 | } |
2785 | m_host.TaskInventory.LockItemsForRead(false); | ||
2759 | 2786 | ||
2760 | if (item.PermsGranter != UUID.Zero) | 2787 | if (item.PermsGranter != UUID.Zero) |
2761 | { | 2788 | { |
@@ -2777,13 +2804,21 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
2777 | { | 2804 | { |
2778 | TaskInventoryItem item; | 2805 | TaskInventoryItem item; |
2779 | 2806 | ||
2807 | m_host.TaskInventory.LockItemsForRead(true); | ||
2780 | lock (m_host.TaskInventory) | 2808 | lock (m_host.TaskInventory) |
2781 | { | 2809 | { |
2810 | |||
2782 | if (!m_host.TaskInventory.ContainsKey(InventorySelf())) | 2811 | if (!m_host.TaskInventory.ContainsKey(InventorySelf())) |
2812 | { | ||
2813 | m_host.TaskInventory.LockItemsForRead(false); | ||
2783 | return; | 2814 | return; |
2815 | } | ||
2784 | else | 2816 | else |
2817 | { | ||
2785 | item = m_host.TaskInventory[InventorySelf()]; | 2818 | item = m_host.TaskInventory[InventorySelf()]; |
2819 | } | ||
2786 | } | 2820 | } |
2821 | m_host.TaskInventory.LockItemsForRead(false); | ||
2787 | 2822 | ||
2788 | m_host.AddScriptLPS(1); | 2823 | m_host.AddScriptLPS(1); |
2789 | 2824 | ||
@@ -2820,13 +2855,19 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
2820 | 2855 | ||
2821 | TaskInventoryItem item; | 2856 | TaskInventoryItem item; |
2822 | 2857 | ||
2823 | lock (m_host.TaskInventory) | 2858 | m_host.TaskInventory.LockItemsForRead(true); |
2859 | |||
2860 | if (!m_host.TaskInventory.ContainsKey(InventorySelf())) | ||
2824 | { | 2861 | { |
2825 | if (!m_host.TaskInventory.ContainsKey(InventorySelf())) | 2862 | m_host.TaskInventory.LockItemsForRead(false); |
2826 | return; | 2863 | return; |
2827 | else | ||
2828 | item = m_host.TaskInventory[InventorySelf()]; | ||
2829 | } | 2864 | } |
2865 | else | ||
2866 | { | ||
2867 | item = m_host.TaskInventory[InventorySelf()]; | ||
2868 | } | ||
2869 | |||
2870 | m_host.TaskInventory.LockItemsForRead(false); | ||
2830 | 2871 | ||
2831 | if (item.PermsGranter != m_host.OwnerID) | 2872 | if (item.PermsGranter != m_host.OwnerID) |
2832 | return; | 2873 | return; |
@@ -2852,13 +2893,19 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
2852 | 2893 | ||
2853 | TaskInventoryItem item; | 2894 | TaskInventoryItem item; |
2854 | 2895 | ||
2855 | lock (m_host.TaskInventory) | 2896 | m_host.TaskInventory.LockItemsForRead(true); |
2897 | |||
2898 | if (!m_host.TaskInventory.ContainsKey(InventorySelf())) | ||
2856 | { | 2899 | { |
2857 | if (!m_host.TaskInventory.ContainsKey(InventorySelf())) | 2900 | m_host.TaskInventory.LockItemsForRead(false); |
2858 | return; | 2901 | return; |
2859 | else | ||
2860 | item = m_host.TaskInventory[InventorySelf()]; | ||
2861 | } | 2902 | } |
2903 | else | ||
2904 | { | ||
2905 | item = m_host.TaskInventory[InventorySelf()]; | ||
2906 | } | ||
2907 | m_host.TaskInventory.LockItemsForRead(false); | ||
2908 | |||
2862 | 2909 | ||
2863 | if (item.PermsGranter != m_host.OwnerID) | 2910 | if (item.PermsGranter != m_host.OwnerID) |
2864 | return; | 2911 | return; |
@@ -3059,12 +3106,6 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3059 | m_host.AddScriptLPS(1); | 3106 | m_host.AddScriptLPS(1); |
3060 | } | 3107 | } |
3061 | 3108 | ||
3062 | public void llRotLookAt(LSL_Rotation target, double strength, double damping) | ||
3063 | { | ||
3064 | m_host.AddScriptLPS(1); | ||
3065 | NotImplemented("llRotLookAt"); | ||
3066 | } | ||
3067 | |||
3068 | public LSL_Integer llStringLength(string str) | 3109 | public LSL_Integer llStringLength(string str) |
3069 | { | 3110 | { |
3070 | m_host.AddScriptLPS(1); | 3111 | m_host.AddScriptLPS(1); |
@@ -3088,14 +3129,17 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3088 | 3129 | ||
3089 | TaskInventoryItem item; | 3130 | TaskInventoryItem item; |
3090 | 3131 | ||
3091 | lock (m_host.TaskInventory) | 3132 | m_host.TaskInventory.LockItemsForRead(true); |
3133 | if (!m_host.TaskInventory.ContainsKey(InventorySelf())) | ||
3092 | { | 3134 | { |
3093 | if (!m_host.TaskInventory.ContainsKey(InventorySelf())) | 3135 | m_host.TaskInventory.LockItemsForRead(false); |
3094 | return; | 3136 | return; |
3095 | else | ||
3096 | item = m_host.TaskInventory[InventorySelf()]; | ||
3097 | } | 3137 | } |
3098 | 3138 | else | |
3139 | { | ||
3140 | item = m_host.TaskInventory[InventorySelf()]; | ||
3141 | } | ||
3142 | m_host.TaskInventory.LockItemsForRead(false); | ||
3099 | if (item.PermsGranter == UUID.Zero) | 3143 | if (item.PermsGranter == UUID.Zero) |
3100 | return; | 3144 | return; |
3101 | 3145 | ||
@@ -3125,13 +3169,18 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3125 | 3169 | ||
3126 | TaskInventoryItem item; | 3170 | TaskInventoryItem item; |
3127 | 3171 | ||
3128 | lock (m_host.TaskInventory) | 3172 | m_host.TaskInventory.LockItemsForRead(true); |
3173 | if (!m_host.TaskInventory.ContainsKey(InventorySelf())) | ||
3129 | { | 3174 | { |
3130 | if (!m_host.TaskInventory.ContainsKey(InventorySelf())) | 3175 | m_host.TaskInventory.LockItemsForRead(false); |
3131 | return; | 3176 | return; |
3132 | else | 3177 | } |
3133 | item = m_host.TaskInventory[InventorySelf()]; | 3178 | else |
3179 | { | ||
3180 | item = m_host.TaskInventory[InventorySelf()]; | ||
3134 | } | 3181 | } |
3182 | m_host.TaskInventory.LockItemsForRead(false); | ||
3183 | |||
3135 | 3184 | ||
3136 | if (item.PermsGranter == UUID.Zero) | 3185 | if (item.PermsGranter == UUID.Zero) |
3137 | return; | 3186 | return; |
@@ -3204,10 +3253,18 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3204 | 3253 | ||
3205 | TaskInventoryItem item; | 3254 | TaskInventoryItem item; |
3206 | 3255 | ||
3207 | lock (m_host.TaskInventory) | 3256 | |
3257 | m_host.TaskInventory.LockItemsForRead(true); | ||
3258 | if (!m_host.TaskInventory.ContainsKey(invItemID)) | ||
3259 | { | ||
3260 | m_host.TaskInventory.LockItemsForRead(false); | ||
3261 | return; | ||
3262 | } | ||
3263 | else | ||
3208 | { | 3264 | { |
3209 | item = m_host.TaskInventory[invItemID]; | 3265 | item = m_host.TaskInventory[invItemID]; |
3210 | } | 3266 | } |
3267 | m_host.TaskInventory.LockItemsForRead(false); | ||
3211 | 3268 | ||
3212 | if (agentID == UUID.Zero || perm == 0) // Releasing permissions | 3269 | if (agentID == UUID.Zero || perm == 0) // Releasing permissions |
3213 | { | 3270 | { |
@@ -3239,11 +3296,10 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3239 | 3296 | ||
3240 | if ((perm & (~implicitPerms)) == 0) // Requested only implicit perms | 3297 | if ((perm & (~implicitPerms)) == 0) // Requested only implicit perms |
3241 | { | 3298 | { |
3242 | lock (m_host.TaskInventory) | 3299 | m_host.TaskInventory.LockItemsForWrite(true); |
3243 | { | 3300 | m_host.TaskInventory[invItemID].PermsGranter = agentID; |
3244 | m_host.TaskInventory[invItemID].PermsGranter = agentID; | 3301 | m_host.TaskInventory[invItemID].PermsMask = perm; |
3245 | m_host.TaskInventory[invItemID].PermsMask = perm; | 3302 | m_host.TaskInventory.LockItemsForWrite(false); |
3246 | } | ||
3247 | 3303 | ||
3248 | m_ScriptEngine.PostScriptEvent(m_itemID, new EventParams( | 3304 | m_ScriptEngine.PostScriptEvent(m_itemID, new EventParams( |
3249 | "run_time_permissions", new Object[] { | 3305 | "run_time_permissions", new Object[] { |
@@ -3263,11 +3319,10 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3263 | 3319 | ||
3264 | if ((perm & (~implicitPerms)) == 0) // Requested only implicit perms | 3320 | if ((perm & (~implicitPerms)) == 0) // Requested only implicit perms |
3265 | { | 3321 | { |
3266 | lock (m_host.TaskInventory) | 3322 | m_host.TaskInventory.LockItemsForWrite(true); |
3267 | { | 3323 | m_host.TaskInventory[invItemID].PermsGranter = agentID; |
3268 | m_host.TaskInventory[invItemID].PermsGranter = agentID; | 3324 | m_host.TaskInventory[invItemID].PermsMask = perm; |
3269 | m_host.TaskInventory[invItemID].PermsMask = perm; | 3325 | m_host.TaskInventory.LockItemsForWrite(false); |
3270 | } | ||
3271 | 3326 | ||
3272 | m_ScriptEngine.PostScriptEvent(m_itemID, new EventParams( | 3327 | m_ScriptEngine.PostScriptEvent(m_itemID, new EventParams( |
3273 | "run_time_permissions", new Object[] { | 3328 | "run_time_permissions", new Object[] { |
@@ -3288,11 +3343,10 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3288 | 3343 | ||
3289 | if (!m_waitingForScriptAnswer) | 3344 | if (!m_waitingForScriptAnswer) |
3290 | { | 3345 | { |
3291 | lock (m_host.TaskInventory) | 3346 | m_host.TaskInventory.LockItemsForWrite(true); |
3292 | { | 3347 | m_host.TaskInventory[invItemID].PermsGranter = agentID; |
3293 | m_host.TaskInventory[invItemID].PermsGranter = agentID; | 3348 | m_host.TaskInventory[invItemID].PermsMask = 0; |
3294 | m_host.TaskInventory[invItemID].PermsMask = 0; | 3349 | m_host.TaskInventory.LockItemsForWrite(false); |
3295 | } | ||
3296 | 3350 | ||
3297 | presence.ControllingClient.OnScriptAnswer += handleScriptAnswer; | 3351 | presence.ControllingClient.OnScriptAnswer += handleScriptAnswer; |
3298 | m_waitingForScriptAnswer=true; | 3352 | m_waitingForScriptAnswer=true; |
@@ -3327,10 +3381,11 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3327 | if ((answer & ScriptBaseClass.PERMISSION_TAKE_CONTROLS) == 0) | 3381 | if ((answer & ScriptBaseClass.PERMISSION_TAKE_CONTROLS) == 0) |
3328 | llReleaseControls(); | 3382 | llReleaseControls(); |
3329 | 3383 | ||
3330 | lock (m_host.TaskInventory) | 3384 | |
3331 | { | 3385 | m_host.TaskInventory.LockItemsForWrite(true); |
3332 | m_host.TaskInventory[invItemID].PermsMask = answer; | 3386 | m_host.TaskInventory[invItemID].PermsMask = answer; |
3333 | } | 3387 | m_host.TaskInventory.LockItemsForWrite(false); |
3388 | |||
3334 | 3389 | ||
3335 | m_ScriptEngine.PostScriptEvent(m_itemID, new EventParams( | 3390 | m_ScriptEngine.PostScriptEvent(m_itemID, new EventParams( |
3336 | "run_time_permissions", new Object[] { | 3391 | "run_time_permissions", new Object[] { |
@@ -3342,16 +3397,17 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3342 | { | 3397 | { |
3343 | m_host.AddScriptLPS(1); | 3398 | m_host.AddScriptLPS(1); |
3344 | 3399 | ||
3345 | lock (m_host.TaskInventory) | 3400 | m_host.TaskInventory.LockItemsForRead(true); |
3401 | |||
3402 | foreach (TaskInventoryItem item in m_host.TaskInventory.Values) | ||
3346 | { | 3403 | { |
3347 | foreach (TaskInventoryItem item in m_host.TaskInventory.Values) | 3404 | if (item.Type == 10 && item.ItemID == m_itemID) |
3348 | { | 3405 | { |
3349 | if (item.Type == 10 && item.ItemID == m_itemID) | 3406 | m_host.TaskInventory.LockItemsForRead(false); |
3350 | { | 3407 | return item.PermsGranter.ToString(); |
3351 | return item.PermsGranter.ToString(); | ||
3352 | } | ||
3353 | } | 3408 | } |
3354 | } | 3409 | } |
3410 | m_host.TaskInventory.LockItemsForRead(false); | ||
3355 | 3411 | ||
3356 | return UUID.Zero.ToString(); | 3412 | return UUID.Zero.ToString(); |
3357 | } | 3413 | } |
@@ -3360,19 +3416,20 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3360 | { | 3416 | { |
3361 | m_host.AddScriptLPS(1); | 3417 | m_host.AddScriptLPS(1); |
3362 | 3418 | ||
3363 | lock (m_host.TaskInventory) | 3419 | m_host.TaskInventory.LockItemsForRead(true); |
3420 | |||
3421 | foreach (TaskInventoryItem item in m_host.TaskInventory.Values) | ||
3364 | { | 3422 | { |
3365 | foreach (TaskInventoryItem item in m_host.TaskInventory.Values) | 3423 | if (item.Type == 10 && item.ItemID == m_itemID) |
3366 | { | 3424 | { |
3367 | if (item.Type == 10 && item.ItemID == m_itemID) | 3425 | int perms = item.PermsMask; |
3368 | { | 3426 | if (m_automaticLinkPermission) |
3369 | int perms = item.PermsMask; | 3427 | perms |= ScriptBaseClass.PERMISSION_CHANGE_LINKS; |
3370 | if (m_automaticLinkPermission) | 3428 | m_host.TaskInventory.LockItemsForRead(false); |
3371 | perms |= ScriptBaseClass.PERMISSION_CHANGE_LINKS; | 3429 | return perms; |
3372 | return perms; | ||
3373 | } | ||
3374 | } | 3430 | } |
3375 | } | 3431 | } |
3432 | m_host.TaskInventory.LockItemsForRead(false); | ||
3376 | 3433 | ||
3377 | return 0; | 3434 | return 0; |
3378 | } | 3435 | } |
@@ -3405,11 +3462,10 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3405 | UUID invItemID = InventorySelf(); | 3462 | UUID invItemID = InventorySelf(); |
3406 | 3463 | ||
3407 | TaskInventoryItem item; | 3464 | TaskInventoryItem item; |
3408 | lock (m_host.TaskInventory) | 3465 | m_host.TaskInventory.LockItemsForRead(true); |
3409 | { | 3466 | item = m_host.TaskInventory[invItemID]; |
3410 | item = m_host.TaskInventory[invItemID]; | 3467 | m_host.TaskInventory.LockItemsForRead(false); |
3411 | } | 3468 | |
3412 | |||
3413 | if ((item.PermsMask & ScriptBaseClass.PERMISSION_CHANGE_LINKS) == 0 | 3469 | if ((item.PermsMask & ScriptBaseClass.PERMISSION_CHANGE_LINKS) == 0 |
3414 | && !m_automaticLinkPermission) | 3470 | && !m_automaticLinkPermission) |
3415 | { | 3471 | { |
@@ -3462,16 +3518,16 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3462 | m_host.AddScriptLPS(1); | 3518 | m_host.AddScriptLPS(1); |
3463 | UUID invItemID = InventorySelf(); | 3519 | UUID invItemID = InventorySelf(); |
3464 | 3520 | ||
3465 | lock (m_host.TaskInventory) | 3521 | m_host.TaskInventory.LockItemsForRead(true); |
3466 | { | ||
3467 | if ((m_host.TaskInventory[invItemID].PermsMask & ScriptBaseClass.PERMISSION_CHANGE_LINKS) == 0 | 3522 | if ((m_host.TaskInventory[invItemID].PermsMask & ScriptBaseClass.PERMISSION_CHANGE_LINKS) == 0 |
3468 | && !m_automaticLinkPermission) | 3523 | && !m_automaticLinkPermission) |
3469 | { | 3524 | { |
3470 | ShoutError("Script trying to link but PERMISSION_CHANGE_LINKS permission not set!"); | 3525 | ShoutError("Script trying to link but PERMISSION_CHANGE_LINKS permission not set!"); |
3526 | m_host.TaskInventory.LockItemsForRead(false); | ||
3471 | return; | 3527 | return; |
3472 | } | 3528 | } |
3473 | } | 3529 | m_host.TaskInventory.LockItemsForRead(false); |
3474 | 3530 | ||
3475 | if (linknum < ScriptBaseClass.LINK_THIS) | 3531 | if (linknum < ScriptBaseClass.LINK_THIS) |
3476 | return; | 3532 | return; |
3477 | 3533 | ||
@@ -3640,17 +3696,16 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3640 | m_host.AddScriptLPS(1); | 3696 | m_host.AddScriptLPS(1); |
3641 | int count = 0; | 3697 | int count = 0; |
3642 | 3698 | ||
3643 | lock (m_host.TaskInventory) | 3699 | m_host.TaskInventory.LockItemsForRead(true); |
3700 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | ||
3644 | { | 3701 | { |
3645 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | 3702 | if (inv.Value.Type == type || type == -1) |
3646 | { | 3703 | { |
3647 | if (inv.Value.Type == type || type == -1) | 3704 | count = count + 1; |
3648 | { | ||
3649 | count = count + 1; | ||
3650 | } | ||
3651 | } | 3705 | } |
3652 | } | 3706 | } |
3653 | 3707 | ||
3708 | m_host.TaskInventory.LockItemsForRead(false); | ||
3654 | return count; | 3709 | return count; |
3655 | } | 3710 | } |
3656 | 3711 | ||
@@ -3659,16 +3714,15 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3659 | m_host.AddScriptLPS(1); | 3714 | m_host.AddScriptLPS(1); |
3660 | ArrayList keys = new ArrayList(); | 3715 | ArrayList keys = new ArrayList(); |
3661 | 3716 | ||
3662 | lock (m_host.TaskInventory) | 3717 | m_host.TaskInventory.LockItemsForRead(true); |
3718 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | ||
3663 | { | 3719 | { |
3664 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | 3720 | if (inv.Value.Type == type || type == -1) |
3665 | { | 3721 | { |
3666 | if (inv.Value.Type == type || type == -1) | 3722 | keys.Add(inv.Value.Name); |
3667 | { | ||
3668 | keys.Add(inv.Value.Name); | ||
3669 | } | ||
3670 | } | 3723 | } |
3671 | } | 3724 | } |
3725 | m_host.TaskInventory.LockItemsForRead(false); | ||
3672 | 3726 | ||
3673 | if (keys.Count == 0) | 3727 | if (keys.Count == 0) |
3674 | { | 3728 | { |
@@ -3705,20 +3759,19 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3705 | } | 3759 | } |
3706 | 3760 | ||
3707 | // move the first object found with this inventory name | 3761 | // move the first object found with this inventory name |
3708 | lock (m_host.TaskInventory) | 3762 | m_host.TaskInventory.LockItemsForRead(true); |
3763 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | ||
3709 | { | 3764 | { |
3710 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | 3765 | if (inv.Value.Name == inventory) |
3711 | { | 3766 | { |
3712 | if (inv.Value.Name == inventory) | 3767 | found = true; |
3713 | { | 3768 | objId = inv.Key; |
3714 | found = true; | 3769 | assetType = inv.Value.Type; |
3715 | objId = inv.Key; | 3770 | objName = inv.Value.Name; |
3716 | assetType = inv.Value.Type; | 3771 | break; |
3717 | objName = inv.Value.Name; | ||
3718 | break; | ||
3719 | } | ||
3720 | } | 3772 | } |
3721 | } | 3773 | } |
3774 | m_host.TaskInventory.LockItemsForRead(false); | ||
3722 | 3775 | ||
3723 | if (!found) | 3776 | if (!found) |
3724 | { | 3777 | { |
@@ -3763,24 +3816,26 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3763 | ScriptSleep(3000); | 3816 | ScriptSleep(3000); |
3764 | } | 3817 | } |
3765 | 3818 | ||
3819 | [DebuggerNonUserCode] | ||
3766 | public void llRemoveInventory(string name) | 3820 | public void llRemoveInventory(string name) |
3767 | { | 3821 | { |
3768 | m_host.AddScriptLPS(1); | 3822 | m_host.AddScriptLPS(1); |
3769 | 3823 | ||
3770 | lock (m_host.TaskInventory) | 3824 | m_host.TaskInventory.LockItemsForRead(true); |
3825 | foreach (TaskInventoryItem item in m_host.TaskInventory.Values) | ||
3771 | { | 3826 | { |
3772 | foreach (TaskInventoryItem item in m_host.TaskInventory.Values) | 3827 | if (item.Name == name) |
3773 | { | 3828 | { |
3774 | if (item.Name == name) | 3829 | if (item.ItemID == m_itemID) |
3775 | { | 3830 | throw new ScriptDeleteException(); |
3776 | if (item.ItemID == m_itemID) | 3831 | else |
3777 | throw new ScriptDeleteException(); | 3832 | m_host.Inventory.RemoveInventoryItem(item.ItemID); |
3778 | else | 3833 | |
3779 | m_host.Inventory.RemoveInventoryItem(item.ItemID); | 3834 | m_host.TaskInventory.LockItemsForRead(false); |
3780 | return; | 3835 | return; |
3781 | } | ||
3782 | } | 3836 | } |
3783 | } | 3837 | } |
3838 | m_host.TaskInventory.LockItemsForRead(false); | ||
3784 | } | 3839 | } |
3785 | 3840 | ||
3786 | public void llSetText(string text, LSL_Vector color, double alpha) | 3841 | public void llSetText(string text, LSL_Vector color, double alpha) |
@@ -3869,6 +3924,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3869 | { | 3924 | { |
3870 | m_host.AddScriptLPS(1); | 3925 | m_host.AddScriptLPS(1); |
3871 | 3926 | ||
3927 | //Clone is thread safe | ||
3872 | TaskInventoryDictionary itemDictionary = (TaskInventoryDictionary)m_host.TaskInventory.Clone(); | 3928 | TaskInventoryDictionary itemDictionary = (TaskInventoryDictionary)m_host.TaskInventory.Clone(); |
3873 | 3929 | ||
3874 | foreach (TaskInventoryItem item in itemDictionary.Values) | 3930 | foreach (TaskInventoryItem item in itemDictionary.Values) |
@@ -3959,17 +4015,16 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
3959 | UUID soundId = UUID.Zero; | 4015 | UUID soundId = UUID.Zero; |
3960 | if (!UUID.TryParse(impact_sound, out soundId)) | 4016 | if (!UUID.TryParse(impact_sound, out soundId)) |
3961 | { | 4017 | { |
3962 | lock (m_host.TaskInventory) | 4018 | m_host.TaskInventory.LockItemsForRead(true); |
4019 | foreach (TaskInventoryItem item in m_host.TaskInventory.Values) | ||
3963 | { | 4020 | { |
3964 | foreach (TaskInventoryItem item in m_host.TaskInventory.Values) | 4021 | if (item.Type == (int)AssetType.Sound && item.Name == impact_sound) |
3965 | { | 4022 | { |
3966 | if (item.Type == (int)AssetType.Sound && item.Name == impact_sound) | 4023 | soundId = item.AssetID; |
3967 | { | 4024 | break; |
3968 | soundId = item.AssetID; | ||
3969 | break; | ||
3970 | } | ||
3971 | } | 4025 | } |
3972 | } | 4026 | } |
4027 | m_host.TaskInventory.LockItemsForRead(false); | ||
3973 | } | 4028 | } |
3974 | m_host.CollisionSound = soundId; | 4029 | m_host.CollisionSound = soundId; |
3975 | m_host.CollisionSoundVolume = (float)impact_volume; | 4030 | m_host.CollisionSoundVolume = (float)impact_volume; |
@@ -4015,6 +4070,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
4015 | UUID partItemID; | 4070 | UUID partItemID; |
4016 | foreach (SceneObjectPart part in parts) | 4071 | foreach (SceneObjectPart part in parts) |
4017 | { | 4072 | { |
4073 | //Clone is thread safe | ||
4018 | TaskInventoryDictionary itemsDictionary = (TaskInventoryDictionary)part.TaskInventory.Clone(); | 4074 | TaskInventoryDictionary itemsDictionary = (TaskInventoryDictionary)part.TaskInventory.Clone(); |
4019 | 4075 | ||
4020 | foreach (TaskInventoryItem item in itemsDictionary.Values) | 4076 | foreach (TaskInventoryItem item in itemsDictionary.Values) |
@@ -4222,17 +4278,16 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
4222 | 4278 | ||
4223 | m_host.AddScriptLPS(1); | 4279 | m_host.AddScriptLPS(1); |
4224 | 4280 | ||
4225 | lock (m_host.TaskInventory) | 4281 | m_host.TaskInventory.LockItemsForRead(true); |
4282 | foreach (TaskInventoryItem item in m_host.TaskInventory.Values) | ||
4226 | { | 4283 | { |
4227 | foreach (TaskInventoryItem item in m_host.TaskInventory.Values) | 4284 | if (item.Type == 10 && item.ItemID == m_itemID) |
4228 | { | 4285 | { |
4229 | if (item.Type == 10 && item.ItemID == m_itemID) | 4286 | result = item.Name!=null?item.Name:String.Empty; |
4230 | { | 4287 | break; |
4231 | result = item.Name!=null?item.Name:String.Empty; | ||
4232 | break; | ||
4233 | } | ||
4234 | } | 4288 | } |
4235 | } | 4289 | } |
4290 | m_host.TaskInventory.LockItemsForRead(false); | ||
4236 | 4291 | ||
4237 | return result; | 4292 | return result; |
4238 | } | 4293 | } |
@@ -4490,23 +4545,24 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
4490 | { | 4545 | { |
4491 | m_host.AddScriptLPS(1); | 4546 | m_host.AddScriptLPS(1); |
4492 | 4547 | ||
4493 | lock (m_host.TaskInventory) | 4548 | m_host.TaskInventory.LockItemsForRead(true); |
4549 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | ||
4494 | { | 4550 | { |
4495 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | 4551 | if (inv.Value.Name == name) |
4496 | { | 4552 | { |
4497 | if (inv.Value.Name == name) | 4553 | if ((inv.Value.CurrentPermissions & (uint)(PermissionMask.Copy | PermissionMask.Transfer | PermissionMask.Modify)) == (uint)(PermissionMask.Copy | PermissionMask.Transfer | PermissionMask.Modify)) |
4498 | { | 4554 | { |
4499 | if ((inv.Value.CurrentPermissions & (uint)(PermissionMask.Copy | PermissionMask.Transfer | PermissionMask.Modify)) == (uint)(PermissionMask.Copy | PermissionMask.Transfer | PermissionMask.Modify)) | 4555 | m_host.TaskInventory.LockItemsForRead(false); |
4500 | { | 4556 | return inv.Value.AssetID.ToString(); |
4501 | return inv.Value.AssetID.ToString(); | 4557 | } |
4502 | } | 4558 | else |
4503 | else | 4559 | { |
4504 | { | 4560 | m_host.TaskInventory.LockItemsForRead(false); |
4505 | return UUID.Zero.ToString(); | 4561 | return UUID.Zero.ToString(); |
4506 | } | ||
4507 | } | 4562 | } |
4508 | } | 4563 | } |
4509 | } | 4564 | } |
4565 | m_host.TaskInventory.LockItemsForRead(false); | ||
4510 | 4566 | ||
4511 | return UUID.Zero.ToString(); | 4567 | return UUID.Zero.ToString(); |
4512 | } | 4568 | } |
@@ -6001,14 +6057,16 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
6001 | 6057 | ||
6002 | protected UUID GetTaskInventoryItem(string name) | 6058 | protected UUID GetTaskInventoryItem(string name) |
6003 | { | 6059 | { |
6004 | lock (m_host.TaskInventory) | 6060 | m_host.TaskInventory.LockItemsForRead(true); |
6061 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | ||
6005 | { | 6062 | { |
6006 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | 6063 | if (inv.Value.Name == name) |
6007 | { | 6064 | { |
6008 | if (inv.Value.Name == name) | 6065 | m_host.TaskInventory.LockItemsForRead(false); |
6009 | return inv.Key; | 6066 | return inv.Key; |
6010 | } | 6067 | } |
6011 | } | 6068 | } |
6069 | m_host.TaskInventory.LockItemsForRead(false); | ||
6012 | 6070 | ||
6013 | return UUID.Zero; | 6071 | return UUID.Zero; |
6014 | } | 6072 | } |
@@ -6319,22 +6377,21 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
6319 | } | 6377 | } |
6320 | 6378 | ||
6321 | // copy the first script found with this inventory name | 6379 | // copy the first script found with this inventory name |
6322 | lock (m_host.TaskInventory) | 6380 | m_host.TaskInventory.LockItemsForRead(true); |
6381 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | ||
6323 | { | 6382 | { |
6324 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | 6383 | if (inv.Value.Name == name) |
6325 | { | 6384 | { |
6326 | if (inv.Value.Name == name) | 6385 | // make sure the object is a script |
6386 | if (10 == inv.Value.Type) | ||
6327 | { | 6387 | { |
6328 | // make sure the object is a script | 6388 | found = true; |
6329 | if (10 == inv.Value.Type) | 6389 | srcId = inv.Key; |
6330 | { | 6390 | break; |
6331 | found = true; | ||
6332 | srcId = inv.Key; | ||
6333 | break; | ||
6334 | } | ||
6335 | } | 6391 | } |
6336 | } | 6392 | } |
6337 | } | 6393 | } |
6394 | m_host.TaskInventory.LockItemsForRead(false); | ||
6338 | 6395 | ||
6339 | if (!found) | 6396 | if (!found) |
6340 | { | 6397 | { |
@@ -8137,28 +8194,28 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8137 | { | 8194 | { |
8138 | m_host.AddScriptLPS(1); | 8195 | m_host.AddScriptLPS(1); |
8139 | 8196 | ||
8140 | lock (m_host.TaskInventory) | 8197 | m_host.TaskInventory.LockItemsForRead(true); |
8198 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | ||
8141 | { | 8199 | { |
8142 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | 8200 | if (inv.Value.Name == item) |
8143 | { | 8201 | { |
8144 | if (inv.Value.Name == item) | 8202 | m_host.TaskInventory.LockItemsForRead(false); |
8203 | switch (mask) | ||
8145 | { | 8204 | { |
8146 | switch (mask) | 8205 | case 0: |
8147 | { | 8206 | return (int)inv.Value.BasePermissions; |
8148 | case 0: | 8207 | case 1: |
8149 | return (int)inv.Value.BasePermissions; | 8208 | return (int)inv.Value.CurrentPermissions; |
8150 | case 1: | 8209 | case 2: |
8151 | return (int)inv.Value.CurrentPermissions; | 8210 | return (int)inv.Value.GroupPermissions; |
8152 | case 2: | 8211 | case 3: |
8153 | return (int)inv.Value.GroupPermissions; | 8212 | return (int)inv.Value.EveryonePermissions; |
8154 | case 3: | 8213 | case 4: |
8155 | return (int)inv.Value.EveryonePermissions; | 8214 | return (int)inv.Value.NextPermissions; |
8156 | case 4: | ||
8157 | return (int)inv.Value.NextPermissions; | ||
8158 | } | ||
8159 | } | 8215 | } |
8160 | } | 8216 | } |
8161 | } | 8217 | } |
8218 | m_host.TaskInventory.LockItemsForRead(false); | ||
8162 | 8219 | ||
8163 | return -1; | 8220 | return -1; |
8164 | } | 8221 | } |
@@ -8173,16 +8230,16 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8173 | { | 8230 | { |
8174 | m_host.AddScriptLPS(1); | 8231 | m_host.AddScriptLPS(1); |
8175 | 8232 | ||
8176 | lock (m_host.TaskInventory) | 8233 | m_host.TaskInventory.LockItemsForRead(true); |
8234 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | ||
8177 | { | 8235 | { |
8178 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | 8236 | if (inv.Value.Name == item) |
8179 | { | 8237 | { |
8180 | if (inv.Value.Name == item) | 8238 | m_host.TaskInventory.LockItemsForRead(false); |
8181 | { | 8239 | return inv.Value.CreatorID.ToString(); |
8182 | return inv.Value.CreatorID.ToString(); | ||
8183 | } | ||
8184 | } | 8240 | } |
8185 | } | 8241 | } |
8242 | m_host.TaskInventory.LockItemsForRead(false); | ||
8186 | 8243 | ||
8187 | llSay(0, "No item name '" + item + "'"); | 8244 | llSay(0, "No item name '" + item + "'"); |
8188 | 8245 | ||
@@ -8706,16 +8763,16 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8706 | { | 8763 | { |
8707 | m_host.AddScriptLPS(1); | 8764 | m_host.AddScriptLPS(1); |
8708 | 8765 | ||
8709 | lock (m_host.TaskInventory) | 8766 | m_host.TaskInventory.LockItemsForRead(true); |
8767 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | ||
8710 | { | 8768 | { |
8711 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | 8769 | if (inv.Value.Name == name) |
8712 | { | 8770 | { |
8713 | if (inv.Value.Name == name) | 8771 | m_host.TaskInventory.LockItemsForRead(false); |
8714 | { | 8772 | return inv.Value.Type; |
8715 | return inv.Value.Type; | ||
8716 | } | ||
8717 | } | 8773 | } |
8718 | } | 8774 | } |
8775 | m_host.TaskInventory.LockItemsForRead(false); | ||
8719 | 8776 | ||
8720 | return -1; | 8777 | return -1; |
8721 | } | 8778 | } |
@@ -8746,17 +8803,20 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8746 | if (invItemID == UUID.Zero) | 8803 | if (invItemID == UUID.Zero) |
8747 | return new LSL_Vector(); | 8804 | return new LSL_Vector(); |
8748 | 8805 | ||
8749 | lock (m_host.TaskInventory) | 8806 | m_host.TaskInventory.LockItemsForRead(true); |
8807 | if (m_host.TaskInventory[invItemID].PermsGranter == UUID.Zero) | ||
8750 | { | 8808 | { |
8751 | if (m_host.TaskInventory[invItemID].PermsGranter == UUID.Zero) | 8809 | m_host.TaskInventory.LockItemsForRead(false); |
8752 | return new LSL_Vector(); | 8810 | return new LSL_Vector(); |
8811 | } | ||
8753 | 8812 | ||
8754 | if ((m_host.TaskInventory[invItemID].PermsMask & ScriptBaseClass.PERMISSION_TRACK_CAMERA) == 0) | 8813 | if ((m_host.TaskInventory[invItemID].PermsMask & ScriptBaseClass.PERMISSION_TRACK_CAMERA) == 0) |
8755 | { | 8814 | { |
8756 | ShoutError("No permissions to track the camera"); | 8815 | ShoutError("No permissions to track the camera"); |
8757 | return new LSL_Vector(); | 8816 | m_host.TaskInventory.LockItemsForRead(false); |
8758 | } | 8817 | return new LSL_Vector(); |
8759 | } | 8818 | } |
8819 | m_host.TaskInventory.LockItemsForRead(false); | ||
8760 | 8820 | ||
8761 | ScenePresence presence = World.GetScenePresence(m_host.OwnerID); | 8821 | ScenePresence presence = World.GetScenePresence(m_host.OwnerID); |
8762 | if (presence != null) | 8822 | if (presence != null) |
@@ -8774,17 +8834,19 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8774 | if (invItemID == UUID.Zero) | 8834 | if (invItemID == UUID.Zero) |
8775 | return new LSL_Rotation(); | 8835 | return new LSL_Rotation(); |
8776 | 8836 | ||
8777 | lock (m_host.TaskInventory) | 8837 | m_host.TaskInventory.LockItemsForRead(true); |
8838 | if (m_host.TaskInventory[invItemID].PermsGranter == UUID.Zero) | ||
8778 | { | 8839 | { |
8779 | if (m_host.TaskInventory[invItemID].PermsGranter == UUID.Zero) | 8840 | m_host.TaskInventory.LockItemsForRead(false); |
8780 | return new LSL_Rotation(); | 8841 | return new LSL_Rotation(); |
8781 | |||
8782 | if ((m_host.TaskInventory[invItemID].PermsMask & ScriptBaseClass.PERMISSION_TRACK_CAMERA) == 0) | ||
8783 | { | ||
8784 | ShoutError("No permissions to track the camera"); | ||
8785 | return new LSL_Rotation(); | ||
8786 | } | ||
8787 | } | 8842 | } |
8843 | if ((m_host.TaskInventory[invItemID].PermsMask & ScriptBaseClass.PERMISSION_TRACK_CAMERA) == 0) | ||
8844 | { | ||
8845 | ShoutError("No permissions to track the camera"); | ||
8846 | m_host.TaskInventory.LockItemsForRead(false); | ||
8847 | return new LSL_Rotation(); | ||
8848 | } | ||
8849 | m_host.TaskInventory.LockItemsForRead(false); | ||
8788 | 8850 | ||
8789 | ScenePresence presence = World.GetScenePresence(m_host.OwnerID); | 8851 | ScenePresence presence = World.GetScenePresence(m_host.OwnerID); |
8790 | if (presence != null) | 8852 | if (presence != null) |
@@ -8934,14 +8996,21 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8934 | if (objectID == UUID.Zero) return; | 8996 | if (objectID == UUID.Zero) return; |
8935 | 8997 | ||
8936 | UUID agentID; | 8998 | UUID agentID; |
8937 | lock (m_host.TaskInventory) | 8999 | m_host.TaskInventory.LockItemsForRead(true); |
8938 | { | 9000 | // we need the permission first, to know which avatar we want to set the camera for |
8939 | // we need the permission first, to know which avatar we want to set the camera for | 9001 | agentID = m_host.TaskInventory[invItemID].PermsGranter; |
8940 | agentID = m_host.TaskInventory[invItemID].PermsGranter; | ||
8941 | 9002 | ||
8942 | if (agentID == UUID.Zero) return; | 9003 | if (agentID == UUID.Zero) |
8943 | if ((m_host.TaskInventory[invItemID].PermsMask & ScriptBaseClass.PERMISSION_CONTROL_CAMERA) == 0) return; | 9004 | { |
9005 | m_host.TaskInventory.LockItemsForRead(false); | ||
9006 | return; | ||
8944 | } | 9007 | } |
9008 | if ((m_host.TaskInventory[invItemID].PermsMask & ScriptBaseClass.PERMISSION_CONTROL_CAMERA) == 0) | ||
9009 | { | ||
9010 | m_host.TaskInventory.LockItemsForRead(false); | ||
9011 | return; | ||
9012 | } | ||
9013 | m_host.TaskInventory.LockItemsForRead(false); | ||
8945 | 9014 | ||
8946 | ScenePresence presence = World.GetScenePresence(agentID); | 9015 | ScenePresence presence = World.GetScenePresence(agentID); |
8947 | 9016 | ||
@@ -8991,12 +9060,19 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
8991 | 9060 | ||
8992 | // we need the permission first, to know which avatar we want to clear the camera for | 9061 | // we need the permission first, to know which avatar we want to clear the camera for |
8993 | UUID agentID; | 9062 | UUID agentID; |
8994 | lock (m_host.TaskInventory) | 9063 | m_host.TaskInventory.LockItemsForRead(true); |
9064 | agentID = m_host.TaskInventory[invItemID].PermsGranter; | ||
9065 | if (agentID == UUID.Zero) | ||
9066 | { | ||
9067 | m_host.TaskInventory.LockItemsForRead(false); | ||
9068 | return; | ||
9069 | } | ||
9070 | if ((m_host.TaskInventory[invItemID].PermsMask & ScriptBaseClass.PERMISSION_CONTROL_CAMERA) == 0) | ||
8995 | { | 9071 | { |
8996 | agentID = m_host.TaskInventory[invItemID].PermsGranter; | 9072 | m_host.TaskInventory.LockItemsForRead(false); |
8997 | if (agentID == UUID.Zero) return; | 9073 | return; |
8998 | if ((m_host.TaskInventory[invItemID].PermsMask & ScriptBaseClass.PERMISSION_CONTROL_CAMERA) == 0) return; | ||
8999 | } | 9074 | } |
9075 | m_host.TaskInventory.LockItemsForRead(false); | ||
9000 | 9076 | ||
9001 | ScenePresence presence = World.GetScenePresence(agentID); | 9077 | ScenePresence presence = World.GetScenePresence(agentID); |
9002 | 9078 | ||
@@ -9453,15 +9529,19 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
9453 | 9529 | ||
9454 | internal UUID ScriptByName(string name) | 9530 | internal UUID ScriptByName(string name) |
9455 | { | 9531 | { |
9456 | lock (m_host.TaskInventory) | 9532 | m_host.TaskInventory.LockItemsForRead(true); |
9533 | |||
9534 | foreach (TaskInventoryItem item in m_host.TaskInventory.Values) | ||
9457 | { | 9535 | { |
9458 | foreach (TaskInventoryItem item in m_host.TaskInventory.Values) | 9536 | if (item.Type == 10 && item.Name == name) |
9459 | { | 9537 | { |
9460 | if (item.Type == 10 && item.Name == name) | 9538 | m_host.TaskInventory.LockItemsForRead(false); |
9461 | return item.ItemID; | 9539 | return item.ItemID; |
9462 | } | 9540 | } |
9463 | } | 9541 | } |
9464 | 9542 | ||
9543 | m_host.TaskInventory.LockItemsForRead(false); | ||
9544 | |||
9465 | return UUID.Zero; | 9545 | return UUID.Zero; |
9466 | } | 9546 | } |
9467 | 9547 | ||
@@ -9502,6 +9582,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
9502 | { | 9582 | { |
9503 | m_host.AddScriptLPS(1); | 9583 | m_host.AddScriptLPS(1); |
9504 | 9584 | ||
9585 | //Clone is thread safe | ||
9505 | TaskInventoryDictionary itemsDictionary = (TaskInventoryDictionary)m_host.TaskInventory.Clone(); | 9586 | TaskInventoryDictionary itemsDictionary = (TaskInventoryDictionary)m_host.TaskInventory.Clone(); |
9506 | 9587 | ||
9507 | UUID assetID = UUID.Zero; | 9588 | UUID assetID = UUID.Zero; |
@@ -9564,6 +9645,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
9564 | { | 9645 | { |
9565 | m_host.AddScriptLPS(1); | 9646 | m_host.AddScriptLPS(1); |
9566 | 9647 | ||
9648 | //Clone is thread safe | ||
9567 | TaskInventoryDictionary itemsDictionary = (TaskInventoryDictionary)m_host.TaskInventory.Clone(); | 9649 | TaskInventoryDictionary itemsDictionary = (TaskInventoryDictionary)m_host.TaskInventory.Clone(); |
9568 | 9650 | ||
9569 | UUID assetID = UUID.Zero; | 9651 | UUID assetID = UUID.Zero; |
diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/OSSL_Api.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/OSSL_Api.cs index e72fa70..10165d3 100644 --- a/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/OSSL_Api.cs +++ b/OpenSim/Region/ScriptEngine/Shared/Api/Implementation/OSSL_Api.cs | |||
@@ -728,18 +728,17 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
728 | if (target != null) | 728 | if (target != null) |
729 | { | 729 | { |
730 | UUID animID=UUID.Zero; | 730 | UUID animID=UUID.Zero; |
731 | lock (m_host.TaskInventory) | 731 | m_host.TaskInventory.LockItemsForRead(true); |
732 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | ||
732 | { | 733 | { |
733 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | 734 | if (inv.Value.Name == animation) |
734 | { | 735 | { |
735 | if (inv.Value.Name == animation) | 736 | if (inv.Value.Type == (int)AssetType.Animation) |
736 | { | 737 | animID = inv.Value.AssetID; |
737 | if (inv.Value.Type == (int)AssetType.Animation) | 738 | continue; |
738 | animID = inv.Value.AssetID; | ||
739 | continue; | ||
740 | } | ||
741 | } | 739 | } |
742 | } | 740 | } |
741 | m_host.TaskInventory.LockItemsForRead(false); | ||
743 | if (animID == UUID.Zero) | 742 | if (animID == UUID.Zero) |
744 | target.Animator.AddAnimation(animation, m_host.UUID); | 743 | target.Animator.AddAnimation(animation, m_host.UUID); |
745 | else | 744 | else |
@@ -761,18 +760,17 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
761 | if (target != null) | 760 | if (target != null) |
762 | { | 761 | { |
763 | UUID animID=UUID.Zero; | 762 | UUID animID=UUID.Zero; |
764 | lock (m_host.TaskInventory) | 763 | m_host.TaskInventory.LockItemsForRead(true); |
764 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | ||
765 | { | 765 | { |
766 | foreach (KeyValuePair<UUID, TaskInventoryItem> inv in m_host.TaskInventory) | 766 | if (inv.Value.Name == animation) |
767 | { | 767 | { |
768 | if (inv.Value.Name == animation) | 768 | if (inv.Value.Type == (int)AssetType.Animation) |
769 | { | 769 | animID = inv.Value.AssetID; |
770 | if (inv.Value.Type == (int)AssetType.Animation) | 770 | continue; |
771 | animID = inv.Value.AssetID; | ||
772 | continue; | ||
773 | } | ||
774 | } | 771 | } |
775 | } | 772 | } |
773 | m_host.TaskInventory.LockItemsForRead(false); | ||
776 | 774 | ||
777 | if (animID == UUID.Zero) | 775 | if (animID == UUID.Zero) |
778 | target.Animator.RemoveAnimation(animation); | 776 | target.Animator.RemoveAnimation(animation); |
@@ -1541,6 +1539,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
1541 | 1539 | ||
1542 | if (!UUID.TryParse(name, out assetID)) | 1540 | if (!UUID.TryParse(name, out assetID)) |
1543 | { | 1541 | { |
1542 | m_host.TaskInventory.LockItemsForRead(true); | ||
1544 | foreach (TaskInventoryItem item in m_host.TaskInventory.Values) | 1543 | foreach (TaskInventoryItem item in m_host.TaskInventory.Values) |
1545 | { | 1544 | { |
1546 | if (item.Type == 7 && item.Name == name) | 1545 | if (item.Type == 7 && item.Name == name) |
@@ -1548,6 +1547,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
1548 | assetID = item.AssetID; | 1547 | assetID = item.AssetID; |
1549 | } | 1548 | } |
1550 | } | 1549 | } |
1550 | m_host.TaskInventory.LockItemsForRead(false); | ||
1551 | } | 1551 | } |
1552 | 1552 | ||
1553 | if (assetID == UUID.Zero) | 1553 | if (assetID == UUID.Zero) |
@@ -1594,6 +1594,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
1594 | 1594 | ||
1595 | if (!UUID.TryParse(name, out assetID)) | 1595 | if (!UUID.TryParse(name, out assetID)) |
1596 | { | 1596 | { |
1597 | m_host.TaskInventory.LockItemsForRead(true); | ||
1597 | foreach (TaskInventoryItem item in m_host.TaskInventory.Values) | 1598 | foreach (TaskInventoryItem item in m_host.TaskInventory.Values) |
1598 | { | 1599 | { |
1599 | if (item.Type == 7 && item.Name == name) | 1600 | if (item.Type == 7 && item.Name == name) |
@@ -1601,6 +1602,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
1601 | assetID = item.AssetID; | 1602 | assetID = item.AssetID; |
1602 | } | 1603 | } |
1603 | } | 1604 | } |
1605 | m_host.TaskInventory.LockItemsForRead(false); | ||
1604 | } | 1606 | } |
1605 | 1607 | ||
1606 | if (assetID == UUID.Zero) | 1608 | if (assetID == UUID.Zero) |
@@ -1651,6 +1653,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
1651 | 1653 | ||
1652 | if (!UUID.TryParse(name, out assetID)) | 1654 | if (!UUID.TryParse(name, out assetID)) |
1653 | { | 1655 | { |
1656 | m_host.TaskInventory.LockItemsForRead(true); | ||
1654 | foreach (TaskInventoryItem item in m_host.TaskInventory.Values) | 1657 | foreach (TaskInventoryItem item in m_host.TaskInventory.Values) |
1655 | { | 1658 | { |
1656 | if (item.Type == 7 && item.Name == name) | 1659 | if (item.Type == 7 && item.Name == name) |
@@ -1658,6 +1661,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Api | |||
1658 | assetID = item.AssetID; | 1661 | assetID = item.AssetID; |
1659 | } | 1662 | } |
1660 | } | 1663 | } |
1664 | m_host.TaskInventory.LockItemsForRead(false); | ||
1661 | } | 1665 | } |
1662 | 1666 | ||
1663 | if (assetID == UUID.Zero) | 1667 | if (assetID == UUID.Zero) |
diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Runtime/Executor.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Runtime/Executor.cs index 7f67599..15e0408 100644 --- a/OpenSim/Region/ScriptEngine/Shared/Api/Runtime/Executor.cs +++ b/OpenSim/Region/ScriptEngine/Shared/Api/Runtime/Executor.cs | |||
@@ -27,6 +27,7 @@ | |||
27 | 27 | ||
28 | using System; | 28 | using System; |
29 | using System.Collections.Generic; | 29 | using System.Collections.Generic; |
30 | using System.Diagnostics; //for [DebuggerNonUserCode] | ||
30 | using System.Reflection; | 31 | using System.Reflection; |
31 | using System.Runtime.Remoting.Lifetime; | 32 | using System.Runtime.Remoting.Lifetime; |
32 | using OpenSim.Region.ScriptEngine.Shared; | 33 | using OpenSim.Region.ScriptEngine.Shared; |
@@ -131,6 +132,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.ScriptBase | |||
131 | return (eventFlags); | 132 | return (eventFlags); |
132 | } | 133 | } |
133 | 134 | ||
135 | [DebuggerNonUserCode] | ||
134 | public void ExecuteEvent(string state, string FunctionName, object[] args) | 136 | public void ExecuteEvent(string state, string FunctionName, object[] args) |
135 | { | 137 | { |
136 | // IMPORTANT: Types and MemberInfo-derived objects require a LOT of memory. | 138 | // IMPORTANT: Types and MemberInfo-derived objects require a LOT of memory. |
diff --git a/OpenSim/Region/ScriptEngine/Shared/Api/Runtime/ScriptBase.cs b/OpenSim/Region/ScriptEngine/Shared/Api/Runtime/ScriptBase.cs index 121159c..a44abb0 100644 --- a/OpenSim/Region/ScriptEngine/Shared/Api/Runtime/ScriptBase.cs +++ b/OpenSim/Region/ScriptEngine/Shared/Api/Runtime/ScriptBase.cs | |||
@@ -33,6 +33,7 @@ using System.Threading; | |||
33 | using System.Reflection; | 33 | using System.Reflection; |
34 | using System.Collections; | 34 | using System.Collections; |
35 | using System.Collections.Generic; | 35 | using System.Collections.Generic; |
36 | using System.Diagnostics; //for [DebuggerNonUserCode] | ||
36 | using OpenSim.Region.ScriptEngine.Interfaces; | 37 | using OpenSim.Region.ScriptEngine.Interfaces; |
37 | using OpenSim.Region.ScriptEngine.Shared; | 38 | using OpenSim.Region.ScriptEngine.Shared; |
38 | using OpenSim.Region.ScriptEngine.Shared.Api.Runtime; | 39 | using OpenSim.Region.ScriptEngine.Shared.Api.Runtime; |
@@ -90,6 +91,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.ScriptBase | |||
90 | return (int)m_Executor.GetStateEventFlags(state); | 91 | return (int)m_Executor.GetStateEventFlags(state); |
91 | } | 92 | } |
92 | 93 | ||
94 | [DebuggerNonUserCode] | ||
93 | public void ExecuteEvent(string state, string FunctionName, object[] args) | 95 | public void ExecuteEvent(string state, string FunctionName, object[] args) |
94 | { | 96 | { |
95 | m_Executor.ExecuteEvent(state, FunctionName, args); | 97 | m_Executor.ExecuteEvent(state, FunctionName, args); |
diff --git a/OpenSim/Region/ScriptEngine/Shared/Instance/ScriptInstance.cs b/OpenSim/Region/ScriptEngine/Shared/Instance/ScriptInstance.cs index 5c5d57e..8333a27 100644 --- a/OpenSim/Region/ScriptEngine/Shared/Instance/ScriptInstance.cs +++ b/OpenSim/Region/ScriptEngine/Shared/Instance/ScriptInstance.cs | |||
@@ -27,6 +27,7 @@ | |||
27 | 27 | ||
28 | using System; | 28 | using System; |
29 | using System.IO; | 29 | using System.IO; |
30 | using System.Diagnostics; //for [DebuggerNonUserCode] | ||
30 | using System.Runtime.Remoting; | 31 | using System.Runtime.Remoting; |
31 | using System.Runtime.Remoting.Lifetime; | 32 | using System.Runtime.Remoting.Lifetime; |
32 | using System.Threading; | 33 | using System.Threading; |
@@ -237,13 +238,12 @@ namespace OpenSim.Region.ScriptEngine.Shared.Instance | |||
237 | 238 | ||
238 | if (part != null) | 239 | if (part != null) |
239 | { | 240 | { |
240 | lock (part.TaskInventory) | 241 | part.TaskInventory.LockItemsForRead(true); |
242 | if (part.TaskInventory.ContainsKey(m_ItemID)) | ||
241 | { | 243 | { |
242 | if (part.TaskInventory.ContainsKey(m_ItemID)) | 244 | m_thisScriptTask = part.TaskInventory[m_ItemID]; |
243 | { | ||
244 | m_thisScriptTask = part.TaskInventory[m_ItemID]; | ||
245 | } | ||
246 | } | 245 | } |
246 | part.TaskInventory.LockItemsForRead(false); | ||
247 | } | 247 | } |
248 | 248 | ||
249 | ApiManager am = new ApiManager(); | 249 | ApiManager am = new ApiManager(); |
@@ -428,14 +428,15 @@ namespace OpenSim.Region.ScriptEngine.Shared.Instance | |||
428 | { | 428 | { |
429 | int permsMask; | 429 | int permsMask; |
430 | UUID permsGranter; | 430 | UUID permsGranter; |
431 | lock (part.TaskInventory) | 431 | part.TaskInventory.LockItemsForRead(true); |
432 | if (!part.TaskInventory.ContainsKey(m_ItemID)) | ||
432 | { | 433 | { |
433 | if (!part.TaskInventory.ContainsKey(m_ItemID)) | 434 | part.TaskInventory.LockItemsForRead(false); |
434 | return; | 435 | return; |
435 | |||
436 | permsGranter = part.TaskInventory[m_ItemID].PermsGranter; | ||
437 | permsMask = part.TaskInventory[m_ItemID].PermsMask; | ||
438 | } | 436 | } |
437 | permsGranter = part.TaskInventory[m_ItemID].PermsGranter; | ||
438 | permsMask = part.TaskInventory[m_ItemID].PermsMask; | ||
439 | part.TaskInventory.LockItemsForRead(false); | ||
439 | 440 | ||
440 | if ((permsMask & ScriptBaseClass.PERMISSION_TAKE_CONTROLS) != 0) | 441 | if ((permsMask & ScriptBaseClass.PERMISSION_TAKE_CONTROLS) != 0) |
441 | { | 442 | { |
@@ -544,6 +545,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Instance | |||
544 | return true; | 545 | return true; |
545 | } | 546 | } |
546 | 547 | ||
548 | [DebuggerNonUserCode] //Prevents the debugger from farting in this function | ||
547 | public void SetState(string state) | 549 | public void SetState(string state) |
548 | { | 550 | { |
549 | if (state == State) | 551 | if (state == State) |
@@ -555,7 +557,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Instance | |||
555 | new DetectParams[0])); | 557 | new DetectParams[0])); |
556 | PostEvent(new EventParams("state_entry", new Object[0], | 558 | PostEvent(new EventParams("state_entry", new Object[0], |
557 | new DetectParams[0])); | 559 | new DetectParams[0])); |
558 | 560 | ||
559 | throw new EventAbortException(); | 561 | throw new EventAbortException(); |
560 | } | 562 | } |
561 | 563 | ||
@@ -638,154 +640,158 @@ namespace OpenSim.Region.ScriptEngine.Shared.Instance | |||
638 | /// <returns></returns> | 640 | /// <returns></returns> |
639 | public object EventProcessor() | 641 | public object EventProcessor() |
640 | { | 642 | { |
643 | |||
644 | EventParams data = null; | ||
645 | |||
646 | lock (m_EventQueue) | ||
647 | { | ||
641 | lock (m_Script) | 648 | lock (m_Script) |
642 | { | 649 | { |
643 | EventParams data = null; | 650 | data = (EventParams) m_EventQueue.Dequeue(); |
644 | 651 | if (data == null) // Shouldn't happen | |
645 | lock (m_EventQueue) | ||
646 | { | 652 | { |
647 | data = (EventParams) m_EventQueue.Dequeue(); | 653 | if ((m_EventQueue.Count > 0) && m_RunEvents && (!m_ShuttingDown)) |
648 | if (data == null) // Shouldn't happen | ||
649 | { | 654 | { |
650 | if ((m_EventQueue.Count > 0) && m_RunEvents && (!m_ShuttingDown)) | 655 | m_CurrentResult = m_Engine.QueueEventHandler(this); |
651 | { | ||
652 | m_CurrentResult = m_Engine.QueueEventHandler(this); | ||
653 | } | ||
654 | else | ||
655 | { | ||
656 | m_CurrentResult = null; | ||
657 | } | ||
658 | return 0; | ||
659 | } | 656 | } |
660 | 657 | else | |
661 | if (data.EventName == "timer") | ||
662 | m_TimerQueued = false; | ||
663 | if (data.EventName == "control") | ||
664 | { | 658 | { |
665 | if (m_ControlEventsInQueue > 0) | 659 | m_CurrentResult = null; |
666 | m_ControlEventsInQueue--; | ||
667 | } | 660 | } |
668 | if (data.EventName == "collision") | 661 | return 0; |
669 | m_CollisionInQueue = false; | ||
670 | } | 662 | } |
671 | |||
672 | //m_log.DebugFormat("[XENGINE]: Processing event {0} for {1}", data.EventName, this); | ||
673 | 663 | ||
674 | m_DetectParams = data.DetectParams; | 664 | if (data.EventName == "timer") |
675 | 665 | m_TimerQueued = false; | |
676 | if (data.EventName == "state") // Hardcoded state change | 666 | if (data.EventName == "control") |
677 | { | 667 | { |
678 | // m_log.DebugFormat("[Script] Script {0}.{1} state set to {2}", | 668 | if (m_ControlEventsInQueue > 0) |
679 | // m_PrimName, m_ScriptName, data.Params[0].ToString()); | 669 | m_ControlEventsInQueue--; |
680 | m_State=data.Params[0].ToString(); | 670 | } |
681 | AsyncCommandManager.RemoveScript(m_Engine, | 671 | if (data.EventName == "collision") |
682 | m_LocalID, m_ItemID); | 672 | m_CollisionInQueue = false; |
673 | } | ||
674 | } | ||
675 | lock(m_Script) | ||
676 | { | ||
677 | |||
678 | //m_log.DebugFormat("[XENGINE]: Processing event {0} for {1}", data.EventName, this); | ||
683 | 679 | ||
684 | SceneObjectPart part = m_Engine.World.GetSceneObjectPart( | 680 | m_DetectParams = data.DetectParams; |
685 | m_LocalID); | 681 | |
686 | if (part != null) | 682 | if (data.EventName == "state") // Hardcoded state change |
687 | { | 683 | { |
688 | part.SetScriptEvents(m_ItemID, | 684 | // m_log.DebugFormat("[Script] Script {0}.{1} state set to {2}", |
689 | (int)m_Script.GetStateEventFlags(State)); | 685 | // m_PrimName, m_ScriptName, data.Params[0].ToString()); |
690 | } | 686 | m_State=data.Params[0].ToString(); |
687 | AsyncCommandManager.RemoveScript(m_Engine, | ||
688 | m_LocalID, m_ItemID); | ||
689 | |||
690 | SceneObjectPart part = m_Engine.World.GetSceneObjectPart( | ||
691 | m_LocalID); | ||
692 | if (part != null) | ||
693 | { | ||
694 | part.SetScriptEvents(m_ItemID, | ||
695 | (int)m_Script.GetStateEventFlags(State)); | ||
691 | } | 696 | } |
692 | else | 697 | } |
698 | else | ||
699 | { | ||
700 | if (m_Engine.World.PipeEventsForScript(m_LocalID) || | ||
701 | data.EventName == "control") // Don't freeze avies! | ||
693 | { | 702 | { |
694 | if (m_Engine.World.PipeEventsForScript(m_LocalID) || | 703 | SceneObjectPart part = m_Engine.World.GetSceneObjectPart( |
695 | data.EventName == "control") // Don't freeze avies! | 704 | m_LocalID); |
696 | { | 705 | // m_log.DebugFormat("[Script] Delivered event {2} in state {3} to {0}.{1}", |
697 | SceneObjectPart part = m_Engine.World.GetSceneObjectPart( | 706 | // m_PrimName, m_ScriptName, data.EventName, m_State); |
698 | m_LocalID); | ||
699 | // m_log.DebugFormat("[Script] Delivered event {2} in state {3} to {0}.{1}", | ||
700 | // m_PrimName, m_ScriptName, data.EventName, m_State); | ||
701 | 707 | ||
702 | try | 708 | try |
703 | { | 709 | { |
704 | m_CurrentEvent = data.EventName; | 710 | m_CurrentEvent = data.EventName; |
705 | m_EventStart = DateTime.Now; | 711 | m_EventStart = DateTime.Now; |
706 | m_InEvent = true; | 712 | m_InEvent = true; |
707 | 713 | ||
708 | m_Script.ExecuteEvent(State, data.EventName, data.Params); | 714 | m_Script.ExecuteEvent(State, data.EventName, data.Params); |
709 | 715 | ||
710 | m_InEvent = false; | 716 | m_InEvent = false; |
711 | m_CurrentEvent = String.Empty; | 717 | m_CurrentEvent = String.Empty; |
712 | 718 | ||
713 | if (m_SaveState) | 719 | if (m_SaveState) |
714 | { | 720 | { |
715 | // This will be the very first event we deliver | 721 | // This will be the very first event we deliver |
716 | // (state_entry) in default state | 722 | // (state_entry) in default state |
717 | // | 723 | // |
718 | 724 | ||
719 | SaveState(m_Assembly); | 725 | SaveState(m_Assembly); |
720 | 726 | ||
721 | m_SaveState = false; | 727 | m_SaveState = false; |
722 | } | ||
723 | } | 728 | } |
724 | catch (Exception e) | 729 | } |
725 | { | 730 | catch (Exception e) |
726 | // m_log.DebugFormat("[SCRIPT] Exception: {0}", e.Message); | 731 | { |
727 | m_InEvent = false; | 732 | // m_log.DebugFormat("[SCRIPT] Exception: {0}", e.Message); |
728 | m_CurrentEvent = String.Empty; | 733 | m_InEvent = false; |
734 | m_CurrentEvent = String.Empty; | ||
729 | 735 | ||
730 | if ((!(e is TargetInvocationException) || (!(e.InnerException is SelfDeleteException) && !(e.InnerException is ScriptDeleteException))) && !(e is ThreadAbortException)) | 736 | if ((!(e is TargetInvocationException) || (!(e.InnerException is SelfDeleteException) && !(e.InnerException is ScriptDeleteException))) && !(e is ThreadAbortException)) |
731 | { | 737 | { |
732 | try | 738 | try |
733 | { | ||
734 | // DISPLAY ERROR INWORLD | ||
735 | string text = FormatException(e); | ||
736 | |||
737 | if (text.Length > 1000) | ||
738 | text = text.Substring(0, 1000); | ||
739 | m_Engine.World.SimChat(Utils.StringToBytes(text), | ||
740 | ChatTypeEnum.DebugChannel, 2147483647, | ||
741 | part.AbsolutePosition, | ||
742 | part.Name, part.UUID, false); | ||
743 | } | ||
744 | catch (Exception) | ||
745 | { | ||
746 | } | ||
747 | // catch (Exception e2) // LEGIT: User Scripting | ||
748 | // { | ||
749 | // m_log.Error("[SCRIPT]: "+ | ||
750 | // "Error displaying error in-world: " + | ||
751 | // e2.ToString()); | ||
752 | // m_log.Error("[SCRIPT]: " + | ||
753 | // "Errormessage: Error compiling script:\r\n" + | ||
754 | // e.ToString()); | ||
755 | // } | ||
756 | } | ||
757 | else if ((e is TargetInvocationException) && (e.InnerException is SelfDeleteException)) | ||
758 | { | 739 | { |
759 | m_InSelfDelete = true; | 740 | // DISPLAY ERROR INWORLD |
760 | if (part != null && part.ParentGroup != null) | 741 | string text = FormatException(e); |
761 | m_Engine.World.DeleteSceneObject(part.ParentGroup, false); | 742 | |
743 | if (text.Length > 1000) | ||
744 | text = text.Substring(0, 1000); | ||
745 | m_Engine.World.SimChat(Utils.StringToBytes(text), | ||
746 | ChatTypeEnum.DebugChannel, 2147483647, | ||
747 | part.AbsolutePosition, | ||
748 | part.Name, part.UUID, false); | ||
762 | } | 749 | } |
763 | else if ((e is TargetInvocationException) && (e.InnerException is ScriptDeleteException)) | 750 | catch (Exception) |
764 | { | 751 | { |
765 | m_InSelfDelete = true; | ||
766 | if (part != null && part.ParentGroup != null) | ||
767 | part.Inventory.RemoveInventoryItem(m_ItemID); | ||
768 | } | 752 | } |
753 | // catch (Exception e2) // LEGIT: User Scripting | ||
754 | // { | ||
755 | // m_log.Error("[SCRIPT]: "+ | ||
756 | // "Error displaying error in-world: " + | ||
757 | // e2.ToString()); | ||
758 | // m_log.Error("[SCRIPT]: " + | ||
759 | // "Errormessage: Error compiling script:\r\n" + | ||
760 | // e.ToString()); | ||
761 | // } | ||
762 | } | ||
763 | else if ((e is TargetInvocationException) && (e.InnerException is SelfDeleteException)) | ||
764 | { | ||
765 | m_InSelfDelete = true; | ||
766 | if (part != null && part.ParentGroup != null) | ||
767 | m_Engine.World.DeleteSceneObject(part.ParentGroup, false); | ||
768 | } | ||
769 | else if ((e is TargetInvocationException) && (e.InnerException is ScriptDeleteException)) | ||
770 | { | ||
771 | m_InSelfDelete = true; | ||
772 | if (part != null && part.ParentGroup != null) | ||
773 | part.Inventory.RemoveInventoryItem(m_ItemID); | ||
769 | } | 774 | } |
770 | } | 775 | } |
771 | } | 776 | } |
777 | } | ||
772 | 778 | ||
773 | lock (m_EventQueue) | 779 | lock (m_EventQueue) |
780 | { | ||
781 | if ((m_EventQueue.Count > 0) && m_RunEvents && (!m_ShuttingDown)) | ||
774 | { | 782 | { |
775 | if ((m_EventQueue.Count > 0) && m_RunEvents && (!m_ShuttingDown)) | 783 | m_CurrentResult = m_Engine.QueueEventHandler(this); |
776 | { | 784 | } |
777 | m_CurrentResult = m_Engine.QueueEventHandler(this); | 785 | else |
778 | } | 786 | { |
779 | else | 787 | m_CurrentResult = null; |
780 | { | ||
781 | m_CurrentResult = null; | ||
782 | } | ||
783 | } | 788 | } |
789 | } | ||
784 | 790 | ||
785 | m_DetectParams = null; | 791 | m_DetectParams = null; |
786 | 792 | ||
787 | return 0; | 793 | return 0; |
788 | } | 794 | } |
789 | } | 795 | } |
790 | 796 | ||
791 | public int EventTime() | 797 | public int EventTime() |
@@ -824,6 +830,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Instance | |||
824 | new Object[0], new DetectParams[0])); | 830 | new Object[0], new DetectParams[0])); |
825 | } | 831 | } |
826 | 832 | ||
833 | [DebuggerNonUserCode] //Stops the VS debugger from farting in this function | ||
827 | public void ApiResetScript() | 834 | public void ApiResetScript() |
828 | { | 835 | { |
829 | // bool running = Running; | 836 | // bool running = Running; |
diff --git a/OpenSim/Region/ScriptEngine/Shared/LSL_Types.cs b/OpenSim/Region/ScriptEngine/Shared/LSL_Types.cs index 3f38bb6..1fc31c5 100644 --- a/OpenSim/Region/ScriptEngine/Shared/LSL_Types.cs +++ b/OpenSim/Region/ScriptEngine/Shared/LSL_Types.cs | |||
@@ -429,6 +429,11 @@ namespace OpenSim.Region.ScriptEngine.Shared | |||
429 | } | 429 | } |
430 | } | 430 | } |
431 | 431 | ||
432 | public int Size | ||
433 | { | ||
434 | get { return 0; } | ||
435 | } | ||
436 | |||
432 | public object[] Data | 437 | public object[] Data |
433 | { | 438 | { |
434 | get { | 439 | get { |