// 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/interpreter/action.h" #include #include #include #include #include #include "executable_semantics/ast/expression.h" #include "executable_semantics/ast/function_definition.h" #include "executable_semantics/interpreter/stack.h" namespace Carbon { auto Action::MakeLValAction(const Expression* e) -> Action* { auto* act = new Action(); act->value = LValAction({.exp = e}); return act; } auto Action::MakeExpressionAction(const Expression* e) -> Action* { auto* act = new Action(); act->value = ExpressionAction({.exp = e}); return act; } auto Action::MakeStatementAction(const Statement* s) -> Action* { auto* act = new Action(); act->value = StatementAction({.stmt = s}); return act; } auto Action::MakeValAction(const Value* v) -> Action* { auto* act = new Action(); act->value = ValAction({.val = v}); return act; } auto Action::GetLValAction() const -> const LValAction& { return std::get(value); } auto Action::GetExpressionAction() const -> const ExpressionAction& { return std::get(value); } auto Action::GetStatementAction() const -> const StatementAction& { return std::get(value); } auto Action::GetValAction() const -> const ValAction& { return std::get(value); } void Action::Print(llvm::raw_ostream& out) const { switch (tag()) { case ActionKind::LValAction: out << *GetLValAction().exp; break; case ActionKind::ExpressionAction: out << *GetExpressionAction().exp; break; case ActionKind::StatementAction: GetStatementAction().stmt->PrintDepth(1, out); break; case ActionKind::ValAction: out << *GetValAction().val; break; } out << "<" << pos << ">"; if (results.size() > 0) { out << "("; for (auto& result : results) { if (result) { out << *result; } out << ","; } out << ")"; } } void Action::PrintList(Stack ls, llvm::raw_ostream& out) { if (!ls.IsEmpty()) { out << *ls.Pop(); if (!ls.IsEmpty()) { out << " :: "; PrintList(ls, out); } } } } // namespace Carbon