From f5955ab539d1484664af1dade973f78d724a0abd Mon Sep 17 00:00:00 2001 From: Tedd Hansen Date: Sun, 12 Aug 2007 13:38:16 +0000 Subject: Initial LSL to C# converter, not working yet! --- .../DotNetEngine/Compiler/LSL/LSL2CSConverter.cs | 156 +++++++++++++++++++++ 1 file changed, 156 insertions(+) create mode 100644 OpenSim/Region/ScriptEngine/DotNetEngine/Compiler/LSL/LSL2CSConverter.cs (limited to 'OpenSim/Region/ScriptEngine/DotNetEngine') diff --git a/OpenSim/Region/ScriptEngine/DotNetEngine/Compiler/LSL/LSL2CSConverter.cs b/OpenSim/Region/ScriptEngine/DotNetEngine/Compiler/LSL/LSL2CSConverter.cs new file mode 100644 index 0000000..b302274 --- /dev/null +++ b/OpenSim/Region/ScriptEngine/DotNetEngine/Compiler/LSL/LSL2CSConverter.cs @@ -0,0 +1,156 @@ +using System; +using System.Collections.Generic; +using System.Text; +using System.Text.RegularExpressions; + +namespace LSL2CS.Converter +{ + public class LSL2CSConverter + { + //private Regex rnw = new Regex(@"[a-zA-Z0-9_\-]", RegexOptions.Compiled); + private Dictionary DataTypes = new Dictionary(); + private Dictionary QUOTES = new Dictionary(); + + public LSL2CSConverter() + { + DataTypes.Add("void", "void"); + DataTypes.Add("integer", "int"); + DataTypes.Add("float", "float"); + DataTypes.Add("string", "string"); + DataTypes.Add("key", "string"); + DataTypes.Add("vector", "vector"); + DataTypes.Add("rotation", "rotation"); + DataTypes.Add("list", "list"); + DataTypes.Add("null", "null"); + } + + + + public string Convert(string Script) + { + string Return = ""; + + // + // Prepare script for processing + // + + // Here we will remove those linebreaks that are allowed in so many languages. + // One hard-ass regex should do the job. + + // Then we will add some linebreaks. + Script = Regex.Replace(Script, @"\r\n", "\n"); + Script = Regex.Replace(Script, @"\n", "\r\n"); + //Script = Regex.Replace(Script, @"\n\s*{", @"{"); + //Script = Regex.Replace(Script, @"[\r\n]", @""); + + // Then we remove unwanted linebreaks + + + //// + //// Split up script to process line by line + //// + //int count = 0; + //string line; + //Regex r = new Regex("\r?\n", RegexOptions.Multiline | RegexOptions.Compiled); + //string[] lines = r.Split(Script); + + //for (int i = 0; i < lines.Length; i++) + //{ + // // Remove space in front and back + // line = lines[i].Trim(); + // count++; + // Return += count + ". " + translate(line) + "\r\n"; + //} + + int level = 0; + bool Level0Set = false; + bool Level1Set = false; + + + // QUOTE REPLACEMENT + //char[] SA = Script.ToCharArray(); + string _Script = ""; + string C; + bool in_quote = false; + bool quote_replaced = false; + string quote_replacement_string = "Q_U_O_T_E_REPLACEMENT_"; + string quote = ""; + int quote_replaced_count = 0; + for (int p = 0; p < Script.Length; p++) + { + + while (true) { + C = Script.Substring(p,1); + if (C == "\"") { + // Toggle inside/outside quote + in_quote = ! in_quote; + if(in_quote) { + quote_replaced_count++; + } else { + // We just left a quote + QUOTES.Add(quote_replacement_string + quote_replaced_count.ToString().PadLeft(5, "0".ToCharArray()[0]), quote); + quote = ""; + } + break; + } + if (!in_quote) { + // We are not inside a quote + quote_replaced = false; + + } else { + // We are inside a quote + if (!quote_replaced) { + // Replace quote + _Script += quote_replacement_string + quote_replaced_count.ToString().PadLeft(5, "0".ToCharArray()[0]); + quote_replaced = true; + } + quote += C; + break; + } + _Script += C; + break; + } + } + // + // END OF QUOTE REPLACEMENT + // + + // Replace CAST - (integer) with (int) + Script = Regex.Replace(_Script, @"\(integer\)", @"(int)", RegexOptions.Compiled | RegexOptions.Multiline); + // Replace return types and function variables - integer a() and f(integer a, integer a) + _Script = Regex.Replace(Script, @"(^|[\(,])(\s*int)eger(\s*)", @"$1$2$3", RegexOptions.Compiled | RegexOptions.Multiline); + + // Add void to functions not having that + Script = Regex.Replace(_Script, @"^(\s*)((?!if|switch|for|foreach)[a-zA-Z0-9_]*\s*\([^\)]*\)[^;]*\{)", @"$1void $2", RegexOptions.Compiled | RegexOptions.Multiline | RegexOptions.Singleline); + + + // Replace int (TEMPORARY QUICKFIX) + //_Script = Regex.Replace(Script, "integer", "int", RegexOptions.Compiled); + + foreach (string key in QUOTES.Keys) + { + string val; + QUOTES.TryGetValue(key, out val); + _Script = Script.Replace(key, "\"" + val + "\""); + Script = _Script; + } + + + Return = Script; + + return Return; + } + //private string GetWord(char[] SA, int p) + //{ + // string ret = ""; + // for (int i = p; p < SA.Length; i++) + // { + // if (!rnw.IsMatch(SA[i].ToString())) + // break; + // ret += SA[i]; + // } + // return ret; + //} + + } +} -- cgit v1.1