Script compiler should now show error on correct line number in original LSL-script.
parent
2fd0e53425
commit
d9b9b16513
|
@ -57,7 +57,7 @@ namespace OpenSim.Region.ScriptEngine.Common
|
||||||
|
|
||||||
//type.InvokeMember(EventName, BindingFlags.InvokeMethod, null, m_Script, args);
|
//type.InvokeMember(EventName, BindingFlags.InvokeMethod, null, m_Script, args);
|
||||||
|
|
||||||
Console.WriteLine("ScriptEngine Executor.ExecuteEvent: \"" + EventName + "\"");
|
//Console.WriteLine("ScriptEngine Executor.ExecuteEvent: \"" + EventName + "\"");
|
||||||
|
|
||||||
if (Events.ContainsKey(EventName) == false)
|
if (Events.ContainsKey(EventName) == false)
|
||||||
{
|
{
|
||||||
|
@ -81,7 +81,7 @@ namespace OpenSim.Region.ScriptEngine.Common
|
||||||
|
|
||||||
if (ev == null) // No event by that name!
|
if (ev == null) // No event by that name!
|
||||||
{
|
{
|
||||||
Console.WriteLine("ScriptEngine Can not find any event named: \"" + EventName + "\"");
|
//Console.WriteLine("ScriptEngine Can not find any event named: \"" + EventName + "\"");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -87,6 +87,7 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler.LSL
|
||||||
//parameters.ReferencedAssemblies.Add("OpenSim.Region.Environment");
|
//parameters.ReferencedAssemblies.Add("OpenSim.Region.Environment");
|
||||||
parameters.GenerateExecutable = false;
|
parameters.GenerateExecutable = false;
|
||||||
parameters.OutputAssembly = OutFile;
|
parameters.OutputAssembly = OutFile;
|
||||||
|
//parameters.IncludeDebugInformation = false;
|
||||||
CompilerResults results = codeProvider.CompileAssemblyFromSource(parameters, Script);
|
CompilerResults results = codeProvider.CompileAssemblyFromSource(parameters, Script);
|
||||||
|
|
||||||
// Go through errors
|
// Go through errors
|
||||||
|
@ -97,7 +98,7 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler.LSL
|
||||||
string errtext = "";
|
string errtext = "";
|
||||||
foreach (CompilerError CompErr in results.Errors)
|
foreach (CompilerError CompErr in results.Errors)
|
||||||
{
|
{
|
||||||
errtext += "Line number " + CompErr.Line +
|
errtext += "Line number " + (CompErr.Line - 1) +
|
||||||
", Error Number: " + CompErr.ErrorNumber +
|
", Error Number: " + CompErr.ErrorNumber +
|
||||||
", '" + CompErr.ErrorText + "'\r\n";
|
", '" + CompErr.ErrorText + "'\r\n";
|
||||||
}
|
}
|
||||||
|
|
|
@ -152,7 +152,7 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler.LSL
|
||||||
in_state = true;
|
in_state = true;
|
||||||
current_statename = m.Groups[1].Captures[0].Value;
|
current_statename = m.Groups[1].Captures[0].Value;
|
||||||
//Console.WriteLine("Current statename: " + current_statename);
|
//Console.WriteLine("Current statename: " + current_statename);
|
||||||
cache = Regex.Replace(cache, @"(?![a-zA-Z_]+)\s*([a-zA-Z_]+)[^a-zA-Z_\(\)]*{", "", RegexOptions.Compiled | RegexOptions.Multiline | RegexOptions.Singleline);
|
cache = Regex.Replace(cache, @"(?<s1>(?![a-zA-Z_]+)\s*)" + @"([a-zA-Z_]+)(?<s2>[^a-zA-Z_\(\)]*){", "${s1}${s2}", RegexOptions.Compiled | RegexOptions.Multiline | RegexOptions.Singleline);
|
||||||
}
|
}
|
||||||
ret += cache;
|
ret += cache;
|
||||||
cache = "";
|
cache = "";
|
||||||
|
@ -169,7 +169,7 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler.LSL
|
||||||
// void dataserver(key query_id, string data) {
|
// void dataserver(key query_id, string data) {
|
||||||
//cache = Regex.Replace(cache, @"([^a-zA-Z_]\s*)((?!if|switch|for)[a-zA-Z_]+\s*\([^\)]*\)[^{]*{)", "$1" + "<STATE>" + "$2", RegexOptions.Compiled | RegexOptions.Multiline | RegexOptions.Singleline);
|
//cache = Regex.Replace(cache, @"([^a-zA-Z_]\s*)((?!if|switch|for)[a-zA-Z_]+\s*\([^\)]*\)[^{]*{)", "$1" + "<STATE>" + "$2", RegexOptions.Compiled | RegexOptions.Multiline | RegexOptions.Singleline);
|
||||||
//Console.WriteLine("Replacing using statename: " + current_statename);
|
//Console.WriteLine("Replacing using statename: " + current_statename);
|
||||||
cache = Regex.Replace(cache, @"^(\s*)((?!(if|switch|for)[^a-zA-Z0-9_])[a-zA-Z0-9_]*\s*\([^\)]*\)[^;]*\{)", @"public $1" + current_statename + "_event_$2", RegexOptions.Compiled | RegexOptions.Multiline | RegexOptions.Singleline);
|
cache = Regex.Replace(cache, @"^(\s*)((?!(if|switch|for)[^a-zA-Z0-9_])[a-zA-Z0-9_]*\s*\([^\)]*\)[^;]*\{)", @"$1public " + current_statename + "_event_$2", RegexOptions.Compiled | RegexOptions.Multiline | RegexOptions.Singleline);
|
||||||
}
|
}
|
||||||
|
|
||||||
ret += cache;
|
ret += cache;
|
||||||
|
@ -202,7 +202,7 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler.LSL
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add "void" in front of functions that needs it
|
// Add "void" in front of functions that needs it
|
||||||
Script = Regex.Replace(Script, @"^(\s*)((?!(if|switch|for)[^a-zA-Z0-9_])[a-zA-Z0-9_]*\s*\([^\)]*\)[^;]*\{)", @"$1void $2", RegexOptions.Compiled | RegexOptions.Multiline | RegexOptions.Singleline);
|
Script = Regex.Replace(Script, @"^(\s*public\s+)((?!(if|switch|for)[^a-zA-Z0-9_])[a-zA-Z0-9_]*\s*\([^\)]*\)[^;]*\{)", @"$1void $2", RegexOptions.Compiled | RegexOptions.Multiline | RegexOptions.Singleline);
|
||||||
|
|
||||||
// Replace <x,y,z> and <x,y,z,r>
|
// Replace <x,y,z> and <x,y,z,r>
|
||||||
Script = Regex.Replace(Script, @"<([^,>]*,[^,>]*,[^,>]*,[^,>]*)>", @"new LSL_Types.Quaternion($1)", RegexOptions.Compiled | RegexOptions.Multiline | RegexOptions.Singleline);
|
Script = Regex.Replace(Script, @"<([^,>]*,[^,>]*,[^,>]*,[^,>]*)>", @"new LSL_Types.Quaternion($1)", RegexOptions.Compiled | RegexOptions.Multiline | RegexOptions.Singleline);
|
||||||
|
@ -228,15 +228,15 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler.LSL
|
||||||
|
|
||||||
// Add namespace, class name and inheritance
|
// Add namespace, class name and inheritance
|
||||||
Return = "" +
|
Return = "" +
|
||||||
"using System;\r\n" +
|
"using System; " +
|
||||||
"using System.Collections.Generic;\r\n" +
|
"using System.Collections.Generic; " +
|
||||||
"using System.Text;\r\n" +
|
"using System.Text; " +
|
||||||
"using OpenSim.Region.ScriptEngine.Common;\r\n" +
|
"using OpenSim.Region.ScriptEngine.Common; " +
|
||||||
"namespace SecondLife {\r\n";
|
"namespace SecondLife { ";
|
||||||
Return += "" +
|
Return += "" +
|
||||||
//"[Serializable] " +
|
//"[Serializable] " +
|
||||||
"public class Script : OpenSim.Region.ScriptEngine.DotNetEngine.Compiler.LSL.LSL_BaseClass {\r\n";
|
"public class Script : OpenSim.Region.ScriptEngine.DotNetEngine.Compiler.LSL.LSL_BaseClass { ";
|
||||||
Return += @"public Script() { }"+"\r\n";
|
Return += @"public Script() { } ";
|
||||||
Return += Script;
|
Return += Script;
|
||||||
Return += "} }\r\n";
|
Return += "} }\r\n";
|
||||||
|
|
||||||
|
|
|
@ -123,6 +123,8 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine
|
||||||
}
|
}
|
||||||
catch (ThreadAbortException tae)
|
catch (ThreadAbortException tae)
|
||||||
{
|
{
|
||||||
|
string a = tae.ToString();
|
||||||
|
a = "";
|
||||||
// Expected
|
// Expected
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue