handle_pattern_list.cpp 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  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. #include "toolchain/parse/handle.h"
  6. namespace Carbon::Parse {
  7. // Handles PatternListElementAs(Tuple|Explicit|Implicit).
  8. static auto HandlePatternListElement(Context& context, StateKind pattern_state,
  9. StateKind finish_state_kind) -> void {
  10. auto state = context.PopState();
  11. context.PushStateForPattern(finish_state_kind, state.in_var_pattern,
  12. state.in_unused_pattern);
  13. context.PushStateForPattern(pattern_state, state.in_var_pattern,
  14. state.in_unused_pattern);
  15. }
  16. auto HandlePatternListElementAsTuple(Context& context) -> void {
  17. HandlePatternListElement(context, StateKind::Pattern,
  18. StateKind::PatternListElementFinishAsTuple);
  19. }
  20. auto HandlePatternListElementAsExplicit(Context& context) -> void {
  21. HandlePatternListElement(context, StateKind::Pattern,
  22. StateKind::PatternListElementFinishAsExplicit);
  23. }
  24. auto HandlePatternListElementAsImplicit(Context& context) -> void {
  25. HandlePatternListElement(context, StateKind::Pattern,
  26. StateKind::PatternListElementFinishAsImplicit);
  27. }
  28. // Handles PatternListElementFinishAs(Tuple|Explicit|Implicit).
  29. static auto HandlePatternListElementFinish(Context& context,
  30. Lex::TokenKind close_token,
  31. StateKind param_state_kind) -> void {
  32. auto state = context.PopState();
  33. if (state.has_error) {
  34. context.ReturnErrorOnState();
  35. }
  36. if (context.ConsumeListToken(NodeKind::PatternListComma, close_token,
  37. state.has_error) ==
  38. Context::ListTokenKind::Comma) {
  39. context.PushStateForPattern(param_state_kind, state.in_var_pattern,
  40. state.in_unused_pattern);
  41. }
  42. }
  43. auto HandlePatternListElementFinishAsTuple(Context& context) -> void {
  44. HandlePatternListElementFinish(context, Lex::TokenKind::CloseParen,
  45. StateKind::PatternListElementAsTuple);
  46. }
  47. auto HandlePatternListElementFinishAsExplicit(Context& context) -> void {
  48. HandlePatternListElementFinish(context, Lex::TokenKind::CloseParen,
  49. StateKind::PatternListElementAsExplicit);
  50. }
  51. auto HandlePatternListElementFinishAsImplicit(Context& context) -> void {
  52. HandlePatternListElementFinish(context, Lex::TokenKind::CloseSquareBracket,
  53. StateKind::PatternListElementAsImplicit);
  54. }
  55. // Handles PatternListAs(Tuple|Explicit|Implicit).
  56. static auto HandlePatternList(Context& context, NodeKind node_kind,
  57. Lex::TokenKind open_token_kind,
  58. Lex::TokenKind close_token_kind,
  59. StateKind param_state, StateKind finish_state)
  60. -> void {
  61. auto state = context.PopState();
  62. context.PushStateForPattern(finish_state, state.in_var_pattern,
  63. state.in_unused_pattern);
  64. context.AddLeafNode(node_kind, context.ConsumeChecked(open_token_kind));
  65. if (!context.PositionIs(close_token_kind)) {
  66. context.PushStateForPattern(param_state, state.in_var_pattern,
  67. state.in_unused_pattern);
  68. }
  69. }
  70. auto HandlePatternListAsTuple(Context& context) -> void {
  71. HandlePatternList(context, NodeKind::TuplePatternStart,
  72. Lex::TokenKind::OpenParen, Lex::TokenKind::CloseParen,
  73. StateKind::PatternListElementAsTuple,
  74. StateKind::PatternListFinishAsTuple);
  75. }
  76. auto HandlePatternListAsExplicit(Context& context) -> void {
  77. HandlePatternList(context, NodeKind::ExplicitParamListStart,
  78. Lex::TokenKind::OpenParen, Lex::TokenKind::CloseParen,
  79. StateKind::PatternListElementAsExplicit,
  80. StateKind::PatternListFinishAsExplicit);
  81. }
  82. auto HandlePatternListAsImplicit(Context& context) -> void {
  83. HandlePatternList(context, NodeKind::ImplicitParamListStart,
  84. Lex::TokenKind::OpenSquareBracket,
  85. Lex::TokenKind::CloseSquareBracket,
  86. StateKind::PatternListElementAsImplicit,
  87. StateKind::PatternListFinishAsImplicit);
  88. }
  89. // Handles PatternListFinishAs(Tuple|Explicit|Implicit).
  90. static auto HandlePatternListFinish(Context& context, NodeKind node_kind,
  91. Lex::TokenKind token_kind) -> void {
  92. auto state = context.PopState();
  93. context.AddNode(node_kind, context.ConsumeChecked(token_kind),
  94. state.has_error);
  95. }
  96. auto HandlePatternListFinishAsTuple(Context& context) -> void {
  97. HandlePatternListFinish(context, NodeKind::TuplePattern,
  98. Lex::TokenKind::CloseParen);
  99. }
  100. auto HandlePatternListFinishAsExplicit(Context& context) -> void {
  101. HandlePatternListFinish(context, NodeKind::ExplicitParamList,
  102. Lex::TokenKind::CloseParen);
  103. }
  104. auto HandlePatternListFinishAsImplicit(Context& context) -> void {
  105. HandlePatternListFinish(context, NodeKind::ImplicitParamList,
  106. Lex::TokenKind::CloseSquareBracket);
  107. }
  108. } // namespace Carbon::Parse