Пример #1
0
        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;
        }
Пример #2
0
        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);
                }
            }
        }
Пример #3
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);
        }