| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293 |
- // Part of the Carbon Language project, under the Apache License v2.0 with LLVM
- // Exceptions. See /LICENSE for license information.
- // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
- #include "executable_semantics/main.h"
- #include <unistd.h>
- #include <cstdio>
- #include <cstring>
- #include <iostream>
- #include <optional>
- #include <string>
- #include <vector>
- #include "common/error.h"
- #include "executable_semantics/common/arena.h"
- #include "executable_semantics/common/nonnull.h"
- #include "executable_semantics/interpreter/exec_program.h"
- #include "executable_semantics/syntax/parse.h"
- #include "executable_semantics/syntax/prelude.h"
- #include "llvm/Support/CommandLine.h"
- #include "llvm/Support/InitLLVM.h"
- #include "llvm/Support/raw_ostream.h"
- namespace Carbon {
- namespace cl = llvm::cl;
- static auto Main(llvm::StringRef default_prelude_file, int argc, char* argv[])
- -> ErrorOr<Success> {
- llvm::setBugReportMsg(
- "Please report issues to "
- "https://github.com/carbon-language/carbon-lang/issues and include the "
- "crash backtrace.\n");
- llvm::InitLLVM init_llvm(argc, argv);
- // Printing to stderr should flush stdout. This is most noticeable when stderr
- // is piped to stdout.
- llvm::errs().tie(&llvm::outs());
- cl::opt<std::string> input_file_name(cl::Positional, cl::desc("<input file>"),
- cl::Required);
- cl::opt<bool> parser_debug("parser_debug",
- cl::desc("Enable debug output from the parser"));
- cl::opt<std::string> trace_file_name(
- "trace_file",
- cl::desc("Output file for tracing; set to `-` to output to stdout."));
- // Find the path of the executable if possible and use that as a relative root
- cl::opt<std::string> prelude_file_name("prelude", cl::desc("<prelude file>"),
- cl::init(default_prelude_file.str()));
- cl::ParseCommandLineOptions(argc, argv);
- // Set up a stream for trace output.
- std::unique_ptr<llvm::raw_ostream> scoped_trace_stream;
- std::optional<Nonnull<llvm::raw_ostream*>> trace_stream;
- if (!trace_file_name.empty()) {
- if (trace_file_name == "-") {
- trace_stream = &llvm::outs();
- } else {
- std::error_code err;
- scoped_trace_stream =
- std::make_unique<llvm::raw_fd_ostream>(trace_file_name, err);
- if (err) {
- return Error(err.message());
- }
- trace_stream = scoped_trace_stream.get();
- }
- }
- Arena arena;
- ASSIGN_OR_RETURN(AST ast, Parse(&arena, input_file_name, parser_debug));
- AddPrelude(prelude_file_name, &arena, &ast.declarations);
- // Typecheck and run the parsed program.
- ASSIGN_OR_RETURN(int return_code, ExecProgram(&arena, ast, trace_stream));
- // Print the return code to stdout even when we aren't tracing.
- (trace_stream ? **trace_stream : llvm::outs())
- << "result: " << return_code << "\n";
- return Success();
- }
- auto ExecutableSemanticsMain(llvm::StringRef default_prelude_file, int argc,
- char** argv) -> int {
- if (auto result = Main(default_prelude_file, argc, argv); !result.ok()) {
- llvm::errs() << result.error().message() << "\n";
- return EXIT_FAILURE;
- }
- return EXIT_SUCCESS;
- }
- } // namespace Carbon
|