// 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/syntax/syntax_helpers.h" #include "common/check.h" #include "common/ostream.h" #include "executable_semantics/common/arena.h" #include "executable_semantics/common/tracing_flag.h" #include "executable_semantics/interpreter/interpreter.h" #include "executable_semantics/interpreter/typecheck.h" namespace Carbon { // Adds builtins, currently only Print(). Note Print() is experimental, not // standardized, but is made available for printing state in tests. static void AddIntrinsics(std::list>* fs) { std::vector print_fields = {TuplePattern::Field( "0", global_arena->RawNew( -1, "format_str", global_arena->RawNew( global_arena->RawNew(-1))))}; auto* print_return = global_arena->RawNew( -1, global_arena->RawNew( IntrinsicExpression::IntrinsicKind::Print), false); auto print = global_arena->New( global_arena->RawNew( -1, "Print", std::vector(), global_arena->RawNew(-1, print_fields), global_arena->RawNew( global_arena->RawNew(-1)), /*is_omitted_return_type=*/false, print_return)); fs->insert(fs->begin(), print); } void ExecProgram(std::list> fs) { AddIntrinsics(&fs); if (tracing_output) { llvm::outs() << "********** source program **********\n"; for (const auto decl : fs) { llvm::outs() << *decl; } llvm::outs() << "********** type checking **********\n"; } state = global_arena->RawNew(); // Compile-time state. TypeCheckContext p = TopLevel(fs); TypeEnv top = p.types; Env ct_top = p.values; std::list> new_decls; for (const auto decl : fs) { new_decls.push_back(MakeTypeChecked(decl, top, ct_top)); } if (tracing_output) { llvm::outs() << "\n"; llvm::outs() << "********** type checking complete **********\n"; for (const auto decl : new_decls) { llvm::outs() << *decl; } llvm::outs() << "********** starting execution **********\n"; } int result = InterpProgram(new_decls); llvm::outs() << "result: " << result << "\n"; } } // namespace Carbon