blob: c8f856c682d72d3c7f81959badcdade76db8ea3e [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
37 // TODO: @@foo, etc.
38
Chris Lattnerbb8fafc2018-06-22 15:52:02 -070039 integer, // 42
40
Chris Lattnere79379a2018-06-22 10:39:19 -070041 // Punctuation.
Chris Lattnerbb8fafc2018-06-22 15:52:02 -070042 arrow, // ->
Chris Lattner4c95a502018-06-23 16:03:42 -070043 colon, // :
Chris Lattnerbb8fafc2018-06-22 15:52:02 -070044 comma, // ,
45 question, // ?
46 questionquestion, // ??
Chris Lattnere79379a2018-06-22 10:39:19 -070047 l_paren, r_paren, // ( )
Chris Lattner4c95a502018-06-23 16:03:42 -070048 l_brace, r_brace, // { }
Chris Lattnere79379a2018-06-22 10:39:19 -070049 less, greater, // < >
50 // TODO: More punctuation.
51
52 // Keywords.
Chris Lattnerbb8fafc2018-06-22 15:52:02 -070053 kw_bf16,
Chris Lattnere79379a2018-06-22 10:39:19 -070054 kw_cfgfunc,
55 kw_extfunc,
Chris Lattnerbb8fafc2018-06-22 15:52:02 -070056 kw_f16,
57 kw_f32,
58 kw_f64,
59 kw_i1,
60 kw_i16,
61 kw_i32,
62 kw_i64,
63 kw_i8,
64 kw_int,
65 kw_memref,
Chris Lattnere79379a2018-06-22 10:39:19 -070066 kw_mlfunc,
Chris Lattner4c95a502018-06-23 16:03:42 -070067 kw_return,
Chris Lattnerbb8fafc2018-06-22 15:52:02 -070068 kw_tensor,
69 kw_vector,
Chris Lattnere79379a2018-06-22 10:39:19 -070070 };
71
72 Token(TokenKind kind, StringRef spelling)
73 : kind(kind), spelling(spelling) {}
74
75 // Return the bytes that make up this token.
76 StringRef getSpelling() const { return spelling; }
77
78 // Token classification.
79 TokenKind getKind() const { return kind; }
80 bool is(TokenKind K) const { return kind == K; }
81
82 bool isAny(TokenKind k1, TokenKind k2) const {
83 return is(k1) || is(k2);
84 }
85
86 /// Return true if this token is one of the specified kinds.
87 template <typename ...T>
88 bool isAny(TokenKind k1, TokenKind k2, TokenKind k3, T... others) const {
89 if (is(k1))
90 return true;
91 return isAny(k2, k3, others...);
92 }
93
94 bool isNot(TokenKind k) const { return kind != k; }
95
96 /// Return true if this token isn't one of the specified kinds.
97 template <typename ...T>
98 bool isNot(TokenKind k1, TokenKind k2, T... others) const {
99 return !isAny(k1, k2, others...);
100 }
101
Chris Lattnerbb8fafc2018-06-22 15:52:02 -0700102 // Helpers to decode specific sorts of tokens.
Chris Lattnere79379a2018-06-22 10:39:19 -0700103
Chris Lattnerbb8fafc2018-06-22 15:52:02 -0700104 /// For an integer token, return its value as an unsigned. If it doesn't fit,
105 /// return None.
106 Optional<unsigned> getUnsignedIntegerValue();
107
108 // Location processing.
Chris Lattnere79379a2018-06-22 10:39:19 -0700109 llvm::SMLoc getLoc() const;
110 llvm::SMLoc getEndLoc() const;
111 llvm::SMRange getLocRange() const;
112
113private:
114 /// Discriminator that indicates the sort of token this is.
115 TokenKind kind;
116
117 /// A reference to the entire token contents; this is always a pointer into
118 /// a memory buffer owned by the source manager.
119 StringRef spelling;
120};
121
122} // end namespace mlir
123
124#endif // MLIR_LIB_PARSER_TOKEN_H