token_kind.cpp 3.2 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 "lexer/token_kind.h"
  5. #include "llvm/ADT/StringRef.h"
  6. namespace Carbon {
  7. auto TokenKind::Name() const -> llvm::StringRef {
  8. static constexpr llvm::StringLiteral Names[] = {
  9. #define CARBON_TOKEN(TokenName) #TokenName,
  10. #include "lexer/token_registry.def"
  11. };
  12. return Names[static_cast<int>(kind_value)];
  13. }
  14. auto TokenKind::IsSymbol() const -> bool {
  15. static constexpr bool Table[] = {
  16. #define CARBON_TOKEN(TokenName) false,
  17. #define CARBON_SYMBOL_TOKEN(TokenName, Spelling) true,
  18. #include "lexer/token_registry.def"
  19. };
  20. return Table[static_cast<int>(kind_value)];
  21. }
  22. auto TokenKind::IsGroupingSymbol() const -> bool {
  23. static constexpr bool Table[] = {
  24. #define CARBON_TOKEN(TokenName) false,
  25. #define CARBON_OPENING_GROUP_SYMBOL_TOKEN(TokenName, Spelling, ClosingName) \
  26. true,
  27. #define CARBON_CLOSING_GROUP_SYMBOL_TOKEN(TokenName, Spelling, OpeningName) \
  28. true,
  29. #include "lexer/token_registry.def"
  30. };
  31. return Table[static_cast<int>(kind_value)];
  32. }
  33. auto TokenKind::IsOpeningSymbol() const -> bool {
  34. static constexpr bool Table[] = {
  35. #define CARBON_TOKEN(TokenName) false,
  36. #define CARBON_OPENING_GROUP_SYMBOL_TOKEN(TokenName, Spelling, ClosingName) \
  37. true,
  38. #include "lexer/token_registry.def"
  39. };
  40. return Table[static_cast<int>(kind_value)];
  41. }
  42. auto TokenKind::GetClosingSymbol() const -> TokenKind {
  43. static constexpr TokenKind Table[] = {
  44. #define CARBON_TOKEN(TokenName) Error(),
  45. #define CARBON_OPENING_GROUP_SYMBOL_TOKEN(TokenName, Spelling, ClosingName) \
  46. ClosingName(),
  47. #include "lexer/token_registry.def"
  48. };
  49. auto result = Table[static_cast<int>(kind_value)];
  50. assert(result != Error() && "Only opening symbols are valid!");
  51. return result;
  52. }
  53. auto TokenKind::IsClosingSymbol() const -> bool {
  54. static constexpr bool Table[] = {
  55. #define CARBON_TOKEN(TokenName) false,
  56. #define CARBON_CLOSING_GROUP_SYMBOL_TOKEN(TokenName, Spelling, OpeningName) \
  57. true,
  58. #include "lexer/token_registry.def"
  59. };
  60. return Table[static_cast<int>(kind_value)];
  61. }
  62. auto TokenKind::GetOpeningSymbol() const -> TokenKind {
  63. static constexpr TokenKind Table[] = {
  64. #define CARBON_TOKEN(TokenName) Error(),
  65. #define CARBON_CLOSING_GROUP_SYMBOL_TOKEN(TokenName, Spelling, OpeningName) \
  66. OpeningName(),
  67. #include "lexer/token_registry.def"
  68. };
  69. auto result = Table[static_cast<int>(kind_value)];
  70. assert(result != Error() && "Only closing symbols are valid!");
  71. return result;
  72. }
  73. auto TokenKind::IsKeyword() const -> bool {
  74. static constexpr bool Table[] = {
  75. #define CARBON_TOKEN(TokenName) false,
  76. #define CARBON_KEYWORD_TOKEN(TokenName, Spelling) true,
  77. #include "lexer/token_registry.def"
  78. };
  79. return Table[static_cast<int>(kind_value)];
  80. }
  81. auto TokenKind::GetFixedSpelling() const -> llvm::StringRef {
  82. static constexpr llvm::StringLiteral Table[] = {
  83. #define CARBON_TOKEN(TokenName) "",
  84. #define CARBON_SYMBOL_TOKEN(TokenName, Spelling) Spelling,
  85. #define CARBON_KEYWORD_TOKEN(TokenName, Spelling) Spelling,
  86. #include "lexer/token_registry.def"
  87. };
  88. return Table[static_cast<int>(kind_value)];
  89. }
  90. } // namespace Carbon