From 169032b4a42736b3feef682fcbfd1cc1f8b159ba Mon Sep 17 00:00:00 2001 From: Tedd Hansen Date: Sat, 16 Feb 2008 07:53:02 +0000 Subject: Fixed ScriptEngine config in OpenSim.ini.example that was out of place. Added some info to failure on GridServices listening port so people can see what actually went wrong. Moved most of the function/event execution module to a baseclass so other execution methods (instead of reflection) can be used with custom script modules run by ScriptEngine.Common. + some accumulated patches --- OpenSim/Region/ScriptEngine/Common/Executor.cs | 64 ++------------------------ 1 file changed, 4 insertions(+), 60 deletions(-) (limited to 'OpenSim/Region/ScriptEngine/Common/Executor.cs') diff --git a/OpenSim/Region/ScriptEngine/Common/Executor.cs b/OpenSim/Region/ScriptEngine/Common/Executor.cs index 6262c64..e35882b 100644 --- a/OpenSim/Region/ScriptEngine/Common/Executor.cs +++ b/OpenSim/Region/ScriptEngine/Common/Executor.cs @@ -33,64 +33,26 @@ using System.Runtime.Remoting.Lifetime; namespace OpenSim.Region.ScriptEngine.Common { - public class Executor : MarshalByRefObject + public class Executor : ExecutorBase { - // Private instance for each script - - private IScript m_Script; + // Cache functions by keeping a reference to them in a dictionary private Dictionary Events = new Dictionary(); - private bool m_Running = true; - //private List Scripts = new List(); - public Executor(IScript Script) + public Executor(IScript script) : base(script) { - m_Script = Script; } - // Object never expires - public override Object InitializeLifetimeService() - { - //Console.WriteLine("Executor: InitializeLifetimeService()"); - // return null; - ILease lease = (ILease) base.InitializeLifetimeService(); - - if (lease.CurrentState == LeaseState.Initial) - { - lease.InitialLeaseTime = TimeSpan.Zero; // TimeSpan.FromMinutes(1); -// lease.SponsorshipTimeout = TimeSpan.FromMinutes(2); -// lease.RenewOnCallTime = TimeSpan.FromSeconds(2); - } - return lease; - } - - public AppDomain GetAppDomain() - { - return AppDomain.CurrentDomain; - } - - public void ExecuteEvent(string FunctionName, object[] args) + protected override void DoExecuteEvent(string FunctionName, object[] args) { // IMPORTANT: Types and MemberInfo-derived objects require a LOT of memory. // Instead use RuntimeTypeHandle, RuntimeFieldHandle and RunTimeHandle (IntPtr) instead! - //try - //{ - if (m_Running == false) - { - // Script is inactive, do not execute! - return; - } string EventName = m_Script.State + "_event_" + FunctionName; -//cfk 2-7-08 dont need this right now and the default Linux build has DEBUG defined ///#if DEBUG /// Console.WriteLine("ScriptEngine: Script event function name: " + EventName); ///#endif - //type.InvokeMember(EventName, BindingFlags.InvokeMethod, null, m_Script, args); - - //Console.WriteLine("ScriptEngine Executor.ExecuteEvent: \String.Empty + EventName + "\String.Empty); - if (Events.ContainsKey(EventName) == false) { // Not found, create @@ -122,27 +84,9 @@ namespace OpenSim.Region.ScriptEngine.Common /// Console.WriteLine("ScriptEngine: Executing function name: " + EventName); ///#endif // Found - //try - //{ - // Invoke it ev.Invoke(m_Script, args); - //} - //catch (Exception e) - //{ - // // TODO: Send to correct place - // Console.WriteLine("ScriptEngine Exception attempting to executing script function: " + e.ToString()); - //} - - - //} - //catch { } } - - public void StopScript() - { - m_Running = false; - } } } \ No newline at end of file -- cgit v1.1