handle_pattern_list.cpp 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  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. #include "toolchain/parse/context.h"
  5. namespace Carbon::Parse {
  6. // Handles PatternListElementAs(Implicit|Tuple).
  7. static auto HandlePatternListElement(Context& context, State pattern_state,
  8. State finish_state) -> void {
  9. context.PopAndDiscardState();
  10. context.PushState(finish_state);
  11. context.PushState(pattern_state);
  12. }
  13. auto HandlePatternListElementAsImplicit(Context& context) -> void {
  14. HandlePatternListElement(context, State::BindingPattern,
  15. State::PatternListElementFinishAsImplicit);
  16. }
  17. auto HandlePatternListElementAsTuple(Context& context) -> void {
  18. HandlePatternListElement(context, State::BindingPattern,
  19. State::PatternListElementFinishAsTuple);
  20. }
  21. // Handles PatternListElementFinishAs(Implicit|Tuple).
  22. static auto HandlePatternListElementFinish(Context& context,
  23. Lex::TokenKind close_token,
  24. State param_state) -> void {
  25. auto state = context.PopState();
  26. if (state.has_error) {
  27. context.ReturnErrorOnState();
  28. }
  29. if (context.ConsumeListToken(NodeKind::PatternListComma, close_token,
  30. state.has_error) ==
  31. Context::ListTokenKind::Comma) {
  32. context.PushState(param_state);
  33. }
  34. }
  35. auto HandlePatternListElementFinishAsImplicit(Context& context) -> void {
  36. HandlePatternListElementFinish(context, Lex::TokenKind::CloseSquareBracket,
  37. State::PatternListElementAsImplicit);
  38. }
  39. auto HandlePatternListElementFinishAsTuple(Context& context) -> void {
  40. HandlePatternListElementFinish(context, Lex::TokenKind::CloseParen,
  41. State::PatternListElementAsTuple);
  42. }
  43. // Handles PatternListAs(Implicit|Tuple).
  44. static auto HandlePatternList(Context& context, NodeKind parse_node_kind,
  45. Lex::TokenKind open_token_kind,
  46. Lex::TokenKind close_token_kind,
  47. State param_state, State finish_state) -> void {
  48. context.PopAndDiscardState();
  49. context.PushState(finish_state);
  50. context.AddLeafNode(parse_node_kind, context.ConsumeChecked(open_token_kind));
  51. if (!context.PositionIs(close_token_kind)) {
  52. context.PushState(param_state);
  53. }
  54. }
  55. auto HandlePatternListAsImplicit(Context& context) -> void {
  56. HandlePatternList(
  57. context, NodeKind::ImplicitParamListStart,
  58. Lex::TokenKind::OpenSquareBracket, Lex::TokenKind::CloseSquareBracket,
  59. State::PatternListElementAsImplicit, State::PatternListFinishAsImplicit);
  60. }
  61. auto HandlePatternListAsTuple(Context& context) -> void {
  62. HandlePatternList(context, NodeKind::TuplePatternStart,
  63. Lex::TokenKind::OpenParen, Lex::TokenKind::CloseParen,
  64. State::PatternListElementAsTuple,
  65. State::PatternListFinishAsTuple);
  66. }
  67. // Handles PatternListFinishAs(Implicit|Tuple).
  68. static auto HandlePatternListFinish(Context& context, NodeKind parse_node_kind,
  69. Lex::TokenKind token_kind) -> void {
  70. auto state = context.PopState();
  71. context.AddNode(parse_node_kind, context.ConsumeChecked(token_kind),
  72. state.subtree_start, state.has_error);
  73. }
  74. auto HandlePatternListFinishAsImplicit(Context& context) -> void {
  75. HandlePatternListFinish(context, NodeKind::ImplicitParamList,
  76. Lex::TokenKind::CloseSquareBracket);
  77. }
  78. auto HandlePatternListFinishAsTuple(Context& context) -> void {
  79. HandlePatternListFinish(context, NodeKind::TuplePattern,
  80. Lex::TokenKind::CloseParen);
  81. }
  82. } // namespace Carbon::Parse