From f9e2f41d7c7906db6e09d3ee4ed6f508df847344 Mon Sep 17 00:00:00 2001 From: Mike Mazur Date: Wed, 23 Jul 2008 06:53:38 +0000 Subject: [PATCH] Enable LSL <-> C# source location mapping when reporing compiler errors to the user in-world. This method is not yet perfect but is an improvement in accuracy over the existing method. --- .../DotNetEngine/Compiler/LSL/Compiler.cs | 16 ++++++++++ .../ScriptEngine/Shared/CodeTools/Compiler.cs | 31 +++++++++++++++++-- 2 files changed, 44 insertions(+), 3 deletions(-) diff --git a/OpenSim/Region/ScriptEngine/DotNetEngine/Compiler/LSL/Compiler.cs b/OpenSim/Region/ScriptEngine/DotNetEngine/Compiler/LSL/Compiler.cs index 73894d5c91..e2e8d36088 100644 --- a/OpenSim/Region/ScriptEngine/DotNetEngine/Compiler/LSL/Compiler.cs +++ b/OpenSim/Region/ScriptEngine/DotNetEngine/Compiler/LSL/Compiler.cs @@ -74,6 +74,7 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler.LSL private static LSL2CSConverter LSL_Converter = new LSL2CSConverter(); //private static CSCodeGenerator LSL_Converter = new CSCodeGenerator(); + //private static Dictionary, KeyValuePair> m_positionMap; // mapping between LSL and C# line/column numbers private static CSharpCodeProvider CScodeProvider = new CSharpCodeProvider(); private static VBCodeProvider VBcodeProvider = new VBCodeProvider(); private static JScriptCodeProvider JScodeProvider = new JScriptCodeProvider(); @@ -277,6 +278,7 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler.LSL // Its LSL, convert it to C# compileScript = LSL_Converter.Convert(Script); //compileScript = LSL_Converter.Convert(Script); + //m_positionMap = LSL_Converter.PositionMap; l = enumCompileType.cs; } @@ -481,6 +483,20 @@ namespace OpenSim.Region.ScriptEngine.DotNetEngine.Compiler.LSL string errtext = String.Empty; foreach (CompilerError CompErr in results.Errors) { + //KeyValuePair lslPos; + + //try + //{ + // lslPos = m_positionMap[new KeyValuePair(CompErr.Line, CompErr.Column)]; + //} + //catch (KeyNotFoundException) // we don't have this line/column mapped + //{ + // lslPos = new KeyValuePair(-1, -1); + //} + + // The Second Life viewer's script editor begins + // countingn lines and columns at 0, so we subtract 1. + //errtext += String.Format("Line {0}, column {1}, Error Number: {2}, '{3}'\r\n", lslPos.Key - 1, lslPos.Value - 1, CompErr.ErrorNumber, CompErr.ErrorText); errtext += "Line number " + (CompErr.Line - LinesToRemoveOnError) + ", Error Number: " + CompErr.ErrorNumber + ", '" + CompErr.ErrorText + "'\r\n"; diff --git a/OpenSim/Region/ScriptEngine/Shared/CodeTools/Compiler.cs b/OpenSim/Region/ScriptEngine/Shared/CodeTools/Compiler.cs index a8c61edec4..f7b6d08497 100644 --- a/OpenSim/Region/ScriptEngine/Shared/CodeTools/Compiler.cs +++ b/OpenSim/Region/ScriptEngine/Shared/CodeTools/Compiler.cs @@ -73,6 +73,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.CodeTools private string ScriptEnginesPath = "ScriptEngines"; private static ICodeConverter LSL_Converter; + private static Dictionary, KeyValuePair> m_positionMap; // mapping between LSL and C# line/column numbers private static CSharpCodeProvider CScodeProvider = new CSharpCodeProvider(); private static VBCodeProvider VBcodeProvider = new VBCodeProvider(); private static JScriptCodeProvider JScodeProvider = new JScriptCodeProvider(); @@ -331,6 +332,10 @@ namespace OpenSim.Region.ScriptEngine.Shared.CodeTools else LSL_Converter = (ICodeConverter)new LSL2CSConverter(); compileScript = LSL_Converter.Convert(Script); + + if (m_UseCompiler) + m_positionMap = ((CSCodeGenerator) LSL_Converter).PositionMap; + l = enumCompileType.cs; } @@ -540,9 +545,29 @@ namespace OpenSim.Region.ScriptEngine.Shared.CodeTools string errtext = String.Empty; foreach (CompilerError CompErr in results.Errors) { - errtext += "Line number " + (CompErr.Line - LinesToRemoveOnError) + - ", Error Number: " + CompErr.ErrorNumber + - ", '" + CompErr.ErrorText + "'\r\n"; + if (m_UseCompiler) + { + KeyValuePair lslPos; + + try + { + lslPos = m_positionMap[new KeyValuePair(CompErr.Line, CompErr.Column)]; + } + catch (KeyNotFoundException) // we don't have this line/column mapped + { + lslPos = new KeyValuePair(-1, -1); + } + + // The Second Life viewer's script editor begins + // countingn lines and columns at 0, so we subtract 1. + errtext += String.Format("Line {0}, column {1}, Error Number: {2}, '{3}'\r\n", lslPos.Key - 1, lslPos.Value - 1, CompErr.ErrorNumber, CompErr.ErrorText); + } + else + { + errtext += "Line number " + (CompErr.Line - LinesToRemoveOnError) + + ", Error Number: " + CompErr.ErrorNumber + + ", '" + CompErr.ErrorText + "'\r\n"; + } } Console.WriteLine("[COMPILER ERROR]:" + errtext); if (!File.Exists(OutFile))