예제 #1
0
        static int Main(string[] args)
        {
            var enc = new UTF8Encoding(false);

            Console.OutputEncoding = enc;
            Console.InputEncoding  = enc;
            ParseNode module;
            string    filename              = null;
            string    mode                  = "run";
            string    prettyOption          = "";
            bool      verbose               = false;
            string    errorCodeTarget       = null;
            var       lines                 = new List <string>();
            string    builtinsExtensionFile = null;
            int       lastArgs              = 0;

            for (int i = 0; i < args.Length; i++)
            {
                var arg = args[i];
                lastArgs = i;
                if (arg == "--help")
                {
                    return(help());
                }
                if (arg == "--about")
                {
                    return(about(i + 1 < args.Length ? args[i + 1] : null));
                }
                if (arg == "--parse-tree")
                {
                    mode = "parse-tree";
                }
                else if (arg.StartsWith("--pretty-print="))
                {
                    mode         = "pretty-print";
                    prettyOption = arg.Substring(15);
                }
                else if (arg == "--pretty-print")
                {
                    mode = "pretty-print";
                }
                else if (arg == "--execution-tree")
                {
                    mode = "execution-tree";
                }
                else if (arg == "--no-run")
                {
                    mode = "no-run";
                }
                else if (arg == "--repl")
                {
                    mode = "repl";
                }
                else if (arg == "--ws")
                {
                    mode = "ws";
                }
                else if (arg == "--verbose")
                {
                    Interpreter.ActivateDebuggingMessages();
                    verbose = true;
                }
                else if (arg == "--builtins-extension")
                {
                    builtinsExtensionFile = args[++i];
                }
                else if (arg == "--errors-to-file")
                {
                    errorCodeTarget = args[++i];
                }
                else if (arg == "-c")
                {
                    mode = "line";
                    if (i >= args.Length - 1)
                    {
                        return(error("Expected code argument after `-c`."));
                    }
                    lines.Add(args[++i]);
                }
                else if (arg == "--")
                {
                    if (i < args.Length - 1)
                    {
                        filename = args[++i];
                    }
                    i++;
                    break;
                }
                else if (arg.StartsWith("-"))
                {
                    return(error("Unknown option `" + arg + "`."));
                }
                else
                {
                    filename = arg;
                    break;
                }
            }

            for (int i = lastArgs + 1; i < args.Length; i++)
            {
                UnusedArgs.Add(args[i]);
            }

            if (mode == "repl" || (mode == "run" && filename == null))
            {
                return(repl(filename, builtinsExtensionFile));
            }
            if (mode == "ws")
            {
                return(WebSocketEndpoint.WSServe());
            }
            if (filename == null && lines.Count == 0)
            {
                return(error("Required filename argument missing."));
            }
            if (!File.Exists(filename) && lines.Count == 0)
            {
                return(error("File `" + filename + "` does not exist."));
            }
            var interp = new Interpreter();

            if (filename != null)
            {
                interp.AddModuleRoot(
                    Path.GetDirectoryName(Path.GetFullPath(filename)));
            }

            interp.AddModuleRoot(Path.GetFullPath("."));

            interp.FailedImportHook = promptInstallModule;
            interp.LoadPrelude();
            if (builtinsExtensionFile != null)
            {
                interp.LoadExtensionFile(builtinsExtensionFile);
            }
            else
            {
                interp.LoadExtensionFile();
            }
            if (runLines(interp, lines) != 0)
            {
                return(1);
            }
            if (filename == null)
            {
                return(0);
            }
            using (StreamReader reader = File.OpenText(filename))
            {
                Parser parser = new Parser(
                    Path.GetFileNameWithoutExtension(filename),
                    reader.ReadToEnd());
                try
                {
                    //Console.WriteLine("========== PARSING ==========");
                    module = parser.Parse();
                    if (mode == "parse-tree")
                    {
                        module.DebugPrint(System.Console.Out, "");
                        return(0);
                    }
                    if (mode == "pretty-print")
                    {
                        Console.Write(
                            ParseNodeMeta.PrettyPrintModule(
                                interp,
                                (ObjectParseNode)module,
                                prettyOption == "semicolons"));
                        return(0);
                    }
                    //Console.WriteLine("========== TRANSLATING ==========");
                    ExecutionTreeTranslator ett = new ExecutionTreeTranslator();
                    Node eModule = ett.Translate(module as ObjectParseNode);
                    if (mode == "execution-tree")
                    {
                        eModule.DebugPrint(Console.Out, "");
                        return(0);
                    }
                    if (mode == "no-run")
                    {
                        return(0);
                    }
                    interp.EnterModule(
                        Path.GetFileNameWithoutExtension(filename));
                    try
                    {
                        eModule.Evaluate(interp);
                    }
                    catch (GraceExceptionPacketException e)
                    {
                        System.Console.Error.WriteLine("Uncaught exception:");
                        ErrorReporting.WriteException(e.ExceptionPacket);
                        if (e.ExceptionPacket.StackTrace != null)
                        {
                            foreach (var l in e.ExceptionPacket.StackTrace)
                            {
                                System.Console.Error.WriteLine("    from "
                                                               + l);
                            }
                        }
                        return(1);
                    }
                }
                catch (StaticErrorException e)
                {
                    if (verbose)
                    {
                        System.Console.WriteLine(e.StackTrace);
                    }
                    if (errorCodeTarget != null)
                    {
                        File.WriteAllText(errorCodeTarget, e.Code);
                    }
                    ErrorReporting.WriteAllRecorded();
                    return(1);
                }
                catch (Exception e)
                {
                    System.Console.Error.WriteLine(
                        "An internal error occurred. "
                        + "Debugging information follows.");
                    System.Console.Error.WriteLine("Runtime version: "
                                                   + Interpreter.GetRuntimeVersion());
                    System.Console.Error.WriteLine(e);
                    System.Console.Error.WriteLine(e.StackTrace);
                    var gepe = e as GraceExceptionPacketException;
                    if (gepe != null)
                    {
                        System.Console.Error.WriteLine("\nThe error was a native Grace exception, whose information follows:");
                        var gep = gepe.ExceptionPacket;
                        System.Console.Error.WriteLine(gep.Description);
                        foreach (var l in gep.StackTrace)
                        {
                            System.Console.Error.WriteLine("  " + l);
                        }
                    }
                    System.Console.Error.WriteLine(
                        "\nAn internal error occurred. "
                        + "This is a bug in the implementation.");
                    return(1);
                }
            }
            return(0);
        }
예제 #2
0
        private static int runModule(string code, string modname,
                                     string mode, WSOutputSink sink)
        {
            var interp = new Interpreter(sink);

            ErrorReporting.SetSink(new OutputSinkWrapper(Console.Error));
            interp.RPCSink = sink;
            interp.AddModuleRoot(Path.GetFullPath("."));
            interp.FailedImportHook = loadCachedModule;
            interp.LoadPrelude();
            Parser    parser = new Parser(modname, code);
            ParseNode module;

            try
            {
                module = parser.Parse();
                ExecutionTreeTranslator ett = new ExecutionTreeTranslator();
                Node eModule = ett.Translate(module as ObjectParseNode);
                sink.SendEvent("build-succeeded", modname);
                if (mode == "build")
                {
                    return(0);
                }
                interp.EnterModule(modname);
                try
                {
                    eModule.Evaluate(interp);
                }
                catch (GraceExceptionPacketException ex)
                {
                    sink.SendRuntimeError(ex.ExceptionPacket.Description,
                                          ex.ExceptionPacket.StackTrace);
                }
            }
            catch (StaticErrorException ex)
            {
                sink.SendStaticError(ex.Code, ex.Module, ex.Line,
                                     ex.Message);
            }
            catch (ThreadAbortException)
            {
                throw;
            }
            catch (WebSocketClosedException)
            {
                return(0);
            }
            catch (Exception ex)
            {
                System.Console.Error.WriteLine(
                    "An internal error occurred. "
                    + "Debugging information follows.");
                System.Console.Error.WriteLine("Runtime version: "
                                               + Interpreter.GetRuntimeVersion());
                System.Console.Error.WriteLine(ex);
                System.Console.Error.WriteLine(ex.StackTrace);
                System.Console.Error.WriteLine(
                    "\nAn internal error occurred. "
                    + "This is a bug in the implementation.");
            }
            sink.SendEvent("execution-complete", modname);
            return(0);
        }