From 9a33a4733ef02fc6c5b8b9887173855f37a47638 Mon Sep 17 00:00:00 2001 From: Mike Mazur Date: Mon, 9 Feb 2009 00:59:02 +0000 Subject: [PATCH] Thanks Tommi Laukkanen for a patch that allows the CSCodeGeneratorTest.TestStringsWithEscapedQuotesAndComments unit test to pass on Windows. Fixes Mantis #3104. --- .../ScriptEngine/Shared/CodeTools/CSCodeGenerator.cs | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/OpenSim/Region/ScriptEngine/Shared/CodeTools/CSCodeGenerator.cs b/OpenSim/Region/ScriptEngine/Shared/CodeTools/CSCodeGenerator.cs index 37d29f7400..f9ab97b1b7 100644 --- a/OpenSim/Region/ScriptEngine/Shared/CodeTools/CSCodeGenerator.cs +++ b/OpenSim/Region/ScriptEngine/Shared/CodeTools/CSCodeGenerator.cs @@ -145,6 +145,10 @@ namespace OpenSim.Region.ScriptEngine.Shared.CodeTools m_braceCount--; //retstr += GenerateLine("}"); + // Removes all carriage return characters which may be generated in Windows platform. Is there + // cleaner way of doing this? + retstr=retstr.Replace("\r", ""); + return retstr; } @@ -711,7 +715,7 @@ namespace OpenSim.Region.ScriptEngine.Shared.CodeTools { string retstr = String.Empty; - // we wrap all typecasted statements in parentheses + // we wrap all typecasted statements in parentheses retstr += Generate(String.Format("({0}) (", te.TypecastType), te); retstr += GenerateNode((SYMBOL) te.kids.Pop()); retstr += Generate(")"); @@ -972,12 +976,12 @@ namespace OpenSim.Region.ScriptEngine.Shared.CodeTools /// /// Returns the passed name with an underscore prepended if that name is a reserved word in C# /// and not resevered in LSL otherwise it just returns the passed name. - /// + /// /// This makes no attempt to cache the results to minimise future lookups. For a non trivial /// scripts the number of unique identifiers could easily grow to the size of the reserved word /// list so maintaining a list or dictionary and doing the lookup there firstwould probably not /// give any real speed advantage. - /// + /// /// I believe there is a class Microsoft.CSharp.CSharpCodeProvider that has a function /// CreateValidIdentifier(str) that will return either the value of str if it is not a C# /// key word or "_"+str if it is. But availability under Mono?