public void Trace() { if (funcs.Count <= 0) { return; } Console.Clear(); clr = ConsoleColor.Black; Console.WriteLine(String.Format("Path:\n\t{0}\nCode:\n\n{1}", path, original)); //Console.WriteLine("\nTokens:"); //for (int i = 0; i < tokens.Count; i++) // tokens[i].TraceMore(0); Console.WriteLine("\n\nVariables\n local\tname\t\ttype\t\tused\tadress"); for (int i = 0; i < variables.Count; i++) { variables[i].TraceMore(0); } if (GlobalVars.CommandCount > 0) { Console.Write(MISC.tabs(0)); MISC.ConsoleWriteLine("Global vars:", ConsoleColor.Black, ConsoleColor.Cyan); GlobalVars.Trace(1); } Console.WriteLine("\nFunctions:"); for (int i = 0; i < funcs.Count; i++) { if (funcs[i] != null) { MISC.ConsoleWriteLine(String.Format(" {0}: {1}", funcs[i].getName, funcs[i].getArgsString), ConsoleColor.Green); } else { MISC.ConsoleWriteLine(String.Format(" {0}:", "null"), ConsoleColor.DarkGreen); } } Console.WriteLine(); for (int i = 0; i < funcs.Count; i++) { if (funcs[i] != null) { clr = (funcs[i].getName.ToLower() == "main") ? ConsoleColor.DarkRed : ConsoleColor.DarkGreen; funcs[i].Trace(0); } } // TraceLLVM(); Console.ResetColor(); int allign = 6; Console.WriteLine(String.Format("\nTime spend, seconds:\n {0} - text parsed and trimmed\n {1} - AST tree builded\n {2} - LLVM IR generated\n" , (generatedTime[0] / 1000.0).ToString().PadRight(allign), (generatedTime[1] / 1000.0).ToString().PadRight(allign), (generatedTime[2] / 1000.0).ToString().PadRight(allign))); return; }
public void Trace() { if (funcs.Count <= 0) { return; } clr = ConsoleColor.Black; Console.WriteLine("\nTokens:"); for (int i = 0; i < tokens.Count; i++) { tokens[i].TraceMore(0); } Console.WriteLine("\nVariables"); for (int i = 0; i < variables.Count; i++) { variables[i].TraceMore(0); } Console.WriteLine("\nFunctions:"); for (int i = 0; i < funcs.Count; i++) { if (funcs[i] != null) { MISC.ConsoleWriteLine(String.Format(" {0}: {1}", funcs[i].getName, funcs[i].getArgsString), ConsoleColor.Green); } else { MISC.ConsoleWriteLine(String.Format(" {0}:", "null"), ConsoleColor.DarkGreen); } } Console.WriteLine(); if (GlobalVars.CommandCount > 0) { Console.Write(MISC.tabs(0)); MISC.ConsoleWriteLine("Global vars:", ConsoleColor.Black, ConsoleColor.Cyan); GlobalVars.Trace(1); } for (int i = 0; i < funcs.Count; i++) { if (funcs[i] != null) { clr = (funcs[i].getName.ToLower() == "main") ? ConsoleColor.DarkRed : ConsoleColor.DarkGreen; funcs[i].Trace(0); } } }
// public void Trace(int depth) { Console.Write(MISC.tabs(depth)); MISC.ConsoleWriteLine(String.Format("FUNCTION \"{0}\"", this.name), ConsoleColor.Black, ConsoleColor.Cyan); Console.Write(MISC.tabs(depth + 1)); MISC.ConsoleWriteLine("<<", ConsoleColor.Cyan); for (int i = 0; i < input.Count; i++) { if (i == input.Count - 1) { MISC.finish = true; } input[i].Trace(depth + 2); } Console.Write(MISC.tabs(depth + 1)); MISC.ConsoleWriteLine(">>", ConsoleColor.Cyan); MISC.finish = true; Console.Write(MISC.tabs(depth + 2)); MISC.ConsoleWriteLine(returnTypes().ToString(), ConsoleColor.Cyan); MISC.finish = true; actions.Trace(depth + 1); }