statement.h 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  1. // Part of the Carbon Language project, under the Apache License v2.0 with LLVM
  2. // Exceptions. See /LICENSE for license information.
  3. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
  4. #ifndef EXECUTABLE_SEMANTICS_AST_STATEMENT_H_
  5. #define EXECUTABLE_SEMANTICS_AST_STATEMENT_H_
  6. #include <list>
  7. #include "common/ostream.h"
  8. #include "executable_semantics/ast/expression.h"
  9. #include "executable_semantics/ast/pattern.h"
  10. #include "llvm/Support/Compiler.h"
  11. namespace Carbon {
  12. enum class StatementKind {
  13. ExpressionStatement,
  14. Assign,
  15. VariableDefinition,
  16. If,
  17. Return,
  18. Sequence,
  19. Block,
  20. While,
  21. Break,
  22. Continue,
  23. Match,
  24. Continuation, // Create a first-class continuation.
  25. Run, // Run a continuation to the next await or until it finishes..
  26. Await, // Pause execution of the continuation.
  27. };
  28. struct Statement;
  29. struct ExpressionStatement {
  30. static constexpr StatementKind Kind = StatementKind::ExpressionStatement;
  31. const Expression* exp;
  32. };
  33. struct Assign {
  34. static constexpr StatementKind Kind = StatementKind::Assign;
  35. const Expression* lhs;
  36. const Expression* rhs;
  37. };
  38. struct VariableDefinition {
  39. static constexpr StatementKind Kind = StatementKind::VariableDefinition;
  40. const Pattern* pat;
  41. const Expression* init;
  42. };
  43. struct If {
  44. static constexpr StatementKind Kind = StatementKind::If;
  45. const Expression* cond;
  46. const Statement* then_stmt;
  47. const Statement* else_stmt;
  48. };
  49. struct Return {
  50. static constexpr StatementKind Kind = StatementKind::Return;
  51. const Expression* exp;
  52. bool is_omitted_exp;
  53. };
  54. struct Sequence {
  55. static constexpr StatementKind Kind = StatementKind::Sequence;
  56. const Statement* stmt;
  57. const Statement* next;
  58. };
  59. struct Block {
  60. static constexpr StatementKind Kind = StatementKind::Block;
  61. const Statement* stmt;
  62. };
  63. struct While {
  64. static constexpr StatementKind Kind = StatementKind::While;
  65. const Expression* cond;
  66. const Statement* body;
  67. };
  68. struct Break {
  69. static constexpr StatementKind Kind = StatementKind::Break;
  70. };
  71. struct Continue {
  72. static constexpr StatementKind Kind = StatementKind::Continue;
  73. };
  74. struct Match {
  75. static constexpr StatementKind Kind = StatementKind::Match;
  76. const Expression* exp;
  77. std::list<std::pair<const Pattern*, const Statement*>>* clauses;
  78. };
  79. struct Continuation {
  80. static constexpr StatementKind Kind = StatementKind::Continuation;
  81. std::string continuation_variable;
  82. const Statement* body;
  83. };
  84. struct Run {
  85. static constexpr StatementKind Kind = StatementKind::Run;
  86. const Expression* argument;
  87. };
  88. struct Await {
  89. static constexpr StatementKind Kind = StatementKind::Await;
  90. };
  91. struct Statement {
  92. // Constructors
  93. static auto MakeExpressionStatement(int line_num, const Expression* exp)
  94. -> const Statement*;
  95. static auto MakeAssign(int line_num, const Expression* lhs,
  96. const Expression* rhs) -> const Statement*;
  97. static auto MakeVariableDefinition(int line_num, const Pattern* pat,
  98. const Expression* init)
  99. -> const Statement*;
  100. static auto MakeIf(int line_num, const Expression* cond,
  101. const Statement* then_stmt, const Statement* else_stmt)
  102. -> const Statement*;
  103. static auto MakeReturn(int line_num, const Expression* exp,
  104. bool is_omitted_exp) -> const Statement*;
  105. static auto MakeSequence(int line_num, const Statement* s1,
  106. const Statement* s2) -> const Statement*;
  107. static auto MakeBlock(int line_num, const Statement* s) -> const Statement*;
  108. static auto MakeWhile(int line_num, const Expression* cond,
  109. const Statement* body) -> const Statement*;
  110. static auto MakeBreak(int line_num) -> const Statement*;
  111. static auto MakeContinue(int line_num) -> const Statement*;
  112. static auto MakeMatch(
  113. int line_num, const Expression* exp,
  114. std::list<std::pair<const Pattern*, const Statement*>>* clauses)
  115. -> const Statement*;
  116. // Returns an AST node for a continuation statement give its line number and
  117. // contituent parts.
  118. //
  119. // __continuation <continuation_variable> {
  120. // <body>
  121. // }
  122. static auto MakeContinuation(int line_num, std::string continuation_variable,
  123. const Statement* body) -> const Statement*;
  124. // Returns an AST node for a run statement give its line number and argument.
  125. //
  126. // __run <argument>;
  127. static auto MakeRun(int line_num, const Expression* argument)
  128. -> const Statement*;
  129. // Returns an AST node for an await statement give its line number.
  130. //
  131. // __await;
  132. static auto MakeAwait(int line_num) -> const Statement*;
  133. auto GetExpressionStatement() const -> const ExpressionStatement&;
  134. auto GetAssign() const -> const Assign&;
  135. auto GetVariableDefinition() const -> const VariableDefinition&;
  136. auto GetIf() const -> const If&;
  137. auto GetReturn() const -> const Return&;
  138. auto GetSequence() const -> const Sequence&;
  139. auto GetBlock() const -> const Block&;
  140. auto GetWhile() const -> const While&;
  141. auto GetBreak() const -> const Break&;
  142. auto GetContinue() const -> const Continue&;
  143. auto GetMatch() const -> const Match&;
  144. auto GetContinuation() const -> const Continuation&;
  145. auto GetRun() const -> const Run&;
  146. auto GetAwait() const -> const Await&;
  147. void Print(llvm::raw_ostream& out) const { PrintDepth(-1, out); }
  148. void PrintDepth(int depth, llvm::raw_ostream& out) const;
  149. LLVM_DUMP_METHOD void Dump() const { Print(llvm::errs()); }
  150. inline auto tag() const -> StatementKind {
  151. return std::visit([](const auto& t) { return t.Kind; }, value);
  152. }
  153. int line_num;
  154. private:
  155. std::variant<ExpressionStatement, Assign, VariableDefinition, If, Return,
  156. Sequence, Block, While, Break, Continue, Match, Continuation,
  157. Run, Await>
  158. value;
  159. };
  160. } // namespace Carbon
  161. #endif // EXECUTABLE_SEMANTICS_AST_STATEMENT_H_