blob: 8a654a17ada9e1ec7aa75cbed8f0b78dcc017a0b [file] [log] [blame]
Chris Lattnere79379a2018-06-22 10:39:19 -07001//===- Token.h - MLIR Token Interface ---------------------------*- C++ -*-===//
2//
3// Copyright 2019 The MLIR Authors.
4//
5// Licensed under the Apache License, Version 2.0 (the "License");
6// you may not use this file except in compliance with the License.
7// You may obtain a copy of the License at
8//
9// http://www.apache.org/licenses/LICENSE-2.0
10//
11// Unless required by applicable law or agreed to in writing, software
12// distributed under the License is distributed on an "AS IS" BASIS,
13// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14// See the License for the specific language governing permissions and
15// limitations under the License.
16// =============================================================================
17
18#ifndef MLIR_LIB_PARSER_TOKEN_H
19#define MLIR_LIB_PARSER_TOKEN_H
20
21#include "mlir/Support/LLVM.h"
22#include "llvm/ADT/StringRef.h"
23#include "llvm/Support/SMLoc.h"
24
25namespace mlir {
26
27/// This represents a token in the MLIR syntax.
28class Token {
29public:
30 enum TokenKind {
31 // Markers
32 eof, error,
33
34 // Identifiers.
35 bare_identifier, // foo
36 at_identifier, // @foo
MLIR Teamf85a6262018-06-27 11:03:08 -070037 affine_map_id, // #foo
Chris Lattnere79379a2018-06-22 10:39:19 -070038 // TODO: @@foo, etc.
39
Chris Lattnerbb8fafc2018-06-22 15:52:02 -070040 integer, // 42
41
Chris Lattnere79379a2018-06-22 10:39:19 -070042 // Punctuation.
Chris Lattnerbb8fafc2018-06-22 15:52:02 -070043 arrow, // ->
Chris Lattner4c95a502018-06-23 16:03:42 -070044 colon, // :
Chris Lattnerbb8fafc2018-06-22 15:52:02 -070045 comma, // ,
46 question, // ?
47 questionquestion, // ??
Chris Lattnere79379a2018-06-22 10:39:19 -070048 l_paren, r_paren, // ( )
Chris Lattner4c95a502018-06-23 16:03:42 -070049 l_brace, r_brace, // { }
Chris Lattnere79379a2018-06-22 10:39:19 -070050 less, greater, // < >
51 // TODO: More punctuation.
52
53 // Keywords.
Chris Lattnerbb8fafc2018-06-22 15:52:02 -070054 kw_bf16,
Chris Lattnerf6d80a02018-06-24 11:18:29 -070055 kw_br,
Chris Lattnere79379a2018-06-22 10:39:19 -070056 kw_cfgfunc,
57 kw_extfunc,
Chris Lattnerbb8fafc2018-06-22 15:52:02 -070058 kw_f16,
59 kw_f32,
60 kw_f64,
61 kw_i1,
62 kw_i16,
63 kw_i32,
64 kw_i64,
65 kw_i8,
66 kw_int,
67 kw_memref,
Chris Lattnere79379a2018-06-22 10:39:19 -070068 kw_mlfunc,
Chris Lattner4c95a502018-06-23 16:03:42 -070069 kw_return,
Chris Lattnerbb8fafc2018-06-22 15:52:02 -070070 kw_tensor,
71 kw_vector,
Chris Lattnere79379a2018-06-22 10:39:19 -070072 };
73
74 Token(TokenKind kind, StringRef spelling)
75 : kind(kind), spelling(spelling) {}
76
77 // Return the bytes that make up this token.
78 StringRef getSpelling() const { return spelling; }
79
80 // Token classification.
81 TokenKind getKind() const { return kind; }
82 bool is(TokenKind K) const { return kind == K; }
83
84 bool isAny(TokenKind k1, TokenKind k2) const {
85 return is(k1) || is(k2);
86 }
87
88 /// Return true if this token is one of the specified kinds.
89 template <typename ...T>
90 bool isAny(TokenKind k1, TokenKind k2, TokenKind k3, T... others) const {
91 if (is(k1))
92 return true;
93 return isAny(k2, k3, others...);
94 }
95
96 bool isNot(TokenKind k) const { return kind != k; }
97
98 /// Return true if this token isn't one of the specified kinds.
99 template <typename ...T>
100 bool isNot(TokenKind k1, TokenKind k2, T... others) const {
101 return !isAny(k1, k2, others...);
102 }
103
Chris Lattnerbb8fafc2018-06-22 15:52:02 -0700104 // Helpers to decode specific sorts of tokens.
Chris Lattnere79379a2018-06-22 10:39:19 -0700105
Chris Lattnerbb8fafc2018-06-22 15:52:02 -0700106 /// For an integer token, return its value as an unsigned. If it doesn't fit,
107 /// return None.
108 Optional<unsigned> getUnsignedIntegerValue();
109
110 // Location processing.
Chris Lattnere79379a2018-06-22 10:39:19 -0700111 llvm::SMLoc getLoc() const;
112 llvm::SMLoc getEndLoc() const;
113 llvm::SMRange getLocRange() const;
114
115private:
116 /// Discriminator that indicates the sort of token this is.
117 TokenKind kind;
118
119 /// A reference to the entire token contents; this is always a pointer into
120 /// a memory buffer owned by the source manager.
121 StringRef spelling;
122};
123
124} // end namespace mlir
125
126#endif // MLIR_LIB_PARSER_TOKEN_H