diff options
Diffstat (limited to 'OpenSim/Region/ScriptEngine/Shared/Instance/ScriptInstance.cs')
-rw-r--r-- | OpenSim/Region/ScriptEngine/Shared/Instance/ScriptInstance.cs | 13 |
1 files changed, 10 insertions, 3 deletions
diff --git a/OpenSim/Region/ScriptEngine/Shared/Instance/ScriptInstance.cs b/OpenSim/Region/ScriptEngine/Shared/Instance/ScriptInstance.cs index b840730..6a9cd72 100644 --- a/OpenSim/Region/ScriptEngine/Shared/Instance/ScriptInstance.cs +++ b/OpenSim/Region/ScriptEngine/Shared/Instance/ScriptInstance.cs | |||
@@ -546,7 +546,8 @@ namespace OpenSim.Region.ScriptEngine.Shared.Instance | |||
546 | public bool Stop(int timeout) | 546 | public bool Stop(int timeout) |
547 | { | 547 | { |
548 | // m_log.DebugFormat( | 548 | // m_log.DebugFormat( |
549 | // "[SCRIPT INSTANCE]: Stopping script {0} {1} with timeout {2}", ScriptName, ItemID, timeout); | 549 | // "[SCRIPT INSTANCE]: Stopping script {0} {1} in {2} {3} with timeout {4} {5} {6}", |
550 | // ScriptName, ItemID, PrimName, ObjectID, timeout, m_InSelfDelete, DateTime.Now.Ticks); | ||
550 | 551 | ||
551 | IScriptWorkItem workItem; | 552 | IScriptWorkItem workItem; |
552 | 553 | ||
@@ -575,7 +576,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.Instance | |||
575 | } | 576 | } |
576 | 577 | ||
577 | // Wait for the current event to complete. | 578 | // Wait for the current event to complete. |
578 | if (workItem.Wait(new TimeSpan((long)timeout * 100000))) | 579 | if (!m_InSelfDelete && workItem.Wait(new TimeSpan((long)timeout * 100000))) |
579 | { | 580 | { |
580 | return true; | 581 | return true; |
581 | } | 582 | } |
@@ -592,7 +593,9 @@ namespace OpenSim.Region.ScriptEngine.Shared.Instance | |||
592 | // forcibly abort the work item (this aborts the underlying thread). | 593 | // forcibly abort the work item (this aborts the underlying thread). |
593 | if (!m_InSelfDelete) | 594 | if (!m_InSelfDelete) |
594 | { | 595 | { |
595 | // m_log.ErrorFormat("[SCRIPT INSTANCE]: Aborting script {0} {1}", ScriptName, ItemID); | 596 | // m_log.ErrorFormat( |
597 | // "[SCRIPT INSTANCE]: Aborting script {0} {1} in prim {2} {3} {4} {5}", | ||
598 | // ScriptName, ItemID, PrimName, ObjectID, m_InSelfDelete, DateTime.Now.Ticks); | ||
596 | 599 | ||
597 | workItem.Abort(); | 600 | workItem.Abort(); |
598 | } | 601 | } |
@@ -706,6 +709,10 @@ namespace OpenSim.Region.ScriptEngine.Shared.Instance | |||
706 | /// <returns></returns> | 709 | /// <returns></returns> |
707 | public object EventProcessor() | 710 | public object EventProcessor() |
708 | { | 711 | { |
712 | // We check here as the thread stopping this instance from running may itself hold the m_Script lock. | ||
713 | if (!Running) | ||
714 | return 0; | ||
715 | |||
709 | lock (m_Script) | 716 | lock (m_Script) |
710 | { | 717 | { |
711 | // m_log.DebugFormat("[XEngine]: EventProcessor() invoked for {0}.{1}", PrimName, ScriptName); | 718 | // m_log.DebugFormat("[XEngine]: EventProcessor() invoked for {0}.{1}", PrimName, ScriptName); |