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
parent
1b2415325a
commit
edd6577f84
|
@ -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)
|
||||||
|
|
Loading…
Reference in New Issue