Set eol
parent
27859faf7a
commit
f9c981007d
|
@ -1,86 +1,86 @@
|
|||
/*
|
||||
* Copyright (c) Contributors, http://opensimulator.org/
|
||||
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
* * Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* * Neither the name of the OpenSim Project nor the
|
||||
* names of its contributors may be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS AND ANY
|
||||
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
|
||||
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
*/
|
||||
/* Original code: Tedd Hansen */
|
||||
using System;
|
||||
|
||||
namespace OpenSim.Region.ScriptEngine.LSOEngine.LSO
|
||||
{
|
||||
public static class Common
|
||||
{
|
||||
public static bool Debug = true;
|
||||
public static bool IL_UseTryCatch = true;
|
||||
public static bool IL_CreateConstructor = true;
|
||||
public static bool IL_CreateFunctionList = true;
|
||||
public static bool IL_ProcessCodeChunks = true;
|
||||
|
||||
public delegate void SendToDebugEventDelegate(string Message);
|
||||
|
||||
public delegate void SendToLogEventDelegate(string Message);
|
||||
|
||||
public static event SendToDebugEventDelegate SendToDebugEvent;
|
||||
public static event SendToLogEventDelegate SendToLogEvent;
|
||||
|
||||
public static void SendToDebug(string Message)
|
||||
{
|
||||
//if (Debug == true)
|
||||
Console.WriteLine("COMPILER:Debug: " + Message);
|
||||
SendToDebugEvent("\r\n" + DateTime.Now.ToString("[HH:mm:ss] ") + Message);
|
||||
}
|
||||
|
||||
public static void SendToLog(string Message)
|
||||
{
|
||||
//if (Debug == true)
|
||||
Console.WriteLine("COMPILER:LOG: " + Message);
|
||||
SendToLogEvent("\r\n" + DateTime.Now.ToString("[HH:mm:ss] ") + Message);
|
||||
}
|
||||
}
|
||||
|
||||
public static class IL_Helper
|
||||
{
|
||||
public static string ReverseFormatString(string text1, string format)
|
||||
{
|
||||
Common.SendToDebug("ReverseFormatString text1: " + text1);
|
||||
Common.SendToDebug("ReverseFormatString format: " + format);
|
||||
return string.Format(format, text1);
|
||||
}
|
||||
|
||||
public static string ReverseFormatString(string text1, UInt32 text2, string format)
|
||||
{
|
||||
Common.SendToDebug("ReverseFormatString text1: " + text1);
|
||||
Common.SendToDebug("ReverseFormatString text2: " + text2.ToString());
|
||||
Common.SendToDebug("ReverseFormatString format: " + format);
|
||||
return string.Format(format, text1, text2.ToString());
|
||||
}
|
||||
|
||||
public static string Cast_ToString(object obj)
|
||||
{
|
||||
Common.SendToDebug("OBJECT TO BE CASTED: " + obj.GetType().ToString());
|
||||
return "ABCDEFGIHJKLMNOPQ123";
|
||||
}
|
||||
}
|
||||
/*
|
||||
* Copyright (c) Contributors, http://opensimulator.org/
|
||||
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
* * Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* * Neither the name of the OpenSim Project nor the
|
||||
* names of its contributors may be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS AND ANY
|
||||
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
|
||||
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
*/
|
||||
/* Original code: Tedd Hansen */
|
||||
using System;
|
||||
|
||||
namespace OpenSim.Region.ScriptEngine.LSOEngine.LSO
|
||||
{
|
||||
public static class Common
|
||||
{
|
||||
public static bool Debug = true;
|
||||
public static bool IL_UseTryCatch = true;
|
||||
public static bool IL_CreateConstructor = true;
|
||||
public static bool IL_CreateFunctionList = true;
|
||||
public static bool IL_ProcessCodeChunks = true;
|
||||
|
||||
public delegate void SendToDebugEventDelegate(string Message);
|
||||
|
||||
public delegate void SendToLogEventDelegate(string Message);
|
||||
|
||||
public static event SendToDebugEventDelegate SendToDebugEvent;
|
||||
public static event SendToLogEventDelegate SendToLogEvent;
|
||||
|
||||
public static void SendToDebug(string Message)
|
||||
{
|
||||
//if (Debug == true)
|
||||
Console.WriteLine("COMPILER:Debug: " + Message);
|
||||
SendToDebugEvent("\r\n" + DateTime.Now.ToString("[HH:mm:ss] ") + Message);
|
||||
}
|
||||
|
||||
public static void SendToLog(string Message)
|
||||
{
|
||||
//if (Debug == true)
|
||||
Console.WriteLine("COMPILER:LOG: " + Message);
|
||||
SendToLogEvent("\r\n" + DateTime.Now.ToString("[HH:mm:ss] ") + Message);
|
||||
}
|
||||
}
|
||||
|
||||
public static class IL_Helper
|
||||
{
|
||||
public static string ReverseFormatString(string text1, string format)
|
||||
{
|
||||
Common.SendToDebug("ReverseFormatString text1: " + text1);
|
||||
Common.SendToDebug("ReverseFormatString format: " + format);
|
||||
return string.Format(format, text1);
|
||||
}
|
||||
|
||||
public static string ReverseFormatString(string text1, UInt32 text2, string format)
|
||||
{
|
||||
Common.SendToDebug("ReverseFormatString text1: " + text1);
|
||||
Common.SendToDebug("ReverseFormatString text2: " + text2.ToString());
|
||||
Common.SendToDebug("ReverseFormatString format: " + format);
|
||||
return string.Format(format, text1, text2.ToString());
|
||||
}
|
||||
|
||||
public static string Cast_ToString(object obj)
|
||||
{
|
||||
Common.SendToDebug("OBJECT TO BE CASTED: " + obj.GetType().ToString());
|
||||
return "ABCDEFGIHJKLMNOPQ123";
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,293 +1,293 @@
|
|||
/*
|
||||
* Copyright (c) Contributors, http://opensimulator.org/
|
||||
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
* * Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* * Neither the name of the OpenSim Project nor the
|
||||
* names of its contributors may be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS AND ANY
|
||||
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
|
||||
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
*/
|
||||
/* Original code: Tedd Hansen */
|
||||
using System;
|
||||
using System.IO;
|
||||
using System.Reflection;
|
||||
using System.Reflection.Emit;
|
||||
using System.Text;
|
||||
using System.Threading;
|
||||
using OpenSim.Region.ScriptEngine.Common;
|
||||
using OpenSim.Region.ScriptEngine.LSOEngine.LSO;
|
||||
|
||||
namespace OpenSim.Region.ScriptEngine.LSOEngine.LSO
|
||||
{
|
||||
public class Engine
|
||||
{
|
||||
//private string LSO_FileName = @"LSO\AdditionTest.lso";
|
||||
private string LSO_FileName; // = @"LSO\CloseToDefault.lso";
|
||||
private AppDomain appDomain;
|
||||
|
||||
public string Compile(string LSOFileName)
|
||||
{
|
||||
LSO_FileName = LSOFileName;
|
||||
|
||||
|
||||
//appDomain = AppDomain.CreateDomain("AlternateAppDomain");
|
||||
appDomain = Thread.GetDomain();
|
||||
|
||||
// Create Assembly Name
|
||||
AssemblyName asmName = new AssemblyName();
|
||||
asmName.Name = Path.GetFileNameWithoutExtension(LSO_FileName);
|
||||
//asmName.Name = "TestAssembly";
|
||||
|
||||
string DLL_FileName = asmName.Name + ".dll";
|
||||
string DLL_FileName_WithPath = Path.GetDirectoryName(LSO_FileName) + @"\" + DLL_FileName;
|
||||
|
||||
LSOEngine.LSO.Common.SendToLog("LSO File Name: " + Path.GetFileName(LSO_FileName));
|
||||
LSOEngine.LSO.Common.SendToLog("Assembly name: " + asmName.Name);
|
||||
LSOEngine.LSO.Common.SendToLog("Assembly File Name: " + asmName.Name + ".dll");
|
||||
LSOEngine.LSO.Common.SendToLog("Starting processing of LSL ByteCode...");
|
||||
LSOEngine.LSO.Common.SendToLog("");
|
||||
|
||||
|
||||
// Create Assembly
|
||||
AssemblyBuilder asmBuilder = appDomain.DefineDynamicAssembly(
|
||||
asmName,
|
||||
AssemblyBuilderAccess.RunAndSave
|
||||
);
|
||||
//// Create Assembly
|
||||
//AssemblyBuilder asmBuilder =
|
||||
// Thread.GetDomain().DefineDynamicAssembly
|
||||
//(asmName, AssemblyBuilderAccess.RunAndSave);
|
||||
|
||||
// Create a module (and save to disk)
|
||||
ModuleBuilder modBuilder = asmBuilder.DefineDynamicModule
|
||||
(asmName.Name,
|
||||
DLL_FileName);
|
||||
|
||||
//Common.SendToDebug("asmName.Name is still \"" + asmName.Name + "\"");
|
||||
// Create a Class (/Type)
|
||||
TypeBuilder typeBuilder = modBuilder.DefineType(
|
||||
"LSL_ScriptObject",
|
||||
TypeAttributes.Public | TypeAttributes.BeforeFieldInit,
|
||||
typeof (LSL_BaseClass));
|
||||
//,
|
||||
// typeof());
|
||||
//, typeof(LSL_BuiltIn_Commands_Interface));
|
||||
//,
|
||||
// typeof(object),
|
||||
// new Type[] { typeof(LSL_CLRInterface.LSLScript) });
|
||||
|
||||
|
||||
/*
|
||||
* Generate the IL itself
|
||||
*/
|
||||
|
||||
LSO_Parser LSOP = new LSO_Parser(LSO_FileName, typeBuilder);
|
||||
LSOP.OpenFile();
|
||||
LSOP.Parse();
|
||||
|
||||
// Constructor has to be created AFTER LSO_Parser because of accumulated variables
|
||||
if (LSOEngine.LSO.Common.IL_CreateConstructor)
|
||||
IL_CREATE_CONSTRUCTOR(typeBuilder, LSOP);
|
||||
|
||||
LSOP.CloseFile();
|
||||
/*
|
||||
* Done generating. Create a type and run it.
|
||||
*/
|
||||
|
||||
|
||||
LSOEngine.LSO.Common.SendToLog("Attempting to compile assembly...");
|
||||
// Compile it
|
||||
Type type = typeBuilder.CreateType();
|
||||
LSOEngine.LSO.Common.SendToLog("Compilation successful!");
|
||||
|
||||
LSOEngine.LSO.Common.SendToLog("Saving assembly: " + DLL_FileName);
|
||||
asmBuilder.Save(DLL_FileName);
|
||||
|
||||
LSOEngine.LSO.Common.SendToLog("Returning assembly filename: " + DLL_FileName);
|
||||
|
||||
|
||||
return DLL_FileName;
|
||||
|
||||
|
||||
//Common.SendToLog("Creating an instance of new assembly...");
|
||||
//// Create an instance we can play with
|
||||
////LSLScript hello = (LSLScript)Activator.CreateInstance(type);
|
||||
////LSL_CLRInterface.LSLScript MyScript = (LSL_CLRInterface.LSLScript)Activator.CreateInstance(type);
|
||||
//object MyScript = (object)Activator.CreateInstance(type);
|
||||
|
||||
|
||||
//System.Reflection.MemberInfo[] Members = type.GetMembers();
|
||||
|
||||
//Common.SendToLog("Members of assembly " + type.ToString() + ":");
|
||||
//foreach (MemberInfo member in Members)
|
||||
// Common.SendToLog(member.ToString());
|
||||
|
||||
|
||||
//// Play with it
|
||||
////MyScript.event_state_entry("Test");
|
||||
//object[] args = { null };
|
||||
////System.Collections.Generic.List<string> Functions = (System.Collections.Generic.List<string>)type.InvokeMember("GetFunctions", BindingFlags.InvokeMethod, null, MyScript, null);
|
||||
|
||||
//string[] ret = { };
|
||||
//if (Common.IL_CreateFunctionList)
|
||||
// ret = (string[])type.InvokeMember("GetFunctions", BindingFlags.InvokeMethod, null, MyScript, null);
|
||||
|
||||
//foreach (string s in ret)
|
||||
//{
|
||||
// Common.SendToLog("");
|
||||
// Common.SendToLog("*** Executing LSL Server Event: " + s);
|
||||
// //object test = type.GetMember(s);
|
||||
// //object runner = type.InvokeMember(s, BindingFlags.Public | BindingFlags.InvokeMethod | BindingFlags.Instance, null, MyScript, args);
|
||||
// //runner();
|
||||
// //objBooks_Late = type.InvokeMember(s, BindingFlags.CreateInstance, null, objApp_Late, null);
|
||||
// type.InvokeMember(s, BindingFlags.InvokeMethod, null, MyScript, new object[] { "Test" });
|
||||
|
||||
//}
|
||||
}
|
||||
|
||||
|
||||
private static void IL_CREATE_CONSTRUCTOR(TypeBuilder typeBuilder, LSO_Parser LSOP)
|
||||
{
|
||||
LSOEngine.LSO.Common.SendToDebug("IL_CREATE_CONSTRUCTOR()");
|
||||
//ConstructorBuilder constructor = typeBuilder.DefineConstructor(
|
||||
// MethodAttributes.Public,
|
||||
// CallingConventions.Standard,
|
||||
// new Type[0]);
|
||||
ConstructorBuilder constructor = typeBuilder.DefineConstructor(
|
||||
MethodAttributes.Public |
|
||||
MethodAttributes.SpecialName |
|
||||
MethodAttributes.RTSpecialName,
|
||||
CallingConventions.Standard,
|
||||
new Type[0]);
|
||||
|
||||
//Define the reflection ConstructorInfor for System.Object
|
||||
ConstructorInfo conObj = typeof (LSL_BaseClass).GetConstructor(new Type[0]);
|
||||
|
||||
//call constructor of base object
|
||||
ILGenerator il = constructor.GetILGenerator();
|
||||
|
||||
il.Emit(OpCodes.Ldarg_0);
|
||||
il.Emit(OpCodes.Call, conObj);
|
||||
|
||||
|
||||
//Common.SendToDebug("IL_CREATE_CONSTRUCTOR: Creating global: UInt32 State = 0;");
|
||||
//string FieldName;
|
||||
//// Create state object
|
||||
//FieldName = "State";
|
||||
//FieldBuilder State_fb = typeBuilder.DefineField(
|
||||
// FieldName,
|
||||
// typeof(UInt32),
|
||||
// FieldAttributes.Public);
|
||||
//il.Emit(OpCodes.Ldarg_0);
|
||||
//il.Emit(OpCodes.Ldc_I4, 0);
|
||||
//il.Emit(OpCodes.Stfld, State_fb);
|
||||
|
||||
|
||||
//Common.SendToDebug("IL_CREATE_CONSTRUCTOR: Creating global: LSL_BuiltIn_Commands_TestImplementation LSL_BuiltIns = New LSL_BuiltIn_Commands_TestImplementation();");
|
||||
////Type objType1 = typeof(object);
|
||||
//Type objType1 = typeof(LSL_BuiltIn_Commands_TestImplementation);
|
||||
|
||||
//FieldName = "LSL_BuiltIns";
|
||||
//FieldBuilder LSL_BuiltIns_fb = typeBuilder.DefineField(
|
||||
// FieldName,
|
||||
// objType1,
|
||||
// FieldAttributes.Public);
|
||||
|
||||
////LSL_BuiltIn_Commands_TestImplementation _ti = new LSL_BuiltIn_Commands_TestImplementation();
|
||||
//il.Emit(OpCodes.Ldarg_0);
|
||||
////il.Emit(OpCodes.Ldstr, "Test 123");
|
||||
//il.Emit(OpCodes.Newobj, objType1.GetConstructor(new Type[] { }));
|
||||
//il.Emit(OpCodes.Stfld, LSL_BuiltIns_fb);
|
||||
|
||||
foreach (UInt32 pos in LSOP.StaticBlocks.Keys)
|
||||
{
|
||||
LSO_Struct.StaticBlock sb;
|
||||
LSOP.StaticBlocks.TryGetValue(pos, out sb);
|
||||
|
||||
if (sb.ObjectType > 0 && sb.ObjectType < 8)
|
||||
{
|
||||
// We don't want void or null's
|
||||
|
||||
il.Emit(OpCodes.Ldarg_0);
|
||||
// Push position to stack
|
||||
il.Emit(OpCodes.Ldc_I4, pos);
|
||||
//il.Emit(OpCodes.Box, typeof(UInt32));
|
||||
|
||||
|
||||
Type datatype = null;
|
||||
|
||||
// Push data to stack
|
||||
LSOEngine.LSO.Common.SendToDebug("Adding to static (" + pos + ") type: " +
|
||||
((LSO_Enums.Variable_Type_Codes) sb.ObjectType).ToString() + " (" + sb.ObjectType +
|
||||
")");
|
||||
switch ((LSO_Enums.Variable_Type_Codes) sb.ObjectType)
|
||||
{
|
||||
case LSO_Enums.Variable_Type_Codes.Float:
|
||||
case LSO_Enums.Variable_Type_Codes.Integer:
|
||||
//UInt32
|
||||
il.Emit(OpCodes.Ldc_I4, BitConverter.ToUInt32(sb.BlockVariable, 0));
|
||||
datatype = typeof (UInt32);
|
||||
il.Emit(OpCodes.Box, datatype);
|
||||
break;
|
||||
case LSO_Enums.Variable_Type_Codes.String:
|
||||
case LSO_Enums.Variable_Type_Codes.Key:
|
||||
//String
|
||||
LSO_Struct.HeapBlock hb =
|
||||
LSOP.GetHeap(LSOP.myHeader.HR + BitConverter.ToUInt32(sb.BlockVariable, 0) - 1);
|
||||
il.Emit(OpCodes.Ldstr, Encoding.UTF8.GetString(hb.Data));
|
||||
datatype = typeof (string);
|
||||
break;
|
||||
case LSO_Enums.Variable_Type_Codes.Vector:
|
||||
datatype = typeof (LSO_Enums.Vector);
|
||||
//TODO: Not implemented
|
||||
break;
|
||||
case LSO_Enums.Variable_Type_Codes.Rotation:
|
||||
//Object
|
||||
//TODO: Not implemented
|
||||
datatype = typeof (LSO_Enums.Rotation);
|
||||
break;
|
||||
default:
|
||||
datatype = typeof (object);
|
||||
break;
|
||||
}
|
||||
|
||||
|
||||
// Make call
|
||||
il.Emit(OpCodes.Call,
|
||||
typeof (LSL_BaseClass).GetMethod("AddToStatic", new Type[] {typeof (UInt32), datatype}));
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
////il.Emit(OpCodes.Newobj, typeof(UInt32));
|
||||
//il.Emit(OpCodes.Starg_0);
|
||||
//// Create LSL function library
|
||||
//FieldBuilder LSL_BuiltIns_fb = typeBuilder.DefineField("LSL_BuiltIns", typeof(LSL_BuiltIn_Commands_Interface), FieldAttributes.Public);
|
||||
//il.Emit(OpCodes.Newobj, typeof(LSL_BuiltIn_Commands_Interface));
|
||||
//il.Emit(OpCodes.Stloc_1);
|
||||
|
||||
il.Emit(OpCodes.Ret);
|
||||
}
|
||||
|
||||
|
||||
// End of class
|
||||
}
|
||||
/*
|
||||
* Copyright (c) Contributors, http://opensimulator.org/
|
||||
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
* * Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* * Neither the name of the OpenSim Project nor the
|
||||
* names of its contributors may be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS AND ANY
|
||||
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
|
||||
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
*/
|
||||
/* Original code: Tedd Hansen */
|
||||
using System;
|
||||
using System.IO;
|
||||
using System.Reflection;
|
||||
using System.Reflection.Emit;
|
||||
using System.Text;
|
||||
using System.Threading;
|
||||
using OpenSim.Region.ScriptEngine.Common;
|
||||
using OpenSim.Region.ScriptEngine.LSOEngine.LSO;
|
||||
|
||||
namespace OpenSim.Region.ScriptEngine.LSOEngine.LSO
|
||||
{
|
||||
public class Engine
|
||||
{
|
||||
//private string LSO_FileName = @"LSO\AdditionTest.lso";
|
||||
private string LSO_FileName; // = @"LSO\CloseToDefault.lso";
|
||||
private AppDomain appDomain;
|
||||
|
||||
public string Compile(string LSOFileName)
|
||||
{
|
||||
LSO_FileName = LSOFileName;
|
||||
|
||||
|
||||
//appDomain = AppDomain.CreateDomain("AlternateAppDomain");
|
||||
appDomain = Thread.GetDomain();
|
||||
|
||||
// Create Assembly Name
|
||||
AssemblyName asmName = new AssemblyName();
|
||||
asmName.Name = Path.GetFileNameWithoutExtension(LSO_FileName);
|
||||
//asmName.Name = "TestAssembly";
|
||||
|
||||
string DLL_FileName = asmName.Name + ".dll";
|
||||
string DLL_FileName_WithPath = Path.GetDirectoryName(LSO_FileName) + @"\" + DLL_FileName;
|
||||
|
||||
LSOEngine.LSO.Common.SendToLog("LSO File Name: " + Path.GetFileName(LSO_FileName));
|
||||
LSOEngine.LSO.Common.SendToLog("Assembly name: " + asmName.Name);
|
||||
LSOEngine.LSO.Common.SendToLog("Assembly File Name: " + asmName.Name + ".dll");
|
||||
LSOEngine.LSO.Common.SendToLog("Starting processing of LSL ByteCode...");
|
||||
LSOEngine.LSO.Common.SendToLog("");
|
||||
|
||||
|
||||
// Create Assembly
|
||||
AssemblyBuilder asmBuilder = appDomain.DefineDynamicAssembly(
|
||||
asmName,
|
||||
AssemblyBuilderAccess.RunAndSave
|
||||
);
|
||||
//// Create Assembly
|
||||
//AssemblyBuilder asmBuilder =
|
||||
// Thread.GetDomain().DefineDynamicAssembly
|
||||
//(asmName, AssemblyBuilderAccess.RunAndSave);
|
||||
|
||||
// Create a module (and save to disk)
|
||||
ModuleBuilder modBuilder = asmBuilder.DefineDynamicModule
|
||||
(asmName.Name,
|
||||
DLL_FileName);
|
||||
|
||||
//Common.SendToDebug("asmName.Name is still \"" + asmName.Name + "\"");
|
||||
// Create a Class (/Type)
|
||||
TypeBuilder typeBuilder = modBuilder.DefineType(
|
||||
"LSL_ScriptObject",
|
||||
TypeAttributes.Public | TypeAttributes.BeforeFieldInit,
|
||||
typeof (LSL_BaseClass));
|
||||
//,
|
||||
// typeof());
|
||||
//, typeof(LSL_BuiltIn_Commands_Interface));
|
||||
//,
|
||||
// typeof(object),
|
||||
// new Type[] { typeof(LSL_CLRInterface.LSLScript) });
|
||||
|
||||
|
||||
/*
|
||||
* Generate the IL itself
|
||||
*/
|
||||
|
||||
LSO_Parser LSOP = new LSO_Parser(LSO_FileName, typeBuilder);
|
||||
LSOP.OpenFile();
|
||||
LSOP.Parse();
|
||||
|
||||
// Constructor has to be created AFTER LSO_Parser because of accumulated variables
|
||||
if (LSOEngine.LSO.Common.IL_CreateConstructor)
|
||||
IL_CREATE_CONSTRUCTOR(typeBuilder, LSOP);
|
||||
|
||||
LSOP.CloseFile();
|
||||
/*
|
||||
* Done generating. Create a type and run it.
|
||||
*/
|
||||
|
||||
|
||||
LSOEngine.LSO.Common.SendToLog("Attempting to compile assembly...");
|
||||
// Compile it
|
||||
Type type = typeBuilder.CreateType();
|
||||
LSOEngine.LSO.Common.SendToLog("Compilation successful!");
|
||||
|
||||
LSOEngine.LSO.Common.SendToLog("Saving assembly: " + DLL_FileName);
|
||||
asmBuilder.Save(DLL_FileName);
|
||||
|
||||
LSOEngine.LSO.Common.SendToLog("Returning assembly filename: " + DLL_FileName);
|
||||
|
||||
|
||||
return DLL_FileName;
|
||||
|
||||
|
||||
//Common.SendToLog("Creating an instance of new assembly...");
|
||||
//// Create an instance we can play with
|
||||
////LSLScript hello = (LSLScript)Activator.CreateInstance(type);
|
||||
////LSL_CLRInterface.LSLScript MyScript = (LSL_CLRInterface.LSLScript)Activator.CreateInstance(type);
|
||||
//object MyScript = (object)Activator.CreateInstance(type);
|
||||
|
||||
|
||||
//System.Reflection.MemberInfo[] Members = type.GetMembers();
|
||||
|
||||
//Common.SendToLog("Members of assembly " + type.ToString() + ":");
|
||||
//foreach (MemberInfo member in Members)
|
||||
// Common.SendToLog(member.ToString());
|
||||
|
||||
|
||||
//// Play with it
|
||||
////MyScript.event_state_entry("Test");
|
||||
//object[] args = { null };
|
||||
////System.Collections.Generic.List<string> Functions = (System.Collections.Generic.List<string>)type.InvokeMember("GetFunctions", BindingFlags.InvokeMethod, null, MyScript, null);
|
||||
|
||||
//string[] ret = { };
|
||||
//if (Common.IL_CreateFunctionList)
|
||||
// ret = (string[])type.InvokeMember("GetFunctions", BindingFlags.InvokeMethod, null, MyScript, null);
|
||||
|
||||
//foreach (string s in ret)
|
||||
//{
|
||||
// Common.SendToLog("");
|
||||
// Common.SendToLog("*** Executing LSL Server Event: " + s);
|
||||
// //object test = type.GetMember(s);
|
||||
// //object runner = type.InvokeMember(s, BindingFlags.Public | BindingFlags.InvokeMethod | BindingFlags.Instance, null, MyScript, args);
|
||||
// //runner();
|
||||
// //objBooks_Late = type.InvokeMember(s, BindingFlags.CreateInstance, null, objApp_Late, null);
|
||||
// type.InvokeMember(s, BindingFlags.InvokeMethod, null, MyScript, new object[] { "Test" });
|
||||
|
||||
//}
|
||||
}
|
||||
|
||||
|
||||
private static void IL_CREATE_CONSTRUCTOR(TypeBuilder typeBuilder, LSO_Parser LSOP)
|
||||
{
|
||||
LSOEngine.LSO.Common.SendToDebug("IL_CREATE_CONSTRUCTOR()");
|
||||
//ConstructorBuilder constructor = typeBuilder.DefineConstructor(
|
||||
// MethodAttributes.Public,
|
||||
// CallingConventions.Standard,
|
||||
// new Type[0]);
|
||||
ConstructorBuilder constructor = typeBuilder.DefineConstructor(
|
||||
MethodAttributes.Public |
|
||||
MethodAttributes.SpecialName |
|
||||
MethodAttributes.RTSpecialName,
|
||||
CallingConventions.Standard,
|
||||
new Type[0]);
|
||||
|
||||
//Define the reflection ConstructorInfor for System.Object
|
||||
ConstructorInfo conObj = typeof (LSL_BaseClass).GetConstructor(new Type[0]);
|
||||
|
||||
//call constructor of base object
|
||||
ILGenerator il = constructor.GetILGenerator();
|
||||
|
||||
il.Emit(OpCodes.Ldarg_0);
|
||||
il.Emit(OpCodes.Call, conObj);
|
||||
|
||||
|
||||
//Common.SendToDebug("IL_CREATE_CONSTRUCTOR: Creating global: UInt32 State = 0;");
|
||||
//string FieldName;
|
||||
//// Create state object
|
||||
//FieldName = "State";
|
||||
//FieldBuilder State_fb = typeBuilder.DefineField(
|
||||
// FieldName,
|
||||
// typeof(UInt32),
|
||||
// FieldAttributes.Public);
|
||||
//il.Emit(OpCodes.Ldarg_0);
|
||||
//il.Emit(OpCodes.Ldc_I4, 0);
|
||||
//il.Emit(OpCodes.Stfld, State_fb);
|
||||
|
||||
|
||||
//Common.SendToDebug("IL_CREATE_CONSTRUCTOR: Creating global: LSL_BuiltIn_Commands_TestImplementation LSL_BuiltIns = New LSL_BuiltIn_Commands_TestImplementation();");
|
||||
////Type objType1 = typeof(object);
|
||||
//Type objType1 = typeof(LSL_BuiltIn_Commands_TestImplementation);
|
||||
|
||||
//FieldName = "LSL_BuiltIns";
|
||||
//FieldBuilder LSL_BuiltIns_fb = typeBuilder.DefineField(
|
||||
// FieldName,
|
||||
// objType1,
|
||||
// FieldAttributes.Public);
|
||||
|
||||
////LSL_BuiltIn_Commands_TestImplementation _ti = new LSL_BuiltIn_Commands_TestImplementation();
|
||||
//il.Emit(OpCodes.Ldarg_0);
|
||||
////il.Emit(OpCodes.Ldstr, "Test 123");
|
||||
//il.Emit(OpCodes.Newobj, objType1.GetConstructor(new Type[] { }));
|
||||
//il.Emit(OpCodes.Stfld, LSL_BuiltIns_fb);
|
||||
|
||||
foreach (UInt32 pos in LSOP.StaticBlocks.Keys)
|
||||
{
|
||||
LSO_Struct.StaticBlock sb;
|
||||
LSOP.StaticBlocks.TryGetValue(pos, out sb);
|
||||
|
||||
if (sb.ObjectType > 0 && sb.ObjectType < 8)
|
||||
{
|
||||
// We don't want void or null's
|
||||
|
||||
il.Emit(OpCodes.Ldarg_0);
|
||||
// Push position to stack
|
||||
il.Emit(OpCodes.Ldc_I4, pos);
|
||||
//il.Emit(OpCodes.Box, typeof(UInt32));
|
||||
|
||||
|
||||
Type datatype = null;
|
||||
|
||||
// Push data to stack
|
||||
LSOEngine.LSO.Common.SendToDebug("Adding to static (" + pos + ") type: " +
|
||||
((LSO_Enums.Variable_Type_Codes) sb.ObjectType).ToString() + " (" + sb.ObjectType +
|
||||
")");
|
||||
switch ((LSO_Enums.Variable_Type_Codes) sb.ObjectType)
|
||||
{
|
||||
case LSO_Enums.Variable_Type_Codes.Float:
|
||||
case LSO_Enums.Variable_Type_Codes.Integer:
|
||||
//UInt32
|
||||
il.Emit(OpCodes.Ldc_I4, BitConverter.ToUInt32(sb.BlockVariable, 0));
|
||||
datatype = typeof (UInt32);
|
||||
il.Emit(OpCodes.Box, datatype);
|
||||
break;
|
||||
case LSO_Enums.Variable_Type_Codes.String:
|
||||
case LSO_Enums.Variable_Type_Codes.Key:
|
||||
//String
|
||||
LSO_Struct.HeapBlock hb =
|
||||
LSOP.GetHeap(LSOP.myHeader.HR + BitConverter.ToUInt32(sb.BlockVariable, 0) - 1);
|
||||
il.Emit(OpCodes.Ldstr, Encoding.UTF8.GetString(hb.Data));
|
||||
datatype = typeof (string);
|
||||
break;
|
||||
case LSO_Enums.Variable_Type_Codes.Vector:
|
||||
datatype = typeof (LSO_Enums.Vector);
|
||||
//TODO: Not implemented
|
||||
break;
|
||||
case LSO_Enums.Variable_Type_Codes.Rotation:
|
||||
//Object
|
||||
//TODO: Not implemented
|
||||
datatype = typeof (LSO_Enums.Rotation);
|
||||
break;
|
||||
default:
|
||||
datatype = typeof (object);
|
||||
break;
|
||||
}
|
||||
|
||||
|
||||
// Make call
|
||||
il.Emit(OpCodes.Call,
|
||||
typeof (LSL_BaseClass).GetMethod("AddToStatic", new Type[] {typeof (UInt32), datatype}));
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
////il.Emit(OpCodes.Newobj, typeof(UInt32));
|
||||
//il.Emit(OpCodes.Starg_0);
|
||||
//// Create LSL function library
|
||||
//FieldBuilder LSL_BuiltIns_fb = typeBuilder.DefineField("LSL_BuiltIns", typeof(LSL_BuiltIn_Commands_Interface), FieldAttributes.Public);
|
||||
//il.Emit(OpCodes.Newobj, typeof(LSL_BuiltIn_Commands_Interface));
|
||||
//il.Emit(OpCodes.Stloc_1);
|
||||
|
||||
il.Emit(OpCodes.Ret);
|
||||
}
|
||||
|
||||
|
||||
// End of class
|
||||
}
|
||||
}
|
|
@ -1,51 +1,51 @@
|
|||
/*
|
||||
* Copyright (c) Contributors, http://opensimulator.org/
|
||||
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
* * Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* * Neither the name of the OpenSim Project nor the
|
||||
* names of its contributors may be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS AND ANY
|
||||
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
|
||||
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
*/
|
||||
/* Original code: Tedd Hansen */
|
||||
using System;
|
||||
using System.Reflection;
|
||||
using System.Reflection.Emit;
|
||||
|
||||
namespace OpenSim.Region.ScriptEngine.LSOEngine.LSO
|
||||
{
|
||||
internal partial class LSO_Parser
|
||||
{
|
||||
private static TypeBuilder CreateType(ModuleBuilder modBuilder, string typeName)
|
||||
{
|
||||
TypeBuilder typeBuilder = modBuilder.DefineType(typeName,
|
||||
TypeAttributes.Public |
|
||||
TypeAttributes.Class |
|
||||
TypeAttributes.AutoClass |
|
||||
TypeAttributes.AnsiClass |
|
||||
TypeAttributes.BeforeFieldInit |
|
||||
TypeAttributes.AutoLayout,
|
||||
typeof (object),
|
||||
new Type[] {typeof (object)});
|
||||
return typeBuilder;
|
||||
}
|
||||
}
|
||||
/*
|
||||
* Copyright (c) Contributors, http://opensimulator.org/
|
||||
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
* * Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* * Neither the name of the OpenSim Project nor the
|
||||
* names of its contributors may be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS AND ANY
|
||||
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
|
||||
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
*/
|
||||
/* Original code: Tedd Hansen */
|
||||
using System;
|
||||
using System.Reflection;
|
||||
using System.Reflection.Emit;
|
||||
|
||||
namespace OpenSim.Region.ScriptEngine.LSOEngine.LSO
|
||||
{
|
||||
internal partial class LSO_Parser
|
||||
{
|
||||
private static TypeBuilder CreateType(ModuleBuilder modBuilder, string typeName)
|
||||
{
|
||||
TypeBuilder typeBuilder = modBuilder.DefineType(typeName,
|
||||
TypeAttributes.Public |
|
||||
TypeAttributes.Class |
|
||||
TypeAttributes.AutoClass |
|
||||
TypeAttributes.AnsiClass |
|
||||
TypeAttributes.BeforeFieldInit |
|
||||
TypeAttributes.AutoLayout,
|
||||
typeof (object),
|
||||
new Type[] {typeof (object)});
|
||||
return typeBuilder;
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,395 +1,395 @@
|
|||
/*
|
||||
* Copyright (c) Contributors, http://opensimulator.org/
|
||||
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
* * Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* * Neither the name of the OpenSim Project nor the
|
||||
* names of its contributors may be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS AS IS AND ANY
|
||||
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
|
||||
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
*/
|
||||
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace OpenSim.Region.ScriptEngine.LSOEngine.LSO
|
||||
{
|
||||
//public partial class LSL_BaseClass
|
||||
//{
|
||||
// /*
|
||||
// * OPCODES
|
||||
// *
|
||||
// * These are internal "assembly" commands,
|
||||
// * basic operators like "ADD", "PUSH" and "POP"
|
||||
// *
|
||||
// * It also contains managed stack and keeps track of internal variables, etc.
|
||||
// *
|
||||
// */
|
||||
|
||||
|
||||
// public void StoreToLocal(UInt32 index)
|
||||
// {
|
||||
// // TODO: How to determine local?
|
||||
// LSOEngine.LSO.Common.SendToDebug("::StoreToLocal " + index);
|
||||
// if (LocalVariables.ContainsKey(index))
|
||||
// LocalVariables.Remove(index);
|
||||
// LocalVariables.Add(index, LSLStack.Peek());
|
||||
// }
|
||||
|
||||
// public void StoreToGlobal(UInt32 index)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::StoreToGlobal " + index);
|
||||
// if (GlobalVariables.ContainsKey(index))
|
||||
// GlobalVariables.Remove(index);
|
||||
// GlobalVariables.Add(index, LSLStack.Peek());
|
||||
// }
|
||||
|
||||
// public void StoreToStatic(UInt32 index)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::StoreToStatic " + index);
|
||||
// //if (StaticVariables.ContainsKey(index))
|
||||
// // StaticVariables.Remove(index);
|
||||
// StaticVariables.Add(index, LSLStack.Peek());
|
||||
// }
|
||||
|
||||
// public void GetFromLocal(UInt32 index)
|
||||
// {
|
||||
// // TODO: How to determine local?
|
||||
// LSOEngine.LSO.Common.SendToDebug("::GetFromLocal " + index);
|
||||
// object ret;
|
||||
// LocalVariables.TryGetValue(index, out ret);
|
||||
// LSLStack.Push(ret);
|
||||
// //return ret;
|
||||
// }
|
||||
|
||||
// public void GetFromGlobal(UInt32 index)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::GetFromGlobal " + index);
|
||||
// object ret;
|
||||
// GlobalVariables.TryGetValue(index, out ret);
|
||||
// LSLStack.Push(ret);
|
||||
// //return ret;
|
||||
// }
|
||||
|
||||
// public void GetFromStatic(UInt32 index)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::GetFromStatic " + index);
|
||||
// object ret;
|
||||
// StaticVariables.TryGetValue(index, out ret);
|
||||
// LSOEngine.LSO.Common.SendToDebug("::GetFromStatic - ObjectType: " + ret.GetType().ToString());
|
||||
// LSLStack.Push(ret);
|
||||
// //return ret;
|
||||
// }
|
||||
|
||||
// public object POPToStack()
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::POPToStack");
|
||||
// //return LSLStack.Pop();
|
||||
// object p = LSLStack.Pop();
|
||||
// if (p.GetType() == typeof (UInt32))
|
||||
// return (UInt32) p;
|
||||
// if (p.GetType() == typeof (string))
|
||||
// return (string) p;
|
||||
// if (p.GetType() == typeof (Int32))
|
||||
// return (Int32) p;
|
||||
// if (p.GetType() == typeof (UInt16))
|
||||
// return (UInt16) p;
|
||||
// if (p.GetType() == typeof (float))
|
||||
// return (float) p;
|
||||
// if (p.GetType() == typeof (LSO_Enums.Vector))
|
||||
// return (LSO_Enums.Vector) p;
|
||||
// if (p.GetType() == typeof (LSO_Enums.Rotation))
|
||||
// return (LSO_Enums.Rotation) p;
|
||||
// if (p.GetType() == typeof (LSO_Enums.Key))
|
||||
// return (LSO_Enums.Key) p;
|
||||
|
||||
// return p;
|
||||
// }
|
||||
|
||||
// //public object POPToStack(UInt32 count)
|
||||
// //{
|
||||
// // // POP NUMBER FROM TOP OF STACK
|
||||
// // //LSLStack.SetLength(LSLStack.Length - 4);
|
||||
// // Common.SendToDebug("::POPToStack " + count);
|
||||
// // if (count < 2)
|
||||
// // return LSLStack.Pop();
|
||||
|
||||
// // Stack<object> s = new Stack<object>();
|
||||
// // for (int i = 0; i < count; i++)
|
||||
// // {
|
||||
// // s.Push(LSLStack.Pop);
|
||||
|
||||
// // }
|
||||
|
||||
// //}
|
||||
|
||||
// public void POP()
|
||||
// {
|
||||
// // POP NUMBER FROM TOP OF STACK
|
||||
// //LSLStack.SetLength(LSLStack.Length - 4);
|
||||
// LSOEngine.LSO.Common.SendToDebug("::POP");
|
||||
// if (LSLStack.Count < 1)
|
||||
// {
|
||||
// //TODO: Temporary fix
|
||||
// LSOEngine.LSO.Common.SendToDebug("ERROR: TRYING TO POP EMPTY STACK!");
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// LSLStack.Pop();
|
||||
// }
|
||||
// }
|
||||
|
||||
// public void PUSH(object Param)
|
||||
// {
|
||||
// if (Param == null)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::PUSH: <null>");
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// //Common.SendToDebug("::PUSH: " + Param.GetType());
|
||||
// }
|
||||
|
||||
// LSLStack.Push(Param);
|
||||
// }
|
||||
|
||||
// public void ADD(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::ADD: " + Param);
|
||||
// object o2 = LSLStack.Pop();
|
||||
// object o1 = LSLStack.Pop();
|
||||
// LSOEngine.LSO.Common.SendToDebug("::ADD: Debug: o1: " + o1.GetType() + " (" + o1.ToString() + "), o2: " + o2.GetType() +
|
||||
// " (" + o2.ToString() + ")");
|
||||
// if (o2.GetType() == typeof (string))
|
||||
// {
|
||||
// LSLStack.Push((string) o1 + (string) o2);
|
||||
// return;
|
||||
// }
|
||||
// if (o2.GetType() == typeof (UInt32))
|
||||
// {
|
||||
// LSLStack.Push((UInt32) o1 + (UInt32) o2);
|
||||
// return;
|
||||
// }
|
||||
// }
|
||||
|
||||
// public void SUB(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::SUB: " + Param);
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// LSLStack.Push((UInt32) (i1 - i2));
|
||||
// }
|
||||
|
||||
// public void MUL(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::SUB: " + Param);
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// LSLStack.Push((UInt32) (i1*i2));
|
||||
// }
|
||||
|
||||
// public void DIV(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::DIV: " + Param);
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// LSLStack.Push((UInt32) (i1/i2));
|
||||
// }
|
||||
|
||||
|
||||
// public void MOD(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::MOD: " + Param);
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// LSLStack.Push((UInt32) (i1%i2));
|
||||
// }
|
||||
|
||||
// public void EQ(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::EQ: " + Param);
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// if (i1 == i2)
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 1);
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 0);
|
||||
// }
|
||||
// }
|
||||
|
||||
// public void NEQ(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::NEQ: " + Param);
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// if (i1 != i2)
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 1);
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 0);
|
||||
// }
|
||||
// }
|
||||
|
||||
// public void LEQ(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::LEQ: " + Param);
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// if (i1 <= i2)
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 1);
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 0);
|
||||
// }
|
||||
// }
|
||||
|
||||
// public void GEQ(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::GEQ: " + Param);
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// if (i1 >= i2)
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 1);
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 0);
|
||||
// }
|
||||
// }
|
||||
|
||||
// public void LESS(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::LESS: " + Param);
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// if (i1 < i2)
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 1);
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 0);
|
||||
// }
|
||||
// }
|
||||
|
||||
// public void GREATER(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::GREATER: " + Param);
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// if (i1 > i2)
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 1);
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 0);
|
||||
// }
|
||||
// }
|
||||
|
||||
|
||||
// public void BITAND()
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::BITAND");
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// LSLStack.Push((UInt32) (i1 & i2));
|
||||
// }
|
||||
|
||||
// public void BITOR()
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::BITOR");
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// LSLStack.Push((UInt32) (i1 | i2));
|
||||
// }
|
||||
|
||||
// public void BITXOR()
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::BITXOR");
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// LSLStack.Push((UInt32) (i1 ^ i2));
|
||||
// }
|
||||
|
||||
// public void BOOLAND()
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::BOOLAND");
|
||||
// bool b2 = bool.Parse((string) LSLStack.Pop());
|
||||
// bool b1 = bool.Parse((string) LSLStack.Pop());
|
||||
// if (b1 && b2)
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 1);
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 0);
|
||||
// }
|
||||
// }
|
||||
|
||||
// public void BOOLOR()
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::BOOLOR");
|
||||
// bool b2 = bool.Parse((string) LSLStack.Pop());
|
||||
// bool b1 = bool.Parse((string) LSLStack.Pop());
|
||||
|
||||
// if (b1 || b2)
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 1);
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 0);
|
||||
// }
|
||||
// }
|
||||
|
||||
// public void NEG(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::NEG: " + Param);
|
||||
// //UInt32 i2 = (UInt32)LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// LSLStack.Push((UInt32) (i1*-1));
|
||||
// }
|
||||
|
||||
// public void BITNOT()
|
||||
// {
|
||||
// //Common.SendToDebug("::BITNOT");
|
||||
// //UInt32 i2 = (UInt32)LSLStack.Pop();
|
||||
// //UInt32 i1 = (UInt32)LSLStack.Pop();
|
||||
// //LSLStack.Push((UInt32)(i1 / i2));
|
||||
// }
|
||||
|
||||
// public void BOOLNOT()
|
||||
// {
|
||||
// //Common.SendToDebug("::BOOLNOT");
|
||||
// ////UInt32 i2 = (UInt32)LSLStack.Pop();
|
||||
// //UInt32 i1 = (UInt32)LSLStack.Pop();
|
||||
// //LSLStack.Push((UInt32)(i1));
|
||||
// }
|
||||
//}
|
||||
/*
|
||||
* Copyright (c) Contributors, http://opensimulator.org/
|
||||
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
* * Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* * Neither the name of the OpenSim Project nor the
|
||||
* names of its contributors may be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS AS IS AND ANY
|
||||
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
|
||||
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
*/
|
||||
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace OpenSim.Region.ScriptEngine.LSOEngine.LSO
|
||||
{
|
||||
//public partial class LSL_BaseClass
|
||||
//{
|
||||
// /*
|
||||
// * OPCODES
|
||||
// *
|
||||
// * These are internal "assembly" commands,
|
||||
// * basic operators like "ADD", "PUSH" and "POP"
|
||||
// *
|
||||
// * It also contains managed stack and keeps track of internal variables, etc.
|
||||
// *
|
||||
// */
|
||||
|
||||
|
||||
// public void StoreToLocal(UInt32 index)
|
||||
// {
|
||||
// // TODO: How to determine local?
|
||||
// LSOEngine.LSO.Common.SendToDebug("::StoreToLocal " + index);
|
||||
// if (LocalVariables.ContainsKey(index))
|
||||
// LocalVariables.Remove(index);
|
||||
// LocalVariables.Add(index, LSLStack.Peek());
|
||||
// }
|
||||
|
||||
// public void StoreToGlobal(UInt32 index)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::StoreToGlobal " + index);
|
||||
// if (GlobalVariables.ContainsKey(index))
|
||||
// GlobalVariables.Remove(index);
|
||||
// GlobalVariables.Add(index, LSLStack.Peek());
|
||||
// }
|
||||
|
||||
// public void StoreToStatic(UInt32 index)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::StoreToStatic " + index);
|
||||
// //if (StaticVariables.ContainsKey(index))
|
||||
// // StaticVariables.Remove(index);
|
||||
// StaticVariables.Add(index, LSLStack.Peek());
|
||||
// }
|
||||
|
||||
// public void GetFromLocal(UInt32 index)
|
||||
// {
|
||||
// // TODO: How to determine local?
|
||||
// LSOEngine.LSO.Common.SendToDebug("::GetFromLocal " + index);
|
||||
// object ret;
|
||||
// LocalVariables.TryGetValue(index, out ret);
|
||||
// LSLStack.Push(ret);
|
||||
// //return ret;
|
||||
// }
|
||||
|
||||
// public void GetFromGlobal(UInt32 index)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::GetFromGlobal " + index);
|
||||
// object ret;
|
||||
// GlobalVariables.TryGetValue(index, out ret);
|
||||
// LSLStack.Push(ret);
|
||||
// //return ret;
|
||||
// }
|
||||
|
||||
// public void GetFromStatic(UInt32 index)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::GetFromStatic " + index);
|
||||
// object ret;
|
||||
// StaticVariables.TryGetValue(index, out ret);
|
||||
// LSOEngine.LSO.Common.SendToDebug("::GetFromStatic - ObjectType: " + ret.GetType().ToString());
|
||||
// LSLStack.Push(ret);
|
||||
// //return ret;
|
||||
// }
|
||||
|
||||
// public object POPToStack()
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::POPToStack");
|
||||
// //return LSLStack.Pop();
|
||||
// object p = LSLStack.Pop();
|
||||
// if (p.GetType() == typeof (UInt32))
|
||||
// return (UInt32) p;
|
||||
// if (p.GetType() == typeof (string))
|
||||
// return (string) p;
|
||||
// if (p.GetType() == typeof (Int32))
|
||||
// return (Int32) p;
|
||||
// if (p.GetType() == typeof (UInt16))
|
||||
// return (UInt16) p;
|
||||
// if (p.GetType() == typeof (float))
|
||||
// return (float) p;
|
||||
// if (p.GetType() == typeof (LSO_Enums.Vector))
|
||||
// return (LSO_Enums.Vector) p;
|
||||
// if (p.GetType() == typeof (LSO_Enums.Rotation))
|
||||
// return (LSO_Enums.Rotation) p;
|
||||
// if (p.GetType() == typeof (LSO_Enums.Key))
|
||||
// return (LSO_Enums.Key) p;
|
||||
|
||||
// return p;
|
||||
// }
|
||||
|
||||
// //public object POPToStack(UInt32 count)
|
||||
// //{
|
||||
// // // POP NUMBER FROM TOP OF STACK
|
||||
// // //LSLStack.SetLength(LSLStack.Length - 4);
|
||||
// // Common.SendToDebug("::POPToStack " + count);
|
||||
// // if (count < 2)
|
||||
// // return LSLStack.Pop();
|
||||
|
||||
// // Stack<object> s = new Stack<object>();
|
||||
// // for (int i = 0; i < count; i++)
|
||||
// // {
|
||||
// // s.Push(LSLStack.Pop);
|
||||
|
||||
// // }
|
||||
|
||||
// //}
|
||||
|
||||
// public void POP()
|
||||
// {
|
||||
// // POP NUMBER FROM TOP OF STACK
|
||||
// //LSLStack.SetLength(LSLStack.Length - 4);
|
||||
// LSOEngine.LSO.Common.SendToDebug("::POP");
|
||||
// if (LSLStack.Count < 1)
|
||||
// {
|
||||
// //TODO: Temporary fix
|
||||
// LSOEngine.LSO.Common.SendToDebug("ERROR: TRYING TO POP EMPTY STACK!");
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// LSLStack.Pop();
|
||||
// }
|
||||
// }
|
||||
|
||||
// public void PUSH(object Param)
|
||||
// {
|
||||
// if (Param == null)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::PUSH: <null>");
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// //Common.SendToDebug("::PUSH: " + Param.GetType());
|
||||
// }
|
||||
|
||||
// LSLStack.Push(Param);
|
||||
// }
|
||||
|
||||
// public void ADD(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::ADD: " + Param);
|
||||
// object o2 = LSLStack.Pop();
|
||||
// object o1 = LSLStack.Pop();
|
||||
// LSOEngine.LSO.Common.SendToDebug("::ADD: Debug: o1: " + o1.GetType() + " (" + o1.ToString() + "), o2: " + o2.GetType() +
|
||||
// " (" + o2.ToString() + ")");
|
||||
// if (o2.GetType() == typeof (string))
|
||||
// {
|
||||
// LSLStack.Push((string) o1 + (string) o2);
|
||||
// return;
|
||||
// }
|
||||
// if (o2.GetType() == typeof (UInt32))
|
||||
// {
|
||||
// LSLStack.Push((UInt32) o1 + (UInt32) o2);
|
||||
// return;
|
||||
// }
|
||||
// }
|
||||
|
||||
// public void SUB(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::SUB: " + Param);
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// LSLStack.Push((UInt32) (i1 - i2));
|
||||
// }
|
||||
|
||||
// public void MUL(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::SUB: " + Param);
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// LSLStack.Push((UInt32) (i1*i2));
|
||||
// }
|
||||
|
||||
// public void DIV(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::DIV: " + Param);
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// LSLStack.Push((UInt32) (i1/i2));
|
||||
// }
|
||||
|
||||
|
||||
// public void MOD(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::MOD: " + Param);
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// LSLStack.Push((UInt32) (i1%i2));
|
||||
// }
|
||||
|
||||
// public void EQ(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::EQ: " + Param);
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// if (i1 == i2)
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 1);
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 0);
|
||||
// }
|
||||
// }
|
||||
|
||||
// public void NEQ(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::NEQ: " + Param);
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// if (i1 != i2)
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 1);
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 0);
|
||||
// }
|
||||
// }
|
||||
|
||||
// public void LEQ(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::LEQ: " + Param);
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// if (i1 <= i2)
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 1);
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 0);
|
||||
// }
|
||||
// }
|
||||
|
||||
// public void GEQ(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::GEQ: " + Param);
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// if (i1 >= i2)
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 1);
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 0);
|
||||
// }
|
||||
// }
|
||||
|
||||
// public void LESS(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::LESS: " + Param);
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// if (i1 < i2)
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 1);
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 0);
|
||||
// }
|
||||
// }
|
||||
|
||||
// public void GREATER(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::GREATER: " + Param);
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// if (i1 > i2)
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 1);
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 0);
|
||||
// }
|
||||
// }
|
||||
|
||||
|
||||
// public void BITAND()
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::BITAND");
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// LSLStack.Push((UInt32) (i1 & i2));
|
||||
// }
|
||||
|
||||
// public void BITOR()
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::BITOR");
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// LSLStack.Push((UInt32) (i1 | i2));
|
||||
// }
|
||||
|
||||
// public void BITXOR()
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::BITXOR");
|
||||
// UInt32 i2 = (UInt32) LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// LSLStack.Push((UInt32) (i1 ^ i2));
|
||||
// }
|
||||
|
||||
// public void BOOLAND()
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::BOOLAND");
|
||||
// bool b2 = bool.Parse((string) LSLStack.Pop());
|
||||
// bool b1 = bool.Parse((string) LSLStack.Pop());
|
||||
// if (b1 && b2)
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 1);
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 0);
|
||||
// }
|
||||
// }
|
||||
|
||||
// public void BOOLOR()
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::BOOLOR");
|
||||
// bool b2 = bool.Parse((string) LSLStack.Pop());
|
||||
// bool b1 = bool.Parse((string) LSLStack.Pop());
|
||||
|
||||
// if (b1 || b2)
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 1);
|
||||
// }
|
||||
// else
|
||||
// {
|
||||
// LSLStack.Push((UInt32) 0);
|
||||
// }
|
||||
// }
|
||||
|
||||
// public void NEG(UInt32 Param)
|
||||
// {
|
||||
// LSOEngine.LSO.Common.SendToDebug("::NEG: " + Param);
|
||||
// //UInt32 i2 = (UInt32)LSLStack.Pop();
|
||||
// UInt32 i1 = (UInt32) LSLStack.Pop();
|
||||
// LSLStack.Push((UInt32) (i1*-1));
|
||||
// }
|
||||
|
||||
// public void BITNOT()
|
||||
// {
|
||||
// //Common.SendToDebug("::BITNOT");
|
||||
// //UInt32 i2 = (UInt32)LSLStack.Pop();
|
||||
// //UInt32 i1 = (UInt32)LSLStack.Pop();
|
||||
// //LSLStack.Push((UInt32)(i1 / i2));
|
||||
// }
|
||||
|
||||
// public void BOOLNOT()
|
||||
// {
|
||||
// //Common.SendToDebug("::BOOLNOT");
|
||||
// ////UInt32 i2 = (UInt32)LSLStack.Pop();
|
||||
// //UInt32 i1 = (UInt32)LSLStack.Pop();
|
||||
// //LSLStack.Push((UInt32)(i1));
|
||||
// }
|
||||
//}
|
||||
}
|
|
@ -1,75 +1,75 @@
|
|||
/*
|
||||
* Copyright (c) Contributors, http://opensimulator.org/
|
||||
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
* * Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* * Neither the name of the OpenSim Project nor the
|
||||
* names of its contributors may be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS AND ANY
|
||||
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
|
||||
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
*/
|
||||
/* Original code: Tedd Hansen */
|
||||
namespace OpenSim.Region.ScriptEngine.LSOEngine.LSO
|
||||
{
|
||||
public class LSL_CLRInterface
|
||||
{
|
||||
public interface LSLScript
|
||||
{
|
||||
//public virtual void Run(object arg)
|
||||
//{
|
||||
//}
|
||||
//void Run(object arg);
|
||||
|
||||
//void event_state_entry(object arg);
|
||||
//void event_state_exit();
|
||||
//void event_touch_start(object arg);
|
||||
//void event_touch();
|
||||
//void event_touch_end();
|
||||
//void event_collision_start();
|
||||
//void event_collision();
|
||||
//void event_collision_end();
|
||||
//void event_land_collision_start();
|
||||
//void event_land_collision();
|
||||
//void event_land_collision_end();
|
||||
//void event_timer();
|
||||
//void event_listen();
|
||||
//void event_on_rez();
|
||||
//void event_sensor();
|
||||
//void event_no_sensor();
|
||||
//void event_control();
|
||||
//void event_money();
|
||||
//void event_email();
|
||||
//void event_at_target();
|
||||
//void event_not_at_target();
|
||||
//void event_at_rot_target();
|
||||
//void event_not_at_rot_target();
|
||||
//void event_run_time_permissions();
|
||||
//void event_changed();
|
||||
//void event_attach();
|
||||
//void event_dataserver();
|
||||
//void event_link_message();
|
||||
//void event_moving_start();
|
||||
//void event_moving_end();
|
||||
//void event_object_rez();
|
||||
//void event_remote_data();
|
||||
//void event_http_response();
|
||||
}
|
||||
}
|
||||
/*
|
||||
* Copyright (c) Contributors, http://opensimulator.org/
|
||||
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
* * Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* * Neither the name of the OpenSim Project nor the
|
||||
* names of its contributors may be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS AND ANY
|
||||
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
|
||||
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
*/
|
||||
/* Original code: Tedd Hansen */
|
||||
namespace OpenSim.Region.ScriptEngine.LSOEngine.LSO
|
||||
{
|
||||
public class LSL_CLRInterface
|
||||
{
|
||||
public interface LSLScript
|
||||
{
|
||||
//public virtual void Run(object arg)
|
||||
//{
|
||||
//}
|
||||
//void Run(object arg);
|
||||
|
||||
//void event_state_entry(object arg);
|
||||
//void event_state_exit();
|
||||
//void event_touch_start(object arg);
|
||||
//void event_touch();
|
||||
//void event_touch_end();
|
||||
//void event_collision_start();
|
||||
//void event_collision();
|
||||
//void event_collision_end();
|
||||
//void event_land_collision_start();
|
||||
//void event_land_collision();
|
||||
//void event_land_collision_end();
|
||||
//void event_timer();
|
||||
//void event_listen();
|
||||
//void event_on_rez();
|
||||
//void event_sensor();
|
||||
//void event_no_sensor();
|
||||
//void event_control();
|
||||
//void event_money();
|
||||
//void event_email();
|
||||
//void event_at_target();
|
||||
//void event_not_at_target();
|
||||
//void event_at_rot_target();
|
||||
//void event_not_at_rot_target();
|
||||
//void event_run_time_permissions();
|
||||
//void event_changed();
|
||||
//void event_attach();
|
||||
//void event_dataserver();
|
||||
//void event_link_message();
|
||||
//void event_moving_start();
|
||||
//void event_moving_end();
|
||||
//void event_object_rez();
|
||||
//void event_remote_data();
|
||||
//void event_http_response();
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,435 +1,435 @@
|
|||
/*
|
||||
* Copyright (c) Contributors, http://opensimulator.org/
|
||||
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
* * Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* * Neither the name of the OpenSim Project nor the
|
||||
* names of its contributors may be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS AND ANY
|
||||
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
|
||||
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
*/
|
||||
/* Original code: Tedd Hansen */
|
||||
using System;
|
||||
using System.Reflection;
|
||||
using System.Reflection.Emit;
|
||||
using OpenSim.Region.ScriptEngine.Common;
|
||||
|
||||
namespace OpenSim.Region.ScriptEngine.LSOEngine.LSO
|
||||
{
|
||||
internal partial class LSO_Parser
|
||||
{
|
||||
//internal Stack<Type> ILStack = new Stack<Type>();
|
||||
//LSO_Enums MyLSO_Enums = new LSO_Enums();
|
||||
|
||||
internal bool LSL_PROCESS_OPCODE(ILGenerator il)
|
||||
{
|
||||
byte bp1;
|
||||
UInt32 u32p1;
|
||||
float fp1;
|
||||
UInt16 opcode = br_read(1)[0];
|
||||
Common.SendToDebug("OPCODE: " + ((LSO_Enums.Operation_Table) opcode).ToString());
|
||||
string idesc = ((LSO_Enums.Operation_Table) opcode).ToString();
|
||||
switch ((LSO_Enums.Operation_Table) opcode)
|
||||
{
|
||||
/***************
|
||||
* IMPLEMENTED *
|
||||
***************/
|
||||
case LSO_Enums.Operation_Table.NOOP:
|
||||
break;
|
||||
case LSO_Enums.Operation_Table.PUSHSP:
|
||||
// Push Stack Top (Memory Address) to stack
|
||||
Common.SendToDebug("Instruction " + idesc);
|
||||
Common.SendToDebug("Instruction " + idesc +
|
||||
": Description: Pushing Stack Top (Memory Address from header) to stack");
|
||||
IL_Push(il, (UInt32) myHeader.SP);
|
||||
break;
|
||||
// BYTE
|
||||
case LSO_Enums.Operation_Table.PUSHARGB:
|
||||
Common.SendToDebug("Param1: " + br_read(1)[0]);
|
||||
break;
|
||||
// INTEGER
|
||||
case LSO_Enums.Operation_Table.PUSHARGI:
|
||||
u32p1 = BitConverter.ToUInt32(br_read(4), 0);
|
||||
Common.SendToDebug("Instruction " + idesc + ", Param1: " + u32p1);
|
||||
IL_Push(il, u32p1);
|
||||
break;
|
||||
// FLOAT
|
||||
case LSO_Enums.Operation_Table.PUSHARGF:
|
||||
fp1 = BitConverter.ToUInt32(br_read(4), 0);
|
||||
Common.SendToDebug("Instruction " + idesc + ", Param1: " + fp1);
|
||||
IL_Push(il, fp1);
|
||||
break;
|
||||
// STRING
|
||||
case LSO_Enums.Operation_Table.PUSHARGS:
|
||||
string s = Read_String();
|
||||
Common.SendToDebug("Instruction " + idesc + ", Param1: " + s);
|
||||
IL_Debug(il, "OPCODE: " + idesc + ":" + s);
|
||||
IL_Push(il, s);
|
||||
break;
|
||||
// VECTOR z,y,x
|
||||
case LSO_Enums.Operation_Table.PUSHARGV:
|
||||
LSO_Enums.Vector v = new LSO_Enums.Vector();
|
||||
v.Z = BitConverter.ToUInt32(br_read(4), 0);
|
||||
v.Y = BitConverter.ToUInt32(br_read(4), 0);
|
||||
v.X = BitConverter.ToUInt32(br_read(4), 0);
|
||||
Common.SendToDebug("Param1 Z: " + v.Z);
|
||||
Common.SendToDebug("Param1 Y: " + v.Y);
|
||||
Common.SendToDebug("Param1 X: " + v.X);
|
||||
IL_Push(il, v);
|
||||
break;
|
||||
// ROTATION s,z,y,x
|
||||
case LSO_Enums.Operation_Table.PUSHARGQ:
|
||||
LSO_Enums.Rotation r = new LSO_Enums.Rotation();
|
||||
r.S = BitConverter.ToUInt32(br_read(4), 0);
|
||||
r.Z = BitConverter.ToUInt32(br_read(4), 0);
|
||||
r.Y = BitConverter.ToUInt32(br_read(4), 0);
|
||||
r.X = BitConverter.ToUInt32(br_read(4), 0);
|
||||
Common.SendToDebug("Param1 S: " + r.S);
|
||||
Common.SendToDebug("Param1 Z: " + r.Z);
|
||||
Common.SendToDebug("Param1 Y: " + r.Y);
|
||||
Common.SendToDebug("Param1 X: " + r.X);
|
||||
IL_Push(il, r);
|
||||
break;
|
||||
|
||||
case LSO_Enums.Operation_Table.PUSHE:
|
||||
IL_Push(il, (UInt32) 0);
|
||||
break;
|
||||
|
||||
case LSO_Enums.Operation_Table.PUSHARGE:
|
||||
u32p1 = BitConverter.ToUInt32(br_read(4), 0);
|
||||
Common.SendToDebug("Param1: " + u32p1);
|
||||
//IL_Push(il, new string(" ".ToCharArray()[0], Convert.ToInt32(u32p1)));
|
||||
IL_Push(il, u32p1);
|
||||
break;
|
||||
// BYTE
|
||||
case LSO_Enums.Operation_Table.ADD:
|
||||
case LSO_Enums.Operation_Table.SUB:
|
||||
case LSO_Enums.Operation_Table.MUL:
|
||||
case LSO_Enums.Operation_Table.DIV:
|
||||
case LSO_Enums.Operation_Table.EQ:
|
||||
case LSO_Enums.Operation_Table.NEQ:
|
||||
case LSO_Enums.Operation_Table.LEQ:
|
||||
case LSO_Enums.Operation_Table.GEQ:
|
||||
case LSO_Enums.Operation_Table.LESS:
|
||||
case LSO_Enums.Operation_Table.GREATER:
|
||||
case LSO_Enums.Operation_Table.NEG:
|
||||
case LSO_Enums.Operation_Table.MOD:
|
||||
bp1 = br_read(1)[0];
|
||||
Common.SendToDebug("Param1: " + bp1);
|
||||
IL_CallBaseFunction(il, idesc, (UInt32) bp1);
|
||||
break;
|
||||
|
||||
// NO ARGUMENTS
|
||||
case LSO_Enums.Operation_Table.BITAND:
|
||||
case LSO_Enums.Operation_Table.BITOR:
|
||||
case LSO_Enums.Operation_Table.BITXOR:
|
||||
case LSO_Enums.Operation_Table.BOOLAND:
|
||||
case LSO_Enums.Operation_Table.BOOLOR:
|
||||
case LSO_Enums.Operation_Table.BITNOT:
|
||||
case LSO_Enums.Operation_Table.BOOLNOT:
|
||||
IL_CallBaseFunction(il, idesc);
|
||||
break;
|
||||
// SHORT
|
||||
case LSO_Enums.Operation_Table.CALLLIB_TWO_BYTE:
|
||||
// TODO: What is size of short?
|
||||
UInt16 U16p1 = BitConverter.ToUInt16(br_read(2), 0);
|
||||
Common.SendToDebug("Instruction " + idesc + ": Builtin Command: " +
|
||||
((LSO_Enums.BuiltIn_Functions) U16p1).ToString());
|
||||
//Common.SendToDebug("Param1: " + U16p1);
|
||||
string fname = ((LSO_Enums.BuiltIn_Functions) U16p1).ToString();
|
||||
|
||||
bool cmdFound = false;
|
||||
foreach (MethodInfo mi in typeof (LSL_BuiltIn_Commands_Interface).GetMethods())
|
||||
{
|
||||
// Found command
|
||||
if (mi.Name == fname)
|
||||
{
|
||||
il.Emit(OpCodes.Ldarg_0);
|
||||
il.Emit(OpCodes.Call, typeof (LSL_BaseClass).GetMethod("GetLSL_BuiltIn", new Type[] {}));
|
||||
// Pop required number of items from my stack to .Net stack
|
||||
IL_PopToStack(il, mi.GetParameters().Length);
|
||||
il.Emit(OpCodes.Callvirt, mi);
|
||||
cmdFound = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (cmdFound == false)
|
||||
{
|
||||
Common.SendToDebug("ERROR: UNABLE TO LOCATE OPCODE " + idesc + " IN BASECLASS");
|
||||
}
|
||||
|
||||
break;
|
||||
|
||||
// RETURN
|
||||
case LSO_Enums.Operation_Table.RETURN:
|
||||
|
||||
Common.SendToDebug("OPCODE: RETURN");
|
||||
return true;
|
||||
|
||||
case LSO_Enums.Operation_Table.POP:
|
||||
case LSO_Enums.Operation_Table.POPS:
|
||||
case LSO_Enums.Operation_Table.POPL:
|
||||
case LSO_Enums.Operation_Table.POPV:
|
||||
case LSO_Enums.Operation_Table.POPQ:
|
||||
// Pops a specific datatype from the stack
|
||||
// We just ignore the datatype for now
|
||||
IL_Pop(il);
|
||||
break;
|
||||
|
||||
// LONG
|
||||
case LSO_Enums.Operation_Table.STORE:
|
||||
case LSO_Enums.Operation_Table.STORES:
|
||||
case LSO_Enums.Operation_Table.STOREL:
|
||||
case LSO_Enums.Operation_Table.STOREV:
|
||||
case LSO_Enums.Operation_Table.STOREQ:
|
||||
u32p1 = BitConverter.ToUInt32(br_read(4), 0);
|
||||
Common.SendToDebug("Param1: " + u32p1.ToString());
|
||||
IL_CallBaseFunction(il, "StoreToLocal", u32p1);
|
||||
break;
|
||||
|
||||
case LSO_Enums.Operation_Table.STOREG:
|
||||
case LSO_Enums.Operation_Table.STOREGS:
|
||||
case LSO_Enums.Operation_Table.STOREGL:
|
||||
case LSO_Enums.Operation_Table.STOREGV:
|
||||
case LSO_Enums.Operation_Table.STOREGQ:
|
||||
u32p1 = BitConverter.ToUInt32(br_read(4), 0);
|
||||
Common.SendToDebug("Param1: " + u32p1.ToString());
|
||||
IL_CallBaseFunction(il, "StoreToGlobal", u32p1);
|
||||
break;
|
||||
|
||||
case LSO_Enums.Operation_Table.LOADP:
|
||||
case LSO_Enums.Operation_Table.LOADSP:
|
||||
case LSO_Enums.Operation_Table.LOADLP:
|
||||
case LSO_Enums.Operation_Table.LOADVP:
|
||||
case LSO_Enums.Operation_Table.LOADQP:
|
||||
u32p1 = BitConverter.ToUInt32(br_read(4), 0);
|
||||
Common.SendToDebug("Param1: " + u32p1.ToString());
|
||||
IL_CallBaseFunction(il, "StoreToLocal", u32p1);
|
||||
IL_Pop(il);
|
||||
break;
|
||||
|
||||
case LSO_Enums.Operation_Table.LOADGP:
|
||||
case LSO_Enums.Operation_Table.LOADGSP:
|
||||
case LSO_Enums.Operation_Table.LOADGLP:
|
||||
case LSO_Enums.Operation_Table.LOADGVP:
|
||||
case LSO_Enums.Operation_Table.LOADGQP:
|
||||
u32p1 = BitConverter.ToUInt32(br_read(4), 0);
|
||||
Common.SendToDebug("Param1: " + u32p1.ToString());
|
||||
IL_CallBaseFunction(il, "StoreToStatic", u32p1 - 6 + myHeader.GVR);
|
||||
IL_Pop(il);
|
||||
break;
|
||||
|
||||
// PUSH FROM LOCAL FRAME
|
||||
case LSO_Enums.Operation_Table.PUSH:
|
||||
case LSO_Enums.Operation_Table.PUSHS:
|
||||
case LSO_Enums.Operation_Table.PUSHL:
|
||||
case LSO_Enums.Operation_Table.PUSHV:
|
||||
case LSO_Enums.Operation_Table.PUSHQ:
|
||||
u32p1 = BitConverter.ToUInt32(br_read(4), 0);
|
||||
Common.SendToDebug("Param1: " + u32p1.ToString());
|
||||
IL_CallBaseFunction(il, "GetFromLocal", u32p1);
|
||||
|
||||
break;
|
||||
|
||||
// PUSH FROM STATIC FRAME
|
||||
case LSO_Enums.Operation_Table.PUSHG:
|
||||
case LSO_Enums.Operation_Table.PUSHGS:
|
||||
case LSO_Enums.Operation_Table.PUSHGL:
|
||||
case LSO_Enums.Operation_Table.PUSHGV:
|
||||
case LSO_Enums.Operation_Table.PUSHGQ:
|
||||
u32p1 = BitConverter.ToUInt32(br_read(4), 0);
|
||||
Common.SendToDebug("Param1: " + u32p1.ToString());
|
||||
IL_CallBaseFunction(il, "GetFromStatic", u32p1 - 6 + myHeader.GVR);
|
||||
break;
|
||||
|
||||
|
||||
/***********************
|
||||
* NOT IMPLEMENTED YET *
|
||||
***********************/
|
||||
|
||||
|
||||
case LSO_Enums.Operation_Table.POPIP:
|
||||
case LSO_Enums.Operation_Table.POPSP:
|
||||
case LSO_Enums.Operation_Table.POPSLR:
|
||||
case LSO_Enums.Operation_Table.POPARG:
|
||||
case LSO_Enums.Operation_Table.POPBP:
|
||||
//Common.SendToDebug("Instruction " + idesc + ": Ignored");
|
||||
Common.SendToDebug("Instruction " + idesc +
|
||||
": Description: Drop x bytes from the stack (TODO: Only popping 1)");
|
||||
//Common.SendToDebug("Param1: " + BitConverter.ToUInt32(br_read(4), 0));
|
||||
IL_Pop(il);
|
||||
break;
|
||||
|
||||
|
||||
// None
|
||||
case LSO_Enums.Operation_Table.PUSHIP:
|
||||
// PUSH INSTRUCTION POINTER
|
||||
break;
|
||||
case LSO_Enums.Operation_Table.PUSHBP:
|
||||
|
||||
case LSO_Enums.Operation_Table.PUSHEV:
|
||||
break;
|
||||
case LSO_Enums.Operation_Table.PUSHEQ:
|
||||
break;
|
||||
|
||||
|
||||
// LONG
|
||||
case LSO_Enums.Operation_Table.JUMP:
|
||||
Common.SendToDebug("Param1: " + BitConverter.ToUInt32(br_read(4), 0));
|
||||
break;
|
||||
// BYTE, LONG
|
||||
case LSO_Enums.Operation_Table.JUMPIF:
|
||||
case LSO_Enums.Operation_Table.JUMPNIF:
|
||||
Common.SendToDebug("Param1: " + br_read(1)[0]);
|
||||
Common.SendToDebug("Param2: " + BitConverter.ToUInt32(br_read(4), 0));
|
||||
break;
|
||||
// LONG
|
||||
case LSO_Enums.Operation_Table.STATE:
|
||||
bp1 = br_read(1)[0];
|
||||
//il.Emit(OpCodes.Ld); // Load local variable 0 onto stack
|
||||
//il.Emit(OpCodes.Ldc_I4, 0); // Push index position
|
||||
//il.Emit(OpCodes.Ldstr, EventList[p1]); // Push value
|
||||
//il.Emit(OpCodes.Stelem_Ref); // Perform array[index] = value
|
||||
break;
|
||||
case LSO_Enums.Operation_Table.CALL:
|
||||
Common.SendToDebug("Param1: " + BitConverter.ToUInt32(br_read(4), 0));
|
||||
Common.SendToDebug("ERROR: Function CALL not implemented yet.");
|
||||
break;
|
||||
// BYTE
|
||||
case LSO_Enums.Operation_Table.CAST:
|
||||
bp1 = br_read(1)[0];
|
||||
Common.SendToDebug("Instruction " + idesc + ": Cast to type: " +
|
||||
((LSO_Enums.OpCode_Cast_TypeDefs) bp1));
|
||||
Common.SendToDebug("Param1: " + bp1);
|
||||
switch ((LSO_Enums.OpCode_Cast_TypeDefs) bp1)
|
||||
{
|
||||
case LSO_Enums.OpCode_Cast_TypeDefs.String:
|
||||
Common.SendToDebug("Instruction " + idesc + ": il.Emit(OpCodes.Box, ILStack.Pop());");
|
||||
break;
|
||||
default:
|
||||
Common.SendToDebug("Instruction " + idesc + ": Unknown cast type!");
|
||||
break;
|
||||
}
|
||||
break;
|
||||
// LONG
|
||||
case LSO_Enums.Operation_Table.STACKTOS:
|
||||
case LSO_Enums.Operation_Table.STACKTOL:
|
||||
Common.SendToDebug("Param1: " + BitConverter.ToUInt32(br_read(4), 0));
|
||||
break;
|
||||
// BYTE
|
||||
case LSO_Enums.Operation_Table.PRINT:
|
||||
case LSO_Enums.Operation_Table.CALLLIB:
|
||||
Common.SendToDebug("Param1: " + br_read(1)[0]);
|
||||
break;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
private void IL_PopToStack(ILGenerator il)
|
||||
{
|
||||
IL_PopToStack(il, 1);
|
||||
}
|
||||
|
||||
private void IL_PopToStack(ILGenerator il, int count)
|
||||
{
|
||||
Common.SendToDebug("IL_PopToStack();");
|
||||
for (int i = 0; i < count; i++)
|
||||
{
|
||||
IL_CallBaseFunction(il, "POPToStack");
|
||||
//il.Emit(OpCodes.Ldarg_0);
|
||||
//il.Emit(OpCodes.Call,
|
||||
// typeof(LSL_BaseClass).GetMethod("POPToStack",
|
||||
// new Type[] { }));
|
||||
}
|
||||
}
|
||||
|
||||
private void IL_Pop(ILGenerator il)
|
||||
{
|
||||
Common.SendToDebug("IL_Pop();");
|
||||
IL_CallBaseFunction(il, "POP");
|
||||
}
|
||||
|
||||
private void IL_Debug(ILGenerator il, string text)
|
||||
{
|
||||
il.Emit(OpCodes.Ldstr, text);
|
||||
il.Emit(OpCodes.Call, typeof (Common).GetMethod("SendToDebug",
|
||||
new Type[] {typeof (string)}
|
||||
));
|
||||
}
|
||||
|
||||
private void IL_CallBaseFunction(ILGenerator il, string methodname)
|
||||
{
|
||||
il.Emit(OpCodes.Ldarg_0);
|
||||
il.Emit(OpCodes.Call, typeof (LSL_BaseClass).GetMethod(methodname, new Type[] {}));
|
||||
}
|
||||
|
||||
private void IL_CallBaseFunction(ILGenerator il, string methodname, object data)
|
||||
{
|
||||
il.Emit(OpCodes.Ldarg_0);
|
||||
if (data.GetType() == typeof (string))
|
||||
il.Emit(OpCodes.Ldstr, (string) data);
|
||||
if (data.GetType() == typeof (UInt32))
|
||||
il.Emit(OpCodes.Ldc_I4, (UInt32) data);
|
||||
il.Emit(OpCodes.Call, typeof (LSL_BaseClass).GetMethod(methodname, new Type[] {data.GetType()}));
|
||||
}
|
||||
|
||||
private void IL_Push(ILGenerator il, object data)
|
||||
{
|
||||
il.Emit(OpCodes.Ldarg_0);
|
||||
Common.SendToDebug("PUSH datatype: " + data.GetType());
|
||||
|
||||
IL_PushDataTypeToILStack(il, data);
|
||||
|
||||
il.Emit(OpCodes.Call, typeof (LSL_BaseClass).GetMethod("PUSH", new Type[] {data.GetType()}));
|
||||
}
|
||||
|
||||
private void IL_PushDataTypeToILStack(ILGenerator il, object data)
|
||||
{
|
||||
if (data.GetType() == typeof (UInt16))
|
||||
{
|
||||
il.Emit(OpCodes.Ldc_I4, (UInt16) data);
|
||||
il.Emit(OpCodes.Box, data.GetType());
|
||||
}
|
||||
if (data.GetType() == typeof (UInt32))
|
||||
{
|
||||
il.Emit(OpCodes.Ldc_I4, (UInt32) data);
|
||||
il.Emit(OpCodes.Box, data.GetType());
|
||||
}
|
||||
if (data.GetType() == typeof (Int32))
|
||||
{
|
||||
il.Emit(OpCodes.Ldc_I4, (Int32) data);
|
||||
il.Emit(OpCodes.Box, data.GetType());
|
||||
}
|
||||
if (data.GetType() == typeof (float))
|
||||
{
|
||||
il.Emit(OpCodes.Ldc_I4, (float) data);
|
||||
il.Emit(OpCodes.Box, data.GetType());
|
||||
}
|
||||
if (data.GetType() == typeof (string))
|
||||
il.Emit(OpCodes.Ldstr, (string) data);
|
||||
//if (data.GetType() == typeof(LSO_Enums.Rotation))
|
||||
// il.Emit(OpCodes.Ldobj, (LSO_Enums.Rotation)data);
|
||||
//if (data.GetType() == typeof(LSO_Enums.Vector))
|
||||
// il.Emit(OpCodes.Ldobj, (LSO_Enums.Vector)data);
|
||||
//if (data.GetType() == typeof(LSO_Enums.Key))
|
||||
// il.Emit(OpCodes.Ldobj, (LSO_Enums.Key)data);
|
||||
}
|
||||
}
|
||||
/*
|
||||
* Copyright (c) Contributors, http://opensimulator.org/
|
||||
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
* * Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* * Neither the name of the OpenSim Project nor the
|
||||
* names of its contributors may be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS AND ANY
|
||||
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
|
||||
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
*/
|
||||
/* Original code: Tedd Hansen */
|
||||
using System;
|
||||
using System.Reflection;
|
||||
using System.Reflection.Emit;
|
||||
using OpenSim.Region.ScriptEngine.Common;
|
||||
|
||||
namespace OpenSim.Region.ScriptEngine.LSOEngine.LSO
|
||||
{
|
||||
internal partial class LSO_Parser
|
||||
{
|
||||
//internal Stack<Type> ILStack = new Stack<Type>();
|
||||
//LSO_Enums MyLSO_Enums = new LSO_Enums();
|
||||
|
||||
internal bool LSL_PROCESS_OPCODE(ILGenerator il)
|
||||
{
|
||||
byte bp1;
|
||||
UInt32 u32p1;
|
||||
float fp1;
|
||||
UInt16 opcode = br_read(1)[0];
|
||||
Common.SendToDebug("OPCODE: " + ((LSO_Enums.Operation_Table) opcode).ToString());
|
||||
string idesc = ((LSO_Enums.Operation_Table) opcode).ToString();
|
||||
switch ((LSO_Enums.Operation_Table) opcode)
|
||||
{
|
||||
/***************
|
||||
* IMPLEMENTED *
|
||||
***************/
|
||||
case LSO_Enums.Operation_Table.NOOP:
|
||||
break;
|
||||
case LSO_Enums.Operation_Table.PUSHSP:
|
||||
// Push Stack Top (Memory Address) to stack
|
||||
Common.SendToDebug("Instruction " + idesc);
|
||||
Common.SendToDebug("Instruction " + idesc +
|
||||
": Description: Pushing Stack Top (Memory Address from header) to stack");
|
||||
IL_Push(il, (UInt32) myHeader.SP);
|
||||
break;
|
||||
// BYTE
|
||||
case LSO_Enums.Operation_Table.PUSHARGB:
|
||||
Common.SendToDebug("Param1: " + br_read(1)[0]);
|
||||
break;
|
||||
// INTEGER
|
||||
case LSO_Enums.Operation_Table.PUSHARGI:
|
||||
u32p1 = BitConverter.ToUInt32(br_read(4), 0);
|
||||
Common.SendToDebug("Instruction " + idesc + ", Param1: " + u32p1);
|
||||
IL_Push(il, u32p1);
|
||||
break;
|
||||
// FLOAT
|
||||
case LSO_Enums.Operation_Table.PUSHARGF:
|
||||
fp1 = BitConverter.ToUInt32(br_read(4), 0);
|
||||
Common.SendToDebug("Instruction " + idesc + ", Param1: " + fp1);
|
||||
IL_Push(il, fp1);
|
||||
break;
|
||||
// STRING
|
||||
case LSO_Enums.Operation_Table.PUSHARGS:
|
||||
string s = Read_String();
|
||||
Common.SendToDebug("Instruction " + idesc + ", Param1: " + s);
|
||||
IL_Debug(il, "OPCODE: " + idesc + ":" + s);
|
||||
IL_Push(il, s);
|
||||
break;
|
||||
// VECTOR z,y,x
|
||||
case LSO_Enums.Operation_Table.PUSHARGV:
|
||||
LSO_Enums.Vector v = new LSO_Enums.Vector();
|
||||
v.Z = BitConverter.ToUInt32(br_read(4), 0);
|
||||
v.Y = BitConverter.ToUInt32(br_read(4), 0);
|
||||
v.X = BitConverter.ToUInt32(br_read(4), 0);
|
||||
Common.SendToDebug("Param1 Z: " + v.Z);
|
||||
Common.SendToDebug("Param1 Y: " + v.Y);
|
||||
Common.SendToDebug("Param1 X: " + v.X);
|
||||
IL_Push(il, v);
|
||||
break;
|
||||
// ROTATION s,z,y,x
|
||||
case LSO_Enums.Operation_Table.PUSHARGQ:
|
||||
LSO_Enums.Rotation r = new LSO_Enums.Rotation();
|
||||
r.S = BitConverter.ToUInt32(br_read(4), 0);
|
||||
r.Z = BitConverter.ToUInt32(br_read(4), 0);
|
||||
r.Y = BitConverter.ToUInt32(br_read(4), 0);
|
||||
r.X = BitConverter.ToUInt32(br_read(4), 0);
|
||||
Common.SendToDebug("Param1 S: " + r.S);
|
||||
Common.SendToDebug("Param1 Z: " + r.Z);
|
||||
Common.SendToDebug("Param1 Y: " + r.Y);
|
||||
Common.SendToDebug("Param1 X: " + r.X);
|
||||
IL_Push(il, r);
|
||||
break;
|
||||
|
||||
case LSO_Enums.Operation_Table.PUSHE:
|
||||
IL_Push(il, (UInt32) 0);
|
||||
break;
|
||||
|
||||
case LSO_Enums.Operation_Table.PUSHARGE:
|
||||
u32p1 = BitConverter.ToUInt32(br_read(4), 0);
|
||||
Common.SendToDebug("Param1: " + u32p1);
|
||||
//IL_Push(il, new string(" ".ToCharArray()[0], Convert.ToInt32(u32p1)));
|
||||
IL_Push(il, u32p1);
|
||||
break;
|
||||
// BYTE
|
||||
case LSO_Enums.Operation_Table.ADD:
|
||||
case LSO_Enums.Operation_Table.SUB:
|
||||
case LSO_Enums.Operation_Table.MUL:
|
||||
case LSO_Enums.Operation_Table.DIV:
|
||||
case LSO_Enums.Operation_Table.EQ:
|
||||
case LSO_Enums.Operation_Table.NEQ:
|
||||
case LSO_Enums.Operation_Table.LEQ:
|
||||
case LSO_Enums.Operation_Table.GEQ:
|
||||
case LSO_Enums.Operation_Table.LESS:
|
||||
case LSO_Enums.Operation_Table.GREATER:
|
||||
case LSO_Enums.Operation_Table.NEG:
|
||||
case LSO_Enums.Operation_Table.MOD:
|
||||
bp1 = br_read(1)[0];
|
||||
Common.SendToDebug("Param1: " + bp1);
|
||||
IL_CallBaseFunction(il, idesc, (UInt32) bp1);
|
||||
break;
|
||||
|
||||
// NO ARGUMENTS
|
||||
case LSO_Enums.Operation_Table.BITAND:
|
||||
case LSO_Enums.Operation_Table.BITOR:
|
||||
case LSO_Enums.Operation_Table.BITXOR:
|
||||
case LSO_Enums.Operation_Table.BOOLAND:
|
||||
case LSO_Enums.Operation_Table.BOOLOR:
|
||||
case LSO_Enums.Operation_Table.BITNOT:
|
||||
case LSO_Enums.Operation_Table.BOOLNOT:
|
||||
IL_CallBaseFunction(il, idesc);
|
||||
break;
|
||||
// SHORT
|
||||
case LSO_Enums.Operation_Table.CALLLIB_TWO_BYTE:
|
||||
// TODO: What is size of short?
|
||||
UInt16 U16p1 = BitConverter.ToUInt16(br_read(2), 0);
|
||||
Common.SendToDebug("Instruction " + idesc + ": Builtin Command: " +
|
||||
((LSO_Enums.BuiltIn_Functions) U16p1).ToString());
|
||||
//Common.SendToDebug("Param1: " + U16p1);
|
||||
string fname = ((LSO_Enums.BuiltIn_Functions) U16p1).ToString();
|
||||
|
||||
bool cmdFound = false;
|
||||
foreach (MethodInfo mi in typeof (LSL_BuiltIn_Commands_Interface).GetMethods())
|
||||
{
|
||||
// Found command
|
||||
if (mi.Name == fname)
|
||||
{
|
||||
il.Emit(OpCodes.Ldarg_0);
|
||||
il.Emit(OpCodes.Call, typeof (LSL_BaseClass).GetMethod("GetLSL_BuiltIn", new Type[] {}));
|
||||
// Pop required number of items from my stack to .Net stack
|
||||
IL_PopToStack(il, mi.GetParameters().Length);
|
||||
il.Emit(OpCodes.Callvirt, mi);
|
||||
cmdFound = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (cmdFound == false)
|
||||
{
|
||||
Common.SendToDebug("ERROR: UNABLE TO LOCATE OPCODE " + idesc + " IN BASECLASS");
|
||||
}
|
||||
|
||||
break;
|
||||
|
||||
// RETURN
|
||||
case LSO_Enums.Operation_Table.RETURN:
|
||||
|
||||
Common.SendToDebug("OPCODE: RETURN");
|
||||
return true;
|
||||
|
||||
case LSO_Enums.Operation_Table.POP:
|
||||
case LSO_Enums.Operation_Table.POPS:
|
||||
case LSO_Enums.Operation_Table.POPL:
|
||||
case LSO_Enums.Operation_Table.POPV:
|
||||
case LSO_Enums.Operation_Table.POPQ:
|
||||
// Pops a specific datatype from the stack
|
||||
// We just ignore the datatype for now
|
||||
IL_Pop(il);
|
||||
break;
|
||||
|
||||
// LONG
|
||||
case LSO_Enums.Operation_Table.STORE:
|
||||
case LSO_Enums.Operation_Table.STORES:
|
||||
case LSO_Enums.Operation_Table.STOREL:
|
||||
case LSO_Enums.Operation_Table.STOREV:
|
||||
case LSO_Enums.Operation_Table.STOREQ:
|
||||
u32p1 = BitConverter.ToUInt32(br_read(4), 0);
|
||||
Common.SendToDebug("Param1: " + u32p1.ToString());
|
||||
IL_CallBaseFunction(il, "StoreToLocal", u32p1);
|
||||
break;
|
||||
|
||||
case LSO_Enums.Operation_Table.STOREG:
|
||||
case LSO_Enums.Operation_Table.STOREGS:
|
||||
case LSO_Enums.Operation_Table.STOREGL:
|
||||
case LSO_Enums.Operation_Table.STOREGV:
|
||||
case LSO_Enums.Operation_Table.STOREGQ:
|
||||
u32p1 = BitConverter.ToUInt32(br_read(4), 0);
|
||||
Common.SendToDebug("Param1: " + u32p1.ToString());
|
||||
IL_CallBaseFunction(il, "StoreToGlobal", u32p1);
|
||||
break;
|
||||
|
||||
case LSO_Enums.Operation_Table.LOADP:
|
||||
case LSO_Enums.Operation_Table.LOADSP:
|
||||
case LSO_Enums.Operation_Table.LOADLP:
|
||||
case LSO_Enums.Operation_Table.LOADVP:
|
||||
case LSO_Enums.Operation_Table.LOADQP:
|
||||
u32p1 = BitConverter.ToUInt32(br_read(4), 0);
|
||||
Common.SendToDebug("Param1: " + u32p1.ToString());
|
||||
IL_CallBaseFunction(il, "StoreToLocal", u32p1);
|
||||
IL_Pop(il);
|
||||
break;
|
||||
|
||||
case LSO_Enums.Operation_Table.LOADGP:
|
||||
case LSO_Enums.Operation_Table.LOADGSP:
|
||||
case LSO_Enums.Operation_Table.LOADGLP:
|
||||
case LSO_Enums.Operation_Table.LOADGVP:
|
||||
case LSO_Enums.Operation_Table.LOADGQP:
|
||||
u32p1 = BitConverter.ToUInt32(br_read(4), 0);
|
||||
Common.SendToDebug("Param1: " + u32p1.ToString());
|
||||
IL_CallBaseFunction(il, "StoreToStatic", u32p1 - 6 + myHeader.GVR);
|
||||
IL_Pop(il);
|
||||
break;
|
||||
|
||||
// PUSH FROM LOCAL FRAME
|
||||
case LSO_Enums.Operation_Table.PUSH:
|
||||
case LSO_Enums.Operation_Table.PUSHS:
|
||||
case LSO_Enums.Operation_Table.PUSHL:
|
||||
case LSO_Enums.Operation_Table.PUSHV:
|
||||
case LSO_Enums.Operation_Table.PUSHQ:
|
||||
u32p1 = BitConverter.ToUInt32(br_read(4), 0);
|
||||
Common.SendToDebug("Param1: " + u32p1.ToString());
|
||||
IL_CallBaseFunction(il, "GetFromLocal", u32p1);
|
||||
|
||||
break;
|
||||
|
||||
// PUSH FROM STATIC FRAME
|
||||
case LSO_Enums.Operation_Table.PUSHG:
|
||||
case LSO_Enums.Operation_Table.PUSHGS:
|
||||
case LSO_Enums.Operation_Table.PUSHGL:
|
||||
case LSO_Enums.Operation_Table.PUSHGV:
|
||||
case LSO_Enums.Operation_Table.PUSHGQ:
|
||||
u32p1 = BitConverter.ToUInt32(br_read(4), 0);
|
||||
Common.SendToDebug("Param1: " + u32p1.ToString());
|
||||
IL_CallBaseFunction(il, "GetFromStatic", u32p1 - 6 + myHeader.GVR);
|
||||
break;
|
||||
|
||||
|
||||
/***********************
|
||||
* NOT IMPLEMENTED YET *
|
||||
***********************/
|
||||
|
||||
|
||||
case LSO_Enums.Operation_Table.POPIP:
|
||||
case LSO_Enums.Operation_Table.POPSP:
|
||||
case LSO_Enums.Operation_Table.POPSLR:
|
||||
case LSO_Enums.Operation_Table.POPARG:
|
||||
case LSO_Enums.Operation_Table.POPBP:
|
||||
//Common.SendToDebug("Instruction " + idesc + ": Ignored");
|
||||
Common.SendToDebug("Instruction " + idesc +
|
||||
": Description: Drop x bytes from the stack (TODO: Only popping 1)");
|
||||
//Common.SendToDebug("Param1: " + BitConverter.ToUInt32(br_read(4), 0));
|
||||
IL_Pop(il);
|
||||
break;
|
||||
|
||||
|
||||
// None
|
||||
case LSO_Enums.Operation_Table.PUSHIP:
|
||||
// PUSH INSTRUCTION POINTER
|
||||
break;
|
||||
case LSO_Enums.Operation_Table.PUSHBP:
|
||||
|
||||
case LSO_Enums.Operation_Table.PUSHEV:
|
||||
break;
|
||||
case LSO_Enums.Operation_Table.PUSHEQ:
|
||||
break;
|
||||
|
||||
|
||||
// LONG
|
||||
case LSO_Enums.Operation_Table.JUMP:
|
||||
Common.SendToDebug("Param1: " + BitConverter.ToUInt32(br_read(4), 0));
|
||||
break;
|
||||
// BYTE, LONG
|
||||
case LSO_Enums.Operation_Table.JUMPIF:
|
||||
case LSO_Enums.Operation_Table.JUMPNIF:
|
||||
Common.SendToDebug("Param1: " + br_read(1)[0]);
|
||||
Common.SendToDebug("Param2: " + BitConverter.ToUInt32(br_read(4), 0));
|
||||
break;
|
||||
// LONG
|
||||
case LSO_Enums.Operation_Table.STATE:
|
||||
bp1 = br_read(1)[0];
|
||||
//il.Emit(OpCodes.Ld); // Load local variable 0 onto stack
|
||||
//il.Emit(OpCodes.Ldc_I4, 0); // Push index position
|
||||
//il.Emit(OpCodes.Ldstr, EventList[p1]); // Push value
|
||||
//il.Emit(OpCodes.Stelem_Ref); // Perform array[index] = value
|
||||
break;
|
||||
case LSO_Enums.Operation_Table.CALL:
|
||||
Common.SendToDebug("Param1: " + BitConverter.ToUInt32(br_read(4), 0));
|
||||
Common.SendToDebug("ERROR: Function CALL not implemented yet.");
|
||||
break;
|
||||
// BYTE
|
||||
case LSO_Enums.Operation_Table.CAST:
|
||||
bp1 = br_read(1)[0];
|
||||
Common.SendToDebug("Instruction " + idesc + ": Cast to type: " +
|
||||
((LSO_Enums.OpCode_Cast_TypeDefs) bp1));
|
||||
Common.SendToDebug("Param1: " + bp1);
|
||||
switch ((LSO_Enums.OpCode_Cast_TypeDefs) bp1)
|
||||
{
|
||||
case LSO_Enums.OpCode_Cast_TypeDefs.String:
|
||||
Common.SendToDebug("Instruction " + idesc + ": il.Emit(OpCodes.Box, ILStack.Pop());");
|
||||
break;
|
||||
default:
|
||||
Common.SendToDebug("Instruction " + idesc + ": Unknown cast type!");
|
||||
break;
|
||||
}
|
||||
break;
|
||||
// LONG
|
||||
case LSO_Enums.Operation_Table.STACKTOS:
|
||||
case LSO_Enums.Operation_Table.STACKTOL:
|
||||
Common.SendToDebug("Param1: " + BitConverter.ToUInt32(br_read(4), 0));
|
||||
break;
|
||||
// BYTE
|
||||
case LSO_Enums.Operation_Table.PRINT:
|
||||
case LSO_Enums.Operation_Table.CALLLIB:
|
||||
Common.SendToDebug("Param1: " + br_read(1)[0]);
|
||||
break;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
private void IL_PopToStack(ILGenerator il)
|
||||
{
|
||||
IL_PopToStack(il, 1);
|
||||
}
|
||||
|
||||
private void IL_PopToStack(ILGenerator il, int count)
|
||||
{
|
||||
Common.SendToDebug("IL_PopToStack();");
|
||||
for (int i = 0; i < count; i++)
|
||||
{
|
||||
IL_CallBaseFunction(il, "POPToStack");
|
||||
//il.Emit(OpCodes.Ldarg_0);
|
||||
//il.Emit(OpCodes.Call,
|
||||
// typeof(LSL_BaseClass).GetMethod("POPToStack",
|
||||
// new Type[] { }));
|
||||
}
|
||||
}
|
||||
|
||||
private void IL_Pop(ILGenerator il)
|
||||
{
|
||||
Common.SendToDebug("IL_Pop();");
|
||||
IL_CallBaseFunction(il, "POP");
|
||||
}
|
||||
|
||||
private void IL_Debug(ILGenerator il, string text)
|
||||
{
|
||||
il.Emit(OpCodes.Ldstr, text);
|
||||
il.Emit(OpCodes.Call, typeof (Common).GetMethod("SendToDebug",
|
||||
new Type[] {typeof (string)}
|
||||
));
|
||||
}
|
||||
|
||||
private void IL_CallBaseFunction(ILGenerator il, string methodname)
|
||||
{
|
||||
il.Emit(OpCodes.Ldarg_0);
|
||||
il.Emit(OpCodes.Call, typeof (LSL_BaseClass).GetMethod(methodname, new Type[] {}));
|
||||
}
|
||||
|
||||
private void IL_CallBaseFunction(ILGenerator il, string methodname, object data)
|
||||
{
|
||||
il.Emit(OpCodes.Ldarg_0);
|
||||
if (data.GetType() == typeof (string))
|
||||
il.Emit(OpCodes.Ldstr, (string) data);
|
||||
if (data.GetType() == typeof (UInt32))
|
||||
il.Emit(OpCodes.Ldc_I4, (UInt32) data);
|
||||
il.Emit(OpCodes.Call, typeof (LSL_BaseClass).GetMethod(methodname, new Type[] {data.GetType()}));
|
||||
}
|
||||
|
||||
private void IL_Push(ILGenerator il, object data)
|
||||
{
|
||||
il.Emit(OpCodes.Ldarg_0);
|
||||
Common.SendToDebug("PUSH datatype: " + data.GetType());
|
||||
|
||||
IL_PushDataTypeToILStack(il, data);
|
||||
|
||||
il.Emit(OpCodes.Call, typeof (LSL_BaseClass).GetMethod("PUSH", new Type[] {data.GetType()}));
|
||||
}
|
||||
|
||||
private void IL_PushDataTypeToILStack(ILGenerator il, object data)
|
||||
{
|
||||
if (data.GetType() == typeof (UInt16))
|
||||
{
|
||||
il.Emit(OpCodes.Ldc_I4, (UInt16) data);
|
||||
il.Emit(OpCodes.Box, data.GetType());
|
||||
}
|
||||
if (data.GetType() == typeof (UInt32))
|
||||
{
|
||||
il.Emit(OpCodes.Ldc_I4, (UInt32) data);
|
||||
il.Emit(OpCodes.Box, data.GetType());
|
||||
}
|
||||
if (data.GetType() == typeof (Int32))
|
||||
{
|
||||
il.Emit(OpCodes.Ldc_I4, (Int32) data);
|
||||
il.Emit(OpCodes.Box, data.GetType());
|
||||
}
|
||||
if (data.GetType() == typeof (float))
|
||||
{
|
||||
il.Emit(OpCodes.Ldc_I4, (float) data);
|
||||
il.Emit(OpCodes.Box, data.GetType());
|
||||
}
|
||||
if (data.GetType() == typeof (string))
|
||||
il.Emit(OpCodes.Ldstr, (string) data);
|
||||
//if (data.GetType() == typeof(LSO_Enums.Rotation))
|
||||
// il.Emit(OpCodes.Ldobj, (LSO_Enums.Rotation)data);
|
||||
//if (data.GetType() == typeof(LSO_Enums.Vector))
|
||||
// il.Emit(OpCodes.Ldobj, (LSO_Enums.Vector)data);
|
||||
//if (data.GetType() == typeof(LSO_Enums.Key))
|
||||
// il.Emit(OpCodes.Ldobj, (LSO_Enums.Key)data);
|
||||
}
|
||||
}
|
||||
}
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
|
@ -1,143 +1,143 @@
|
|||
/*
|
||||
* Copyright (c) Contributors, http://opensimulator.org/
|
||||
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
* * Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* * Neither the name of the OpenSim Project nor the
|
||||
* names of its contributors may be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS AND ANY
|
||||
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
|
||||
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
*/
|
||||
/* Original code: Tedd Hansen */
|
||||
|
||||
using System;
|
||||
using System.Collections;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace OpenSim.Region.ScriptEngine.LSOEngine.LSO
|
||||
{
|
||||
internal static class LSO_Struct
|
||||
{
|
||||
public struct Header
|
||||
{
|
||||
public UInt32 TM;
|
||||
public UInt32 IP;
|
||||
public UInt32 VN;
|
||||
public UInt32 BP;
|
||||
public UInt32 SP;
|
||||
public UInt32 HR;
|
||||
public UInt32 HP;
|
||||
public UInt32 CS;
|
||||
public UInt32 NS;
|
||||
public UInt32 CE;
|
||||
public UInt32 IE;
|
||||
public UInt32 ER;
|
||||
public UInt32 FR;
|
||||
public UInt32 SLR;
|
||||
public UInt32 GVR;
|
||||
public UInt32 GFR;
|
||||
public UInt32 PR;
|
||||
public UInt32 ESR;
|
||||
public UInt32 SR;
|
||||
public UInt64 NCE;
|
||||
public UInt64 NIE;
|
||||
public UInt64 NER;
|
||||
}
|
||||
|
||||
public struct StaticBlock
|
||||
{
|
||||
public UInt32 Static_Chunk_Header_Size;
|
||||
public byte ObjectType;
|
||||
public byte Unknown;
|
||||
public byte[] BlockVariable;
|
||||
}
|
||||
|
||||
/* Not actually a structure
|
||||
public struct StaticBlockVariable
|
||||
{
|
||||
public UInt32 Integer1;
|
||||
public UInt32 Float1;
|
||||
public UInt32 HeapPointer_String;
|
||||
public UInt32 HeapPointer_Key;
|
||||
public byte[] Vector_12;
|
||||
public byte[] Rotation_16;
|
||||
public UInt32 Pointer_List_Structure;
|
||||
} */
|
||||
|
||||
public struct HeapBlock
|
||||
{
|
||||
public Int32 DataBlockSize;
|
||||
public byte ObjectType;
|
||||
public UInt16 ReferenceCount;
|
||||
public byte[] Data;
|
||||
}
|
||||
|
||||
public struct StateFrameBlock
|
||||
{
|
||||
public UInt32 StateCount;
|
||||
public StatePointerBlock[] StatePointer;
|
||||
}
|
||||
|
||||
public struct StatePointerBlock
|
||||
{
|
||||
public UInt32 Location;
|
||||
public BitArray EventMask;
|
||||
public StateBlock StateBlock;
|
||||
}
|
||||
|
||||
public struct StateBlock
|
||||
{
|
||||
public UInt32 StartPos;
|
||||
public UInt32 EndPos;
|
||||
public UInt32 HeaderSize;
|
||||
public byte Unknown;
|
||||
public StateBlockHandler[] StateBlockHandlers;
|
||||
}
|
||||
|
||||
public struct StateBlockHandler
|
||||
{
|
||||
public UInt32 CodeChunkPointer;
|
||||
public UInt32 CallFrameSize;
|
||||
}
|
||||
|
||||
public struct FunctionBlock
|
||||
{
|
||||
public UInt32 FunctionCount;
|
||||
public UInt32[] CodeChunkPointer;
|
||||
}
|
||||
|
||||
public struct CodeChunk
|
||||
{
|
||||
public UInt32 CodeChunkHeaderSize;
|
||||
public string Comment;
|
||||
public List<CodeChunkArgument> CodeChunkArguments;
|
||||
public byte EndMarker;
|
||||
public byte ReturnTypePos;
|
||||
public StaticBlock ReturnType;
|
||||
}
|
||||
|
||||
public struct CodeChunkArgument
|
||||
{
|
||||
public byte FunctionReturnTypePos;
|
||||
public byte NullString;
|
||||
public StaticBlock FunctionReturnType;
|
||||
}
|
||||
}
|
||||
/*
|
||||
* Copyright (c) Contributors, http://opensimulator.org/
|
||||
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
* * Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* * Neither the name of the OpenSim Project nor the
|
||||
* names of its contributors may be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS ``AS IS AND ANY
|
||||
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
|
||||
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
*/
|
||||
/* Original code: Tedd Hansen */
|
||||
|
||||
using System;
|
||||
using System.Collections;
|
||||
using System.Collections.Generic;
|
||||
|
||||
namespace OpenSim.Region.ScriptEngine.LSOEngine.LSO
|
||||
{
|
||||
internal static class LSO_Struct
|
||||
{
|
||||
public struct Header
|
||||
{
|
||||
public UInt32 TM;
|
||||
public UInt32 IP;
|
||||
public UInt32 VN;
|
||||
public UInt32 BP;
|
||||
public UInt32 SP;
|
||||
public UInt32 HR;
|
||||
public UInt32 HP;
|
||||
public UInt32 CS;
|
||||
public UInt32 NS;
|
||||
public UInt32 CE;
|
||||
public UInt32 IE;
|
||||
public UInt32 ER;
|
||||
public UInt32 FR;
|
||||
public UInt32 SLR;
|
||||
public UInt32 GVR;
|
||||
public UInt32 GFR;
|
||||
public UInt32 PR;
|
||||
public UInt32 ESR;
|
||||
public UInt32 SR;
|
||||
public UInt64 NCE;
|
||||
public UInt64 NIE;
|
||||
public UInt64 NER;
|
||||
}
|
||||
|
||||
public struct StaticBlock
|
||||
{
|
||||
public UInt32 Static_Chunk_Header_Size;
|
||||
public byte ObjectType;
|
||||
public byte Unknown;
|
||||
public byte[] BlockVariable;
|
||||
}
|
||||
|
||||
/* Not actually a structure
|
||||
public struct StaticBlockVariable
|
||||
{
|
||||
public UInt32 Integer1;
|
||||
public UInt32 Float1;
|
||||
public UInt32 HeapPointer_String;
|
||||
public UInt32 HeapPointer_Key;
|
||||
public byte[] Vector_12;
|
||||
public byte[] Rotation_16;
|
||||
public UInt32 Pointer_List_Structure;
|
||||
} */
|
||||
|
||||
public struct HeapBlock
|
||||
{
|
||||
public Int32 DataBlockSize;
|
||||
public byte ObjectType;
|
||||
public UInt16 ReferenceCount;
|
||||
public byte[] Data;
|
||||
}
|
||||
|
||||
public struct StateFrameBlock
|
||||
{
|
||||
public UInt32 StateCount;
|
||||
public StatePointerBlock[] StatePointer;
|
||||
}
|
||||
|
||||
public struct StatePointerBlock
|
||||
{
|
||||
public UInt32 Location;
|
||||
public BitArray EventMask;
|
||||
public StateBlock StateBlock;
|
||||
}
|
||||
|
||||
public struct StateBlock
|
||||
{
|
||||
public UInt32 StartPos;
|
||||
public UInt32 EndPos;
|
||||
public UInt32 HeaderSize;
|
||||
public byte Unknown;
|
||||
public StateBlockHandler[] StateBlockHandlers;
|
||||
}
|
||||
|
||||
public struct StateBlockHandler
|
||||
{
|
||||
public UInt32 CodeChunkPointer;
|
||||
public UInt32 CallFrameSize;
|
||||
}
|
||||
|
||||
public struct FunctionBlock
|
||||
{
|
||||
public UInt32 FunctionCount;
|
||||
public UInt32[] CodeChunkPointer;
|
||||
}
|
||||
|
||||
public struct CodeChunk
|
||||
{
|
||||
public UInt32 CodeChunkHeaderSize;
|
||||
public string Comment;
|
||||
public List<CodeChunkArgument> CodeChunkArguments;
|
||||
public byte EndMarker;
|
||||
public byte ReturnTypePos;
|
||||
public StaticBlock ReturnType;
|
||||
}
|
||||
|
||||
public struct CodeChunkArgument
|
||||
{
|
||||
public byte FunctionReturnTypePos;
|
||||
public byte NullString;
|
||||
public StaticBlock FunctionReturnType;
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,38 +1,38 @@
|
|||
using System.Reflection;
|
||||
using System.Runtime.InteropServices;
|
||||
|
||||
// General Information about an assembly is controlled through the following
|
||||
// set of attributes. Change these attribute values to modify the information
|
||||
// associated with an assembly.
|
||||
|
||||
[assembly: AssemblyTitle("OpenSim.Region.ScriptEngine.LSOEngine")]
|
||||
[assembly : AssemblyDescription("")]
|
||||
[assembly : AssemblyConfiguration("")]
|
||||
[assembly : AssemblyCompany("")]
|
||||
[assembly: AssemblyProduct("OpenSim.Region.ScriptEngine.LSOEngine")]
|
||||
[assembly : AssemblyCopyright("Copyright © 2007")]
|
||||
[assembly : AssemblyTrademark("")]
|
||||
[assembly : AssemblyCulture("")]
|
||||
|
||||
// Setting ComVisible to false makes the types in this assembly not visible
|
||||
// to COM components. If you need to access a type in this assembly from
|
||||
// COM, set the ComVisible attribute to true on that type.
|
||||
|
||||
[assembly : ComVisible(false)]
|
||||
|
||||
// The following GUID is for the ID of the typelib if this project is exposed to COM
|
||||
|
||||
[assembly : Guid("2842257e-6fde-4460-9368-4cde57fa9cc4")]
|
||||
|
||||
// Version information for an assembly consists of the following four values:
|
||||
//
|
||||
// Major Version
|
||||
// Minor Version
|
||||
// Build Number
|
||||
// Revision
|
||||
//
|
||||
// You can specify all the values or you can default the Revision and Build Numbers
|
||||
// by using the '*' as shown below:
|
||||
|
||||
[assembly : AssemblyVersion("1.0.0.0")]
|
||||
using System.Reflection;
|
||||
using System.Runtime.InteropServices;
|
||||
|
||||
// General Information about an assembly is controlled through the following
|
||||
// set of attributes. Change these attribute values to modify the information
|
||||
// associated with an assembly.
|
||||
|
||||
[assembly: AssemblyTitle("OpenSim.Region.ScriptEngine.LSOEngine")]
|
||||
[assembly : AssemblyDescription("")]
|
||||
[assembly : AssemblyConfiguration("")]
|
||||
[assembly : AssemblyCompany("")]
|
||||
[assembly: AssemblyProduct("OpenSim.Region.ScriptEngine.LSOEngine")]
|
||||
[assembly : AssemblyCopyright("Copyright © 2007")]
|
||||
[assembly : AssemblyTrademark("")]
|
||||
[assembly : AssemblyCulture("")]
|
||||
|
||||
// Setting ComVisible to false makes the types in this assembly not visible
|
||||
// to COM components. If you need to access a type in this assembly from
|
||||
// COM, set the ComVisible attribute to true on that type.
|
||||
|
||||
[assembly : ComVisible(false)]
|
||||
|
||||
// The following GUID is for the ID of the typelib if this project is exposed to COM
|
||||
|
||||
[assembly : Guid("2842257e-6fde-4460-9368-4cde57fa9cc4")]
|
||||
|
||||
// Version information for an assembly consists of the following four values:
|
||||
//
|
||||
// Major Version
|
||||
// Minor Version
|
||||
// Build Number
|
||||
// Revision
|
||||
//
|
||||
// You can specify all the values or you can default the Revision and Build Numbers
|
||||
// by using the '*' as shown below:
|
||||
|
||||
[assembly : AssemblyVersion("1.0.0.0")]
|
||||
[assembly : AssemblyFileVersion("1.0.0.0")]
|
|
@ -1,55 +1,55 @@
|
|||
/*
|
||||
* Copyright (c) Contributors, http://opensimulator.org/
|
||||
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
* * Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* * Neither the name of the OpenSim Project nor the
|
||||
* names of its contributors may be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS AS IS AND ANY
|
||||
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
|
||||
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
*/
|
||||
|
||||
using System;
|
||||
using Nini.Config;
|
||||
using OpenSim.Framework.Console;
|
||||
using OpenSim.Region.Environment.Interfaces;
|
||||
using OpenSim.Region.Environment.Scenes;
|
||||
using OpenSim.Region.ScriptEngine.Common;
|
||||
using OpenSim.Region.ScriptEngine.Common.ScriptEngineBase;
|
||||
using EventManager = OpenSim.Region.ScriptEngine.Common.ScriptEngineBase.EventManager;
|
||||
using ScriptManager=OpenSim.Region.ScriptEngine.LSOEngine.ScriptManager;
|
||||
|
||||
namespace OpenSim.Region.ScriptEngine.LSOEngine
|
||||
{
|
||||
[Serializable]
|
||||
public class ScriptEngine : OpenSim.Region.ScriptEngine.Common.ScriptEngineBase.ScriptEngine
|
||||
{
|
||||
// We need to override a few things for our DotNetEngine
|
||||
public override void Initialise(Scene scene, IConfigSource config)
|
||||
{
|
||||
InitializeEngine(scene, MainLog.Instance, true, GetScriptManager());
|
||||
}
|
||||
|
||||
public override OpenSim.Region.ScriptEngine.Common.ScriptEngineBase.ScriptManager _GetScriptManager()
|
||||
{
|
||||
return new ScriptManager(this);
|
||||
}
|
||||
}
|
||||
/*
|
||||
* Copyright (c) Contributors, http://opensimulator.org/
|
||||
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
* * Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* * Neither the name of the OpenSim Project nor the
|
||||
* names of its contributors may be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS AS IS AND ANY
|
||||
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
|
||||
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
*/
|
||||
|
||||
using System;
|
||||
using Nini.Config;
|
||||
using OpenSim.Framework.Console;
|
||||
using OpenSim.Region.Environment.Interfaces;
|
||||
using OpenSim.Region.Environment.Scenes;
|
||||
using OpenSim.Region.ScriptEngine.Common;
|
||||
using OpenSim.Region.ScriptEngine.Common.ScriptEngineBase;
|
||||
using EventManager = OpenSim.Region.ScriptEngine.Common.ScriptEngineBase.EventManager;
|
||||
using ScriptManager=OpenSim.Region.ScriptEngine.LSOEngine.ScriptManager;
|
||||
|
||||
namespace OpenSim.Region.ScriptEngine.LSOEngine
|
||||
{
|
||||
[Serializable]
|
||||
public class ScriptEngine : OpenSim.Region.ScriptEngine.Common.ScriptEngineBase.ScriptEngine
|
||||
{
|
||||
// We need to override a few things for our DotNetEngine
|
||||
public override void Initialise(Scene scene, IConfigSource config)
|
||||
{
|
||||
InitializeEngine(scene, MainLog.Instance, true, GetScriptManager());
|
||||
}
|
||||
|
||||
public override OpenSim.Region.ScriptEngine.Common.ScriptEngineBase.ScriptManager _GetScriptManager()
|
||||
{
|
||||
return new ScriptManager(this);
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,158 +1,158 @@
|
|||
/*
|
||||
* Copyright (c) Contributors, http://opensimulator.org/
|
||||
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
* * Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* * Neither the name of the OpenSim Project nor the
|
||||
* names of its contributors may be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS AS IS AND ANY
|
||||
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
|
||||
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
*/
|
||||
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.IO;
|
||||
using System.Reflection;
|
||||
using System.Runtime.Serialization.Formatters.Binary;
|
||||
using System.Threading;
|
||||
using libsecondlife;
|
||||
using OpenSim.Framework;
|
||||
using OpenSim.Region.Environment.Scenes;
|
||||
using OpenSim.Region.ScriptEngine.Common;
|
||||
|
||||
namespace OpenSim.Region.ScriptEngine.LSOEngine
|
||||
{
|
||||
public class ScriptManager : OpenSim.Region.ScriptEngine.Common.ScriptEngineBase.ScriptManager
|
||||
{
|
||||
public ScriptManager(Common.ScriptEngineBase.ScriptEngine scriptEngine)
|
||||
: base(scriptEngine)
|
||||
{
|
||||
base.m_scriptEngine = scriptEngine;
|
||||
|
||||
}
|
||||
|
||||
// KEEP TRACK OF SCRIPTS <int id, whatever script>
|
||||
//internal Dictionary<uint, Dictionary<LLUUID, LSL_BaseClass>> Scripts = new Dictionary<uint, Dictionary<LLUUID, LSL_BaseClass>>();
|
||||
// LOAD SCRIPT
|
||||
// UNLOAD SCRIPT
|
||||
// PROVIDE SCRIPT WITH ITS INTERFACE TO OpenSim
|
||||
|
||||
public override void _StartScript(uint localID, LLUUID itemID, string Script)
|
||||
{
|
||||
//IScriptHost root = host.GetRoot();
|
||||
Console.WriteLine("ScriptManager StartScript: localID: " + localID + ", itemID: " + itemID);
|
||||
|
||||
// We will initialize and start the script.
|
||||
// It will be up to the script itself to hook up the correct events.
|
||||
string ScriptSource = "";
|
||||
|
||||
SceneObjectPart m_host = World.GetSceneObjectPart(localID);
|
||||
|
||||
try
|
||||
{
|
||||
// Compile (We assume LSL)
|
||||
//ScriptSource = LSLCompiler.CompileFromLSLText(Script);
|
||||
|
||||
#if DEBUG
|
||||
long before;
|
||||
before = GC.GetTotalMemory(true);
|
||||
#endif
|
||||
|
||||
IScript CompiledScript;
|
||||
CompiledScript = m_scriptEngine.m_AppDomainManager.LoadScript(ScriptSource);
|
||||
|
||||
#if DEBUG
|
||||
Console.WriteLine("Script " + itemID + " occupies {0} bytes", GC.GetTotalMemory(true) - before);
|
||||
#endif
|
||||
|
||||
CompiledScript.Source = ScriptSource;
|
||||
// Add it to our script memstruct
|
||||
SetScript(localID, itemID, CompiledScript);
|
||||
|
||||
// We need to give (untrusted) assembly a private instance of BuiltIns
|
||||
// this private copy will contain Read-Only FullitemID so that it can bring that on to the server whenever needed.
|
||||
|
||||
|
||||
LSL_BuiltIn_Commands LSLB = new LSL_BuiltIn_Commands(m_scriptEngine, m_host, localID, itemID);
|
||||
|
||||
// Start the script - giving it BuiltIns
|
||||
CompiledScript.Start(LSLB);
|
||||
|
||||
// Fire the first start-event
|
||||
m_scriptEngine.m_EventQueueManager.AddToScriptQueue(localID, itemID, "state_entry", new object[] { });
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
//m_scriptEngine.Log.Error("ScriptEngine", "Error compiling script: " + e.ToString());
|
||||
try
|
||||
{
|
||||
// DISPLAY ERROR INWORLD
|
||||
string text = "Error compiling script:\r\n" + e.Message.ToString();
|
||||
if (text.Length > 1500)
|
||||
text = text.Substring(0, 1500);
|
||||
World.SimChat(Helpers.StringToField(text), ChatTypeEnum.Say, 0, m_host.AbsolutePosition,
|
||||
m_host.Name, m_host.UUID);
|
||||
}
|
||||
catch (Exception e2)
|
||||
{
|
||||
m_scriptEngine.Log.Error("ScriptEngine", "Error displaying error in-world: " + e2.ToString());
|
||||
m_scriptEngine.Log.Error("ScriptEngine",
|
||||
"Errormessage: Error compiling script:\r\n" + e.Message.ToString());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public override void _StopScript(uint localID, LLUUID itemID)
|
||||
{
|
||||
// Stop script
|
||||
Console.WriteLine("Stop script localID: " + localID + " LLUID: " + itemID.ToString());
|
||||
|
||||
|
||||
// Stop long command on script
|
||||
m_scriptEngine.m_LSLLongCmdHandler.RemoveScript(localID, itemID);
|
||||
|
||||
IScript LSLBC = GetScript(localID, itemID);
|
||||
if (LSLBC == null)
|
||||
return;
|
||||
|
||||
// TEMP: First serialize it
|
||||
//GetSerializedScript(localID, itemID);
|
||||
|
||||
|
||||
try
|
||||
{
|
||||
// Get AppDomain
|
||||
AppDomain ad = LSLBC.Exec.GetAppDomain();
|
||||
// Tell script not to accept new requests
|
||||
GetScript(localID, itemID).Exec.StopScript();
|
||||
// Remove from internal structure
|
||||
RemoveScript(localID, itemID);
|
||||
// Tell AppDomain that we have stopped script
|
||||
m_scriptEngine.m_AppDomainManager.StopScript(ad);
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
Console.WriteLine("Exception stopping script localID: " + localID + " LLUID: " + itemID.ToString() +
|
||||
": " + e.ToString());
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
/*
|
||||
* Copyright (c) Contributors, http://opensimulator.org/
|
||||
* See CONTRIBUTORS.TXT for a full list of copyright holders.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without
|
||||
* modification, are permitted provided that the following conditions are met:
|
||||
* * Redistributions of source code must retain the above copyright
|
||||
* notice, this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright
|
||||
* notice, this list of conditions and the following disclaimer in the
|
||||
* documentation and/or other materials provided with the distribution.
|
||||
* * Neither the name of the OpenSim Project nor the
|
||||
* names of its contributors may be used to endorse or promote products
|
||||
* derived from this software without specific prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE DEVELOPERS AS IS AND ANY
|
||||
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
* DISCLAIMED. IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY
|
||||
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*
|
||||
*/
|
||||
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.IO;
|
||||
using System.Reflection;
|
||||
using System.Runtime.Serialization.Formatters.Binary;
|
||||
using System.Threading;
|
||||
using libsecondlife;
|
||||
using OpenSim.Framework;
|
||||
using OpenSim.Region.Environment.Scenes;
|
||||
using OpenSim.Region.ScriptEngine.Common;
|
||||
|
||||
namespace OpenSim.Region.ScriptEngine.LSOEngine
|
||||
{
|
||||
public class ScriptManager : OpenSim.Region.ScriptEngine.Common.ScriptEngineBase.ScriptManager
|
||||
{
|
||||
public ScriptManager(Common.ScriptEngineBase.ScriptEngine scriptEngine)
|
||||
: base(scriptEngine)
|
||||
{
|
||||
base.m_scriptEngine = scriptEngine;
|
||||
|
||||
}
|
||||
|
||||
// KEEP TRACK OF SCRIPTS <int id, whatever script>
|
||||
//internal Dictionary<uint, Dictionary<LLUUID, LSL_BaseClass>> Scripts = new Dictionary<uint, Dictionary<LLUUID, LSL_BaseClass>>();
|
||||
// LOAD SCRIPT
|
||||
// UNLOAD SCRIPT
|
||||
// PROVIDE SCRIPT WITH ITS INTERFACE TO OpenSim
|
||||
|
||||
public override void _StartScript(uint localID, LLUUID itemID, string Script)
|
||||
{
|
||||
//IScriptHost root = host.GetRoot();
|
||||
Console.WriteLine("ScriptManager StartScript: localID: " + localID + ", itemID: " + itemID);
|
||||
|
||||
// We will initialize and start the script.
|
||||
// It will be up to the script itself to hook up the correct events.
|
||||
string ScriptSource = "";
|
||||
|
||||
SceneObjectPart m_host = World.GetSceneObjectPart(localID);
|
||||
|
||||
try
|
||||
{
|
||||
// Compile (We assume LSL)
|
||||
//ScriptSource = LSLCompiler.CompileFromLSLText(Script);
|
||||
|
||||
#if DEBUG
|
||||
long before;
|
||||
before = GC.GetTotalMemory(true);
|
||||
#endif
|
||||
|
||||
IScript CompiledScript;
|
||||
CompiledScript = m_scriptEngine.m_AppDomainManager.LoadScript(ScriptSource);
|
||||
|
||||
#if DEBUG
|
||||
Console.WriteLine("Script " + itemID + " occupies {0} bytes", GC.GetTotalMemory(true) - before);
|
||||
#endif
|
||||
|
||||
CompiledScript.Source = ScriptSource;
|
||||
// Add it to our script memstruct
|
||||
SetScript(localID, itemID, CompiledScript);
|
||||
|
||||
// We need to give (untrusted) assembly a private instance of BuiltIns
|
||||
// this private copy will contain Read-Only FullitemID so that it can bring that on to the server whenever needed.
|
||||
|
||||
|
||||
LSL_BuiltIn_Commands LSLB = new LSL_BuiltIn_Commands(m_scriptEngine, m_host, localID, itemID);
|
||||
|
||||
// Start the script - giving it BuiltIns
|
||||
CompiledScript.Start(LSLB);
|
||||
|
||||
// Fire the first start-event
|
||||
m_scriptEngine.m_EventQueueManager.AddToScriptQueue(localID, itemID, "state_entry", new object[] { });
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
//m_scriptEngine.Log.Error("ScriptEngine", "Error compiling script: " + e.ToString());
|
||||
try
|
||||
{
|
||||
// DISPLAY ERROR INWORLD
|
||||
string text = "Error compiling script:\r\n" + e.Message.ToString();
|
||||
if (text.Length > 1500)
|
||||
text = text.Substring(0, 1500);
|
||||
World.SimChat(Helpers.StringToField(text), ChatTypeEnum.Say, 0, m_host.AbsolutePosition,
|
||||
m_host.Name, m_host.UUID);
|
||||
}
|
||||
catch (Exception e2)
|
||||
{
|
||||
m_scriptEngine.Log.Error("ScriptEngine", "Error displaying error in-world: " + e2.ToString());
|
||||
m_scriptEngine.Log.Error("ScriptEngine",
|
||||
"Errormessage: Error compiling script:\r\n" + e.Message.ToString());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public override void _StopScript(uint localID, LLUUID itemID)
|
||||
{
|
||||
// Stop script
|
||||
Console.WriteLine("Stop script localID: " + localID + " LLUID: " + itemID.ToString());
|
||||
|
||||
|
||||
// Stop long command on script
|
||||
m_scriptEngine.m_LSLLongCmdHandler.RemoveScript(localID, itemID);
|
||||
|
||||
IScript LSLBC = GetScript(localID, itemID);
|
||||
if (LSLBC == null)
|
||||
return;
|
||||
|
||||
// TEMP: First serialize it
|
||||
//GetSerializedScript(localID, itemID);
|
||||
|
||||
|
||||
try
|
||||
{
|
||||
// Get AppDomain
|
||||
AppDomain ad = LSLBC.Exec.GetAppDomain();
|
||||
// Tell script not to accept new requests
|
||||
GetScript(localID, itemID).Exec.StopScript();
|
||||
// Remove from internal structure
|
||||
RemoveScript(localID, itemID);
|
||||
// Tell AppDomain that we have stopped script
|
||||
m_scriptEngine.m_AppDomainManager.StopScript(ad);
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
Console.WriteLine("Exception stopping script localID: " + localID + " LLUID: " + itemID.ToString() +
|
||||
": " + e.ToString());
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue