while I'm not convinced this is causing my current run away

loop, this queue manipulation is dead wrong as Queue is not
a synchronized data structure.  Hopefully this helps.
0.6.0-stable
Sean Dague 2008-05-07 18:10:18 +00:00
parent 1b2415325a
commit edd6577f84
1 changed files with 21 additions and 18 deletions

View File

@ -207,11 +207,11 @@ namespace OpenSim.Region.ScriptEngine.Common.ScriptEngineBase
public void DoScriptLoadUnload() public void DoScriptLoadUnload()
{ {
if (LUQueue.Count > 0) lock (LUQueue) {
{ if (LUQueue.Count > 0)
LUStruct item = LUQueue.Dequeue();
lock (startStopLock) // Lock so we have only 1 thread working on loading/unloading of scripts
{ {
LUStruct item = LUQueue.Dequeue();
if (item.Action == LUType.Unload) if (item.Action == LUType.Unload)
{ {
_StopScript(item.localID, item.itemID); _StopScript(item.localID, item.itemID);
@ -222,9 +222,8 @@ namespace OpenSim.Region.ScriptEngine.Common.ScriptEngineBase
} }
} }
} }
} }
#endregion #endregion
#region Helper functions #region Helper functions
@ -250,18 +249,20 @@ namespace OpenSim.Region.ScriptEngine.Common.ScriptEngineBase
/// <param name="localID"></param> /// <param name="localID"></param>
public void StartScript(uint localID, LLUUID itemID, string Script) public void StartScript(uint localID, LLUUID itemID, string Script)
{ {
if (LUQueue.Count >= LoadUnloadMaxQueueSize) lock(LUQueue) {
{ if (LUQueue.Count >= LoadUnloadMaxQueueSize)
m_scriptEngine.Log.Error("[" + m_scriptEngine.ScriptEngineName + "]: ERROR: Load/unload queue item count is at " + LUQueue.Count + ". Config variable \"LoadUnloadMaxQueueSize\" is set to " + LoadUnloadMaxQueueSize + ", so ignoring new script."); {
return; m_scriptEngine.Log.Error("[" + m_scriptEngine.ScriptEngineName + "]: ERROR: Load/unload queue item count is at " + LUQueue.Count + ". Config variable \"LoadUnloadMaxQueueSize\" is set to " + LoadUnloadMaxQueueSize + ", so ignoring new script.");
} return;
}
LUStruct ls = new LUStruct(); LUStruct ls = new LUStruct();
ls.localID = localID; ls.localID = localID;
ls.itemID = itemID; ls.itemID = itemID;
ls.script = Script; ls.script = Script;
ls.Action = LUType.Load; ls.Action = LUType.Load;
LUQueue.Enqueue(ls); LUQueue.Enqueue(ls);
}
} }
/// <summary> /// <summary>
@ -275,7 +276,9 @@ namespace OpenSim.Region.ScriptEngine.Common.ScriptEngineBase
ls.localID = localID; ls.localID = localID;
ls.itemID = itemID; ls.itemID = itemID;
ls.Action = LUType.Unload; ls.Action = LUType.Unload;
LUQueue.Enqueue(ls); lock (LUQueue) {
LUQueue.Enqueue(ls);
}
} }
// Create a new instance of the compiler (reuse) // Create a new instance of the compiler (reuse)