diff options
Diffstat (limited to '')
-rw-r--r-- | OpenSim/Region/ScriptEngine/YEngine/XMRInstMisc.cs (renamed from OpenSim/Region/ScriptEngine/XMREngine/XMRInstMisc.cs) | 237 |
1 files changed, 133 insertions, 104 deletions
diff --git a/OpenSim/Region/ScriptEngine/XMREngine/XMRInstMisc.cs b/OpenSim/Region/ScriptEngine/YEngine/XMRInstMisc.cs index 6ff486a..8f020ce 100644 --- a/OpenSim/Region/ScriptEngine/XMREngine/XMRInstMisc.cs +++ b/OpenSim/Region/ScriptEngine/YEngine/XMRInstMisc.cs | |||
@@ -42,7 +42,7 @@ using OpenSim.Region.ScriptEngine.Interfaces; | |||
42 | using OpenSim.Region.ScriptEngine.Shared; | 42 | using OpenSim.Region.ScriptEngine.Shared; |
43 | using OpenSim.Region.ScriptEngine.Shared.Api; | 43 | using OpenSim.Region.ScriptEngine.Shared.Api; |
44 | using OpenSim.Region.ScriptEngine.Shared.ScriptBase; | 44 | using OpenSim.Region.ScriptEngine.Shared.ScriptBase; |
45 | using OpenSim.Region.ScriptEngine.XMREngine; | 45 | using OpenSim.Region.ScriptEngine.Yengine; |
46 | using OpenSim.Region.Framework.Scenes; | 46 | using OpenSim.Region.Framework.Scenes; |
47 | using log4net; | 47 | using log4net; |
48 | 48 | ||
@@ -56,7 +56,7 @@ using LSL_Vector = OpenSim.Region.ScriptEngine.Shared.LSL_Types.Vector3; | |||
56 | 56 | ||
57 | // This class exists in the main app domain | 57 | // This class exists in the main app domain |
58 | // | 58 | // |
59 | namespace OpenSim.Region.ScriptEngine.XMREngine | 59 | namespace OpenSim.Region.ScriptEngine.Yengine |
60 | { | 60 | { |
61 | public partial class XMRInstance | 61 | public partial class XMRInstance |
62 | { | 62 | { |
@@ -80,57 +80,48 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
80 | suspendOnCheckRunHold = true; | 80 | suspendOnCheckRunHold = true; |
81 | 81 | ||
82 | /* | 82 | /* |
83 | * Wait for it to stop executing and prevent it from starting again | 83 | * Don't send us any more events. |
84 | * as it can't run without a microthread. | ||
85 | */ | 84 | */ |
86 | lock (m_RunLock) | 85 | lock(m_RunLock) |
87 | { | 86 | { |
88 | if (microthread != null) | 87 | if(m_Part != null) |
89 | { | 88 | { |
90 | m_RunOnePhase = "disposing"; | 89 | m_Part.RemoveScriptEvents(m_ItemID); |
91 | CheckRunLockInvariants(true); | 90 | AsyncCommandManager.RemoveScript(m_Engine, m_LocalID, m_ItemID); |
92 | microthread.Dispose (); | 91 | m_Part = null; |
93 | microthread = null; | ||
94 | } | 92 | } |
95 | } | 93 | } |
96 | 94 | ||
97 | /* | 95 | /* |
98 | * Don't send us any more events. | ||
99 | */ | ||
100 | if (m_Part != null) | ||
101 | { | ||
102 | xmrTrapRegionCrossing (0); | ||
103 | m_Part.RemoveScriptEvents(m_ItemID); | ||
104 | AsyncCommandManager.RemoveScript(m_Engine, m_LocalID, m_ItemID); | ||
105 | m_Part = null; | ||
106 | } | ||
107 | |||
108 | /* | ||
109 | * Let script methods get garbage collected if no one else is using | 96 | * Let script methods get garbage collected if no one else is using |
110 | * them. | 97 | * them. |
111 | */ | 98 | */ |
112 | DecObjCodeRefCount (); | 99 | DecObjCodeRefCount(); |
113 | } | 100 | } |
114 | 101 | ||
115 | private void DecObjCodeRefCount () | 102 | private void DecObjCodeRefCount() |
116 | { | 103 | { |
117 | if (m_ObjCode != null) { | 104 | if(m_ObjCode != null) |
118 | lock (m_CompileLock) { | 105 | { |
106 | lock(m_CompileLock) | ||
107 | { | ||
119 | ScriptObjCode objCode; | 108 | ScriptObjCode objCode; |
120 | 109 | ||
121 | if (m_CompiledScriptObjCode.TryGetValue (m_ScriptObjCodeKey, out objCode) && | 110 | if(m_CompiledScriptObjCode.TryGetValue(m_ScriptObjCodeKey, out objCode) && |
122 | (objCode == m_ObjCode) && | 111 | (objCode == m_ObjCode) && |
123 | (-- objCode.refCount == 0)) { | 112 | (--objCode.refCount == 0)) |
124 | m_CompiledScriptObjCode.Remove (m_ScriptObjCodeKey); | 113 | { |
114 | m_CompiledScriptObjCode.Remove(m_ScriptObjCodeKey); | ||
125 | } | 115 | } |
126 | } | 116 | } |
127 | m_ObjCode = null; | 117 | m_ObjCode = null; |
128 | } | 118 | } |
129 | } | 119 | } |
130 | 120 | ||
131 | public void Verbose (string format, params object[] args) | 121 | public void Verbose(string format, params object[] args) |
132 | { | 122 | { |
133 | if (m_Engine.m_Verbose) m_log.DebugFormat (format, args); | 123 | if(m_Engine.m_Verbose) |
124 | m_log.DebugFormat(format, args); | ||
134 | } | 125 | } |
135 | 126 | ||
136 | // Called by 'xmr top' console command | 127 | // Called by 'xmr top' console command |
@@ -138,37 +129,39 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
138 | // Sacha | 129 | // Sacha |
139 | public void RunTestTop() | 130 | public void RunTestTop() |
140 | { | 131 | { |
141 | if (m_InstEHSlice > 0){ | 132 | if(m_InstEHSlice > 0) |
142 | Console.WriteLine(m_DescName); | 133 | { |
143 | Console.WriteLine(" m_LocalID = " + m_LocalID); | 134 | Console.WriteLine(m_DescName); |
144 | Console.WriteLine(" m_ItemID = " + m_ItemID); | 135 | Console.WriteLine(" m_LocalID = " + m_LocalID); |
145 | Console.WriteLine(" m_Item.AssetID = " + m_Item.AssetID); | 136 | Console.WriteLine(" m_ItemID = " + m_ItemID); |
146 | Console.WriteLine(" m_StartParam = " + m_StartParam); | 137 | Console.WriteLine(" m_Item.AssetID = " + m_Item.AssetID); |
147 | Console.WriteLine(" m_PostOnRez = " + m_PostOnRez); | 138 | Console.WriteLine(" m_StartParam = " + m_StartParam); |
148 | Console.WriteLine(" m_StateSource = " + m_StateSource); | 139 | Console.WriteLine(" m_PostOnRez = " + m_PostOnRez); |
149 | Console.WriteLine(" m_SuspendCount = " + m_SuspendCount); | 140 | Console.WriteLine(" m_StateSource = " + m_StateSource); |
150 | Console.WriteLine(" m_SleepUntil = " + m_SleepUntil); | 141 | Console.WriteLine(" m_SuspendCount = " + m_SuspendCount); |
151 | Console.WriteLine(" m_IState = " + m_IState.ToString()); | 142 | Console.WriteLine(" m_SleepUntil = " + m_SleepUntil); |
152 | Console.WriteLine(" m_StateCode = " + GetStateName(stateCode)); | 143 | Console.WriteLine(" m_IState = " + m_IState.ToString()); |
153 | Console.WriteLine(" eventCode = " + eventCode.ToString()); | 144 | Console.WriteLine(" m_StateCode = " + GetStateName(stateCode)); |
154 | Console.WriteLine(" m_LastRanAt = " + m_LastRanAt.ToString()); | 145 | Console.WriteLine(" eventCode = " + eventCode.ToString()); |
155 | Console.WriteLine(" heapUsed/Limit = " + xmrHeapUsed () + "/" + heapLimit); | 146 | Console.WriteLine(" m_LastRanAt = " + m_LastRanAt.ToString()); |
156 | Console.WriteLine(" m_InstEHEvent = " + m_InstEHEvent.ToString()); | 147 | Console.WriteLine(" heapUsed/Limit = " + xmrHeapUsed() + "/" + heapLimit); |
157 | Console.WriteLine(" m_InstEHSlice = " + m_InstEHSlice.ToString()); | 148 | Console.WriteLine(" m_InstEHEvent = " + m_InstEHEvent.ToString()); |
158 | } | 149 | Console.WriteLine(" m_InstEHSlice = " + m_InstEHSlice.ToString()); |
150 | } | ||
159 | } | 151 | } |
160 | 152 | ||
161 | // Called by 'xmr ls' console command | 153 | // Called by 'xmr ls' console command |
162 | // to dump this script's state to console | 154 | // to dump this script's state to console |
163 | public string RunTestLs(bool flagFull) | 155 | public string RunTestLs(bool flagFull) |
164 | { | 156 | { |
165 | if (flagFull) { | 157 | if(flagFull) |
158 | { | ||
166 | StringBuilder sb = new StringBuilder(); | 159 | StringBuilder sb = new StringBuilder(); |
167 | sb.AppendLine(m_DescName); | 160 | sb.AppendLine(m_DescName); |
168 | sb.AppendLine(" m_LocalID = " + m_LocalID); | 161 | sb.AppendLine(" m_LocalID = " + m_LocalID); |
169 | sb.AppendLine(" m_ItemID = " + m_ItemID + " (.state file)"); | 162 | sb.AppendLine(" m_ItemID = " + m_ItemID + " (.state file)"); |
170 | sb.AppendLine(" m_Item.AssetID = " + m_Item.AssetID); | 163 | sb.AppendLine(" m_Item.AssetID = " + m_Item.AssetID); |
171 | sb.AppendLine(" m_Part.WorldPosition = " + m_Part.GetWorldPosition ()); | 164 | sb.AppendLine(" m_Part.WorldPosition = " + m_Part.GetWorldPosition()); |
172 | sb.AppendLine(" m_ScriptObjCodeKey = " + m_ScriptObjCodeKey + " (source text)"); | 165 | sb.AppendLine(" m_ScriptObjCodeKey = " + m_ScriptObjCodeKey + " (source text)"); |
173 | sb.AppendLine(" m_StartParam = " + m_StartParam); | 166 | sb.AppendLine(" m_StartParam = " + m_StartParam); |
174 | sb.AppendLine(" m_PostOnRez = " + m_PostOnRez); | 167 | sb.AppendLine(" m_PostOnRez = " + m_PostOnRez); |
@@ -185,28 +178,28 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
185 | sb.AppendLine(" suspOnCkRunHold = " + suspendOnCheckRunHold); | 178 | sb.AppendLine(" suspOnCkRunHold = " + suspendOnCheckRunHold); |
186 | sb.AppendLine(" suspOnCkRunTemp = " + suspendOnCheckRunTemp); | 179 | sb.AppendLine(" suspOnCkRunTemp = " + suspendOnCheckRunTemp); |
187 | sb.AppendLine(" m_CheckRunPhase = " + m_CheckRunPhase); | 180 | sb.AppendLine(" m_CheckRunPhase = " + m_CheckRunPhase); |
188 | sb.AppendLine(" heapUsed/Limit = " + xmrHeapUsed () + "/" + heapLimit); | 181 | sb.AppendLine(" heapUsed/Limit = " + xmrHeapUsed() + "/" + heapLimit); |
189 | sb.AppendLine(" m_InstEHEvent = " + m_InstEHEvent.ToString()); | 182 | sb.AppendLine(" m_InstEHEvent = " + m_InstEHEvent.ToString()); |
190 | sb.AppendLine(" m_InstEHSlice = " + m_InstEHSlice.ToString()); | 183 | sb.AppendLine(" m_InstEHSlice = " + m_InstEHSlice.ToString()); |
191 | sb.AppendLine(" m_CPUTime = " + m_CPUTime); | 184 | sb.AppendLine(" m_CPUTime = " + m_CPUTime); |
192 | sb.AppendLine(" callMode = " + callMode); | 185 | sb.AppendLine(" callMode = " + callMode); |
193 | sb.AppendLine(" captureStackFrames = " + captureStackFrames); | 186 | lock(m_QueueLock) |
194 | sb.AppendLine(" stackFramesRestored = " + stackFramesRestored); | ||
195 | lock (m_QueueLock) | ||
196 | { | 187 | { |
197 | sb.AppendLine(" m_Running = " + m_Running); | 188 | sb.AppendLine(" m_Running = " + m_Running); |
198 | foreach (EventParams evt in m_EventQueue) | 189 | foreach(EventParams evt in m_EventQueue) |
199 | { | 190 | { |
200 | sb.AppendLine(" evt.EventName = " + evt.EventName); | 191 | sb.AppendLine(" evt.EventName = " + evt.EventName); |
201 | } | 192 | } |
202 | } | 193 | } |
203 | return sb.ToString(); | 194 | return sb.ToString(); |
204 | } else { | 195 | } |
205 | return String.Format("{0} {1} {2} {3} {4} {5}", | 196 | else |
206 | m_ItemID, | 197 | { |
207 | m_CPUTime.ToString("F3").PadLeft(9), | 198 | return String.Format("{0} {1} {2} {3} {4} {5}", |
208 | m_InstEHEvent.ToString().PadLeft(9), | 199 | m_ItemID, |
209 | m_IState.ToString().PadRight(10), | 200 | m_CPUTime.ToString("F3").PadLeft(9), |
201 | m_InstEHEvent.ToString().PadLeft(9), | ||
202 | m_IState.ToString().PadRight(10), | ||
210 | m_Part.GetWorldPosition().ToString().PadRight(32), | 203 | m_Part.GetWorldPosition().ToString().PadRight(32), |
211 | m_DescName); | 204 | m_DescName); |
212 | } | 205 | } |
@@ -218,16 +211,16 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
218 | */ | 211 | */ |
219 | public int GetStateEventFlags(int stateCode) | 212 | public int GetStateEventFlags(int stateCode) |
220 | { | 213 | { |
221 | if ((stateCode < 0) || | 214 | if((stateCode < 0) || |
222 | (stateCode >= m_ObjCode.scriptEventHandlerTable.GetLength(0))) | 215 | (stateCode >= m_ObjCode.scriptEventHandlerTable.GetLength(0))) |
223 | { | 216 | { |
224 | return 0; | 217 | return 0; |
225 | } | 218 | } |
226 | 219 | ||
227 | int code = 0; | 220 | int code = 0; |
228 | for (int i = 0 ; i < 32; i ++) | 221 | for(int i = 0; i < 32; i++) |
229 | { | 222 | { |
230 | if (m_ObjCode.scriptEventHandlerTable[stateCode, i] != null) | 223 | if(m_ObjCode.scriptEventHandlerTable[stateCode, i] != null) |
231 | { | 224 | { |
232 | code |= 1 << i; | 225 | code |= 1 << i; |
233 | } | 226 | } |
@@ -239,41 +232,47 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
239 | /** | 232 | /** |
240 | * @brief Get the .state file name. | 233 | * @brief Get the .state file name. |
241 | */ | 234 | */ |
242 | public static string GetStateFileName (string scriptBasePath, UUID itemID) | 235 | public static string GetStateFileName(string scriptBasePath, UUID itemID) |
243 | { | 236 | { |
244 | return GetScriptFileName (scriptBasePath, itemID.ToString() + ".state"); | 237 | return GetScriptFileName(scriptBasePath, itemID.ToString() + ".state"); |
245 | } | 238 | } |
246 | 239 | ||
247 | public string GetScriptFileName (string filename) | 240 | public string GetScriptFileName(string filename) |
248 | { | 241 | { |
249 | return GetScriptFileName (m_ScriptBasePath, filename); | 242 | return GetScriptFileName(m_ScriptBasePath, filename); |
250 | } | 243 | } |
251 | 244 | ||
252 | public static string GetScriptFileName (string scriptBasePath, string filename) | 245 | public static string GetScriptFileName(string scriptBasePath, string filename) |
253 | { | 246 | { |
254 | /* | 247 | /* |
255 | * Get old path, ie, all files lumped in a single huge directory. | 248 | * Get old path, ie, all files lumped in a single huge directory. |
256 | */ | 249 | */ |
257 | string oldPath = Path.Combine (scriptBasePath, filename); | 250 | string oldPath = Path.Combine(scriptBasePath, filename); |
258 | 251 | ||
259 | /* | 252 | /* |
260 | * Get new path, ie, files split up based on first 2 chars of name. | 253 | * Get new path, ie, files split up based on first 2 chars of name. |
261 | */ | 254 | */ |
262 | string subdir = filename.Substring (0, 2); | 255 | // string subdir = filename.Substring (0, 2); |
263 | filename = filename.Substring (2); | 256 | // filename = filename.Substring (2); |
264 | scriptBasePath = Path.Combine (scriptBasePath, subdir); | 257 | string subdir = filename.Substring(0, 1); |
265 | Directory.CreateDirectory (scriptBasePath); | 258 | filename = filename.Substring(1); |
266 | string newPath = Path.Combine (scriptBasePath, filename); | 259 | scriptBasePath = Path.Combine(scriptBasePath, subdir); |
260 | Directory.CreateDirectory(scriptBasePath); | ||
261 | string newPath = Path.Combine(scriptBasePath, filename); | ||
267 | 262 | ||
268 | /* | 263 | /* |
269 | * If file exists only in old location, move to new location. | 264 | * If file exists only in old location, move to new location. |
270 | * If file exists in both locations, delete old location. | 265 | * If file exists in both locations, delete old location. |
271 | */ | 266 | */ |
272 | if (File.Exists (oldPath)) { | 267 | if(File.Exists(oldPath)) |
273 | if (File.Exists (newPath)) { | 268 | { |
274 | File.Delete (oldPath); | 269 | if(File.Exists(newPath)) |
275 | } else { | 270 | { |
276 | File.Move (oldPath, newPath); | 271 | File.Delete(oldPath); |
272 | } | ||
273 | else | ||
274 | { | ||
275 | File.Move(oldPath, newPath); | ||
277 | } | 276 | } |
278 | } | 277 | } |
279 | 278 | ||
@@ -286,12 +285,15 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
286 | /** | 285 | /** |
287 | * @brief Decode state code (int) to state name (string). | 286 | * @brief Decode state code (int) to state name (string). |
288 | */ | 287 | */ |
289 | public string GetStateName (int stateCode) | 288 | public string GetStateName(int stateCode) |
290 | { | 289 | { |
291 | try { | 290 | try |
291 | { | ||
292 | return m_ObjCode.stateNames[stateCode]; | 292 | return m_ObjCode.stateNames[stateCode]; |
293 | } catch { | 293 | } |
294 | return stateCode.ToString (); | 294 | catch |
295 | { | ||
296 | return stateCode.ToString(); | ||
295 | } | 297 | } |
296 | } | 298 | } |
297 | 299 | ||
@@ -300,42 +302,66 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
300 | */ | 302 | */ |
301 | public int StartParam | 303 | public int StartParam |
302 | { | 304 | { |
303 | get { return m_StartParam; } | 305 | get |
304 | set { m_StartParam = value; } | 306 | { |
307 | return m_StartParam; | ||
308 | } | ||
309 | set | ||
310 | { | ||
311 | m_StartParam = value; | ||
312 | } | ||
305 | } | 313 | } |
306 | 314 | ||
307 | public SceneObjectPart SceneObject | 315 | public SceneObjectPart SceneObject |
308 | { | 316 | { |
309 | get { return m_Part; } | 317 | get |
318 | { | ||
319 | return m_Part; | ||
320 | } | ||
310 | } | 321 | } |
311 | 322 | ||
312 | public DetectParams[] DetectParams | 323 | public DetectParams[] DetectParams |
313 | { | 324 | { |
314 | get { return m_DetectParams; } | 325 | get |
315 | set { m_DetectParams = value; } | 326 | { |
327 | return m_DetectParams; | ||
328 | } | ||
329 | set | ||
330 | { | ||
331 | m_DetectParams = value; | ||
332 | } | ||
316 | } | 333 | } |
317 | 334 | ||
318 | public UUID ItemID | 335 | public UUID ItemID |
319 | { | 336 | { |
320 | get { return m_ItemID; } | 337 | get |
338 | { | ||
339 | return m_ItemID; | ||
340 | } | ||
321 | } | 341 | } |
322 | 342 | ||
323 | public UUID AssetID | 343 | public UUID AssetID |
324 | { | 344 | { |
325 | get { return m_Item.AssetID; } | 345 | get |
346 | { | ||
347 | return m_Item.AssetID; | ||
348 | } | ||
326 | } | 349 | } |
327 | 350 | ||
328 | public bool Running | 351 | public bool Running |
329 | { | 352 | { |
330 | get { return m_Running; } | 353 | get |
354 | { | ||
355 | return m_Running; | ||
356 | } | ||
331 | set | 357 | set |
332 | { | 358 | { |
333 | lock (m_QueueLock) | 359 | lock(m_QueueLock) |
334 | { | 360 | { |
335 | m_Running = value; | 361 | m_Running = value; |
336 | if (!value) | 362 | if(!value) |
337 | { | 363 | { |
338 | EmptyEventQueues (); | 364 | EmptyEventQueues(); |
339 | } | 365 | } |
340 | } | 366 | } |
341 | } | 367 | } |
@@ -345,26 +371,28 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
345 | * @brief Empty out the event queues. | 371 | * @brief Empty out the event queues. |
346 | * Assumes caller has the m_QueueLock locked. | 372 | * Assumes caller has the m_QueueLock locked. |
347 | */ | 373 | */ |
348 | public void EmptyEventQueues () | 374 | public void EmptyEventQueues() |
349 | { | 375 | { |
350 | m_EventQueue.Clear(); | 376 | m_EventQueue.Clear(); |
351 | for (int i = m_EventCounts.Length; -- i >= 0;) m_EventCounts[i] = 0; | 377 | for(int i = m_EventCounts.Length; --i >= 0;) |
378 | m_EventCounts[i] = 0; | ||
352 | } | 379 | } |
353 | 380 | ||
354 | /** | 381 | /** |
355 | * @brief Convert an LSL vector to an Openmetaverse vector. | 382 | * @brief Convert an LSL vector to an Openmetaverse vector. |
356 | */ | 383 | */ |
357 | public static OpenMetaverse.Vector3 LSLVec2OMVec (LSL_Vector lslVec) | 384 | public static OpenMetaverse.Vector3 LSLVec2OMVec(LSL_Vector lslVec) |
358 | { | 385 | { |
359 | return new OpenMetaverse.Vector3 ((float)lslVec.x, (float)lslVec.y, (float)lslVec.z); | 386 | return new OpenMetaverse.Vector3((float)lslVec.x, (float)lslVec.y, (float)lslVec.z); |
360 | } | 387 | } |
361 | 388 | ||
362 | /** | 389 | /** |
363 | * @brief Extract an integer from an element of an LSL_List. | 390 | * @brief Extract an integer from an element of an LSL_List. |
364 | */ | 391 | */ |
365 | public static int ListInt (object element) | 392 | public static int ListInt(object element) |
366 | { | 393 | { |
367 | if (element is LSL_Integer) { | 394 | if(element is LSL_Integer) |
395 | { | ||
368 | return (int)(LSL_Integer)element; | 396 | return (int)(LSL_Integer)element; |
369 | } | 397 | } |
370 | return (int)element; | 398 | return (int)element; |
@@ -373,9 +401,10 @@ namespace OpenSim.Region.ScriptEngine.XMREngine | |||
373 | /** | 401 | /** |
374 | * @brief Extract a string from an element of an LSL_List. | 402 | * @brief Extract a string from an element of an LSL_List. |
375 | */ | 403 | */ |
376 | public static string ListStr (object element) | 404 | public static string ListStr(object element) |
377 | { | 405 | { |
378 | if (element is LSL_String) { | 406 | if(element is LSL_String) |
407 | { | ||
379 | return (string)(LSL_String)element; | 408 | return (string)(LSL_String)element; |
380 | } | 409 | } |
381 | return (string)element; | 410 | return (string)element; |