semantics_parse_tree_handler.h 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  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 CARBON_TOOLCHAIN_SEMANTICS_SEMANTICS_PARSE_TREE_HANDLER_H_
  5. #define CARBON_TOOLCHAIN_SEMANTICS_SEMANTICS_PARSE_TREE_HANDLER_H_
  6. #include "common/check.h"
  7. #include "toolchain/parser/parse_tree.h"
  8. #include "toolchain/semantics/semantics_ir.h"
  9. namespace Carbon {
  10. // Handles processing of a ParseTree for semantics.
  11. class SemanticsParseTreeHandler {
  12. public:
  13. // Stores references for work.
  14. explicit SemanticsParseTreeHandler(const TokenizedBuffer& tokens,
  15. const ParseTree& parse_tree,
  16. SemanticsIR& semantics)
  17. : tokens_(&tokens), parse_tree_(&parse_tree), semantics_(&semantics) {}
  18. // Outputs the ParseTree information into SemanticsIR.
  19. auto Build() -> void;
  20. private:
  21. struct TraversalStackEntry {
  22. ParseTree::Node parse_node;
  23. llvm::Optional<SemanticsNodeId> result_id;
  24. };
  25. auto Push(ParseTree::Node parse_node) -> void {
  26. node_stack_.push_back({parse_node, llvm::None});
  27. }
  28. auto Push(ParseTree::Node parse_node, SemanticsNode node) -> void {
  29. auto node_id = semantics_->AddNode(node);
  30. node_stack_.push_back({parse_node, node_id});
  31. }
  32. auto Pop(ParseNodeKind pop_parse_kind) -> void {
  33. auto back = node_stack_.back();
  34. auto parse_kind = parse_tree_->node_kind(back.parse_node);
  35. CARBON_CHECK(parse_kind == pop_parse_kind)
  36. << "Expected " << pop_parse_kind << ", found " << parse_kind;
  37. CARBON_CHECK(!back.result_id) << "Expected no result ID on " << parse_kind;
  38. node_stack_.pop_back();
  39. }
  40. auto PopWithResult() -> SemanticsNodeId {
  41. auto back = node_stack_.back();
  42. auto node_id = *back.result_id;
  43. node_stack_.pop_back();
  44. return node_id;
  45. }
  46. auto PopWithResult(ParseNodeKind pop_parse_kind) -> SemanticsNodeId {
  47. auto back = node_stack_.back();
  48. auto parse_kind = parse_tree_->node_kind(back.parse_node);
  49. auto node_id = *back.result_id;
  50. CARBON_CHECK(parse_kind == pop_parse_kind)
  51. << "Expected " << pop_parse_kind << ", found " << parse_kind;
  52. node_stack_.pop_back();
  53. return node_id;
  54. }
  55. // Parse node handlers.
  56. auto HandleDeclaredName(ParseTree::Node parse_node) -> void;
  57. auto HandleFunctionDefinition(ParseTree::Node parse_node) -> void;
  58. auto HandleFunctionDefinitionStart(ParseTree::Node parse_node) -> void;
  59. auto HandleInfixOperator(ParseTree::Node parse_node) -> void;
  60. auto HandleLiteral(ParseTree::Node parse_node) -> void;
  61. auto HandleParameterList(ParseTree::Node parse_node) -> void;
  62. auto HandleReturnStatement(ParseTree::Node parse_node) -> void;
  63. // Tokens for getting data on literals.
  64. const TokenizedBuffer* tokens_;
  65. // The file's parse tree.
  66. const ParseTree* parse_tree_;
  67. // The SemanticsIR being added to.
  68. SemanticsIR* semantics_;
  69. // The stack during Build. Will contain file-level parse nodes on return.
  70. llvm::SmallVector<TraversalStackEntry> node_stack_;
  71. };
  72. } // namespace Carbon
  73. #endif // CARBON_TOOLCHAIN_SEMANTICS_SEMANTICS_PARSE_TREE_HANDLER_H_