Correct the design error I introduced into ScriptComms. Untested but about to
be.avinationmerge
parent
44f1f87656
commit
4b76c52c41
|
@ -31,7 +31,6 @@ using OpenMetaverse;
|
||||||
namespace OpenSim.Region.Framework.Interfaces
|
namespace OpenSim.Region.Framework.Interfaces
|
||||||
{
|
{
|
||||||
public delegate void ScriptCommand(UUID script, string id, string module, string command, string k);
|
public delegate void ScriptCommand(UUID script, string id, string module, string command, string k);
|
||||||
public delegate object ScriptInvocation(UUID script, object[] parms);
|
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Interface for communication between OpenSim modules and in-world scripts
|
/// Interface for communication between OpenSim modules and in-world scripts
|
||||||
|
@ -46,10 +45,10 @@ namespace OpenSim.Region.Framework.Interfaces
|
||||||
/// </summary>
|
/// </summary>
|
||||||
event ScriptCommand OnScriptCommand;
|
event ScriptCommand OnScriptCommand;
|
||||||
|
|
||||||
void RegisterScriptInvocation(ScriptInvocation fn);
|
void RegisterScriptInvocation(Delegate fn);
|
||||||
ScriptInvocation[] GetScriptInvocationList();
|
Delegate[] GetScriptInvocationList();
|
||||||
|
|
||||||
ScriptInvocation LookupScriptInvocation(string fname);
|
Delegate LookupScriptInvocation(string fname);
|
||||||
string LookupModInvocation(string fname);
|
string LookupModInvocation(string fname);
|
||||||
Type[] LookupTypeSignature(string fname);
|
Type[] LookupTypeSignature(string fname);
|
||||||
Type LookupReturnType(string fname);
|
Type LookupReturnType(string fname);
|
||||||
|
|
|
@ -47,15 +47,15 @@ namespace OpenSim.Region.CoreModules.Scripting.ScriptModuleComms
|
||||||
#region ScriptInvocation
|
#region ScriptInvocation
|
||||||
protected class ScriptInvocationData
|
protected class ScriptInvocationData
|
||||||
{
|
{
|
||||||
public ScriptInvocation ScriptInvocationFn { get; private set; }
|
public Delegate ScriptInvocationDelegate { get; private set; }
|
||||||
public string FunctionName { get; private set; }
|
public string FunctionName { get; private set; }
|
||||||
public Type[] TypeSignature { get; private set; }
|
public Type[] TypeSignature { get; private set; }
|
||||||
public Type ReturnType { get; private set; }
|
public Type ReturnType { get; private set; }
|
||||||
|
|
||||||
public ScriptInvocationData(string fname, ScriptInvocation fn, Type[] callsig, Type returnsig)
|
public ScriptInvocationData(string fname, Delegate fn, Type[] callsig, Type returnsig)
|
||||||
{
|
{
|
||||||
FunctionName = fname;
|
FunctionName = fname;
|
||||||
ScriptInvocationFn = fn;
|
ScriptInvocationDelegate = fn;
|
||||||
TypeSignature = callsig;
|
TypeSignature = callsig;
|
||||||
ReturnType = returnsig;
|
ReturnType = returnsig;
|
||||||
}
|
}
|
||||||
|
@ -126,26 +126,30 @@ namespace OpenSim.Region.CoreModules.Scripting.ScriptModuleComms
|
||||||
m_scriptModule.PostScriptEvent(script, "link_message", args);
|
m_scriptModule.PostScriptEvent(script, "link_message", args);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void RegisterScriptInvocation(ScriptInvocation fcall)
|
public void RegisterScriptInvocation(Delegate fcall)
|
||||||
{
|
{
|
||||||
lock (m_scriptInvocation)
|
lock (m_scriptInvocation)
|
||||||
{
|
{
|
||||||
ParameterInfo[] parameters = fcall.Method.GetParameters ();
|
ParameterInfo[] parameters = fcall.Method.GetParameters ();
|
||||||
Type[] parmTypes = new Type[parameters.Length];
|
if (parameters.Length == 0) // Must have one UUID param
|
||||||
for (int i = 0 ; i < parameters.Length ; i++)
|
return;
|
||||||
parmTypes[i] = parameters[i].ParameterType;
|
|
||||||
|
// Hide the first parameter
|
||||||
|
Type[] parmTypes = new Type[parameters.Length - 1];
|
||||||
|
for (int i = 1 ; i < parameters.Length ; i++)
|
||||||
|
parmTypes[i - 1] = parameters[i].ParameterType;
|
||||||
m_scriptInvocation[fcall.Method.Name] = new ScriptInvocationData(fcall.Method.Name, fcall, parmTypes, fcall.Method.ReturnType);
|
m_scriptInvocation[fcall.Method.Name] = new ScriptInvocationData(fcall.Method.Name, fcall, parmTypes, fcall.Method.ReturnType);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public ScriptInvocation[] GetScriptInvocationList()
|
public Delegate[] GetScriptInvocationList()
|
||||||
{
|
{
|
||||||
List<ScriptInvocation> ret = new List<ScriptInvocation>();
|
List<Delegate> ret = new List<Delegate>();
|
||||||
|
|
||||||
lock (m_scriptInvocation)
|
lock (m_scriptInvocation)
|
||||||
{
|
{
|
||||||
foreach (ScriptInvocationData d in m_scriptInvocation.Values)
|
foreach (ScriptInvocationData d in m_scriptInvocation.Values)
|
||||||
ret.Add(d.ScriptInvocationFn);
|
ret.Add(d.ScriptInvocationDelegate);
|
||||||
}
|
}
|
||||||
return ret.ToArray();
|
return ret.ToArray();
|
||||||
}
|
}
|
||||||
|
@ -177,13 +181,13 @@ namespace OpenSim.Region.CoreModules.Scripting.ScriptModuleComms
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public ScriptInvocation LookupScriptInvocation(string fname)
|
public Delegate LookupScriptInvocation(string fname)
|
||||||
{
|
{
|
||||||
lock (m_scriptInvocation)
|
lock (m_scriptInvocation)
|
||||||
{
|
{
|
||||||
ScriptInvocationData sid;
|
ScriptInvocationData sid;
|
||||||
if (m_scriptInvocation.TryGetValue(fname,out sid))
|
if (m_scriptInvocation.TryGetValue(fname,out sid))
|
||||||
return sid.ScriptInvocationFn;
|
return sid.ScriptInvocationDelegate;
|
||||||
}
|
}
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
|
@ -215,8 +219,12 @@ namespace OpenSim.Region.CoreModules.Scripting.ScriptModuleComms
|
||||||
|
|
||||||
public object InvokeOperation(UUID scriptid, string fname, params object[] parms)
|
public object InvokeOperation(UUID scriptid, string fname, params object[] parms)
|
||||||
{
|
{
|
||||||
ScriptInvocation fn = LookupScriptInvocation(fname);
|
List<object> olist = new List<object>();
|
||||||
return fn(scriptid,parms);
|
olist.Add(scriptid);
|
||||||
|
foreach (object o in parms)
|
||||||
|
olist.Add(o);
|
||||||
|
Delegate fn = LookupScriptInvocation(fname);
|
||||||
|
return fn.DynamicInvoke(olist.ToArray());
|
||||||
}
|
}
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue