1 //===- MILexer.h - Lexer for machine instructions -------------------------===//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 // This file declares the function that lexes the machine instruction source
13 //===----------------------------------------------------------------------===//
15 #ifndef LLVM_LIB_CODEGEN_MIRPARSER_MILEXER_H
16 #define LLVM_LIB_CODEGEN_MIRPARSER_MILEXER_H
18 #include "llvm/ADT/APSInt.h"
19 #include "llvm/ADT/StringRef.h"
20 #include "llvm/ADT/STLExtras.h"
27 /// A token produced by the machine instruction lexer.
34 // Tokens with no info.
57 unsigned StringOffset;
62 MIToken(TokenKind Kind, StringRef Range, unsigned StringOffset = 0)
63 : Kind(Kind), StringOffset(StringOffset), Range(Range) {}
65 MIToken(TokenKind Kind, StringRef Range, const APSInt &IntVal,
66 unsigned StringOffset = 0)
67 : Kind(Kind), StringOffset(StringOffset), Range(Range), IntVal(IntVal) {}
69 TokenKind kind() const { return Kind; }
71 bool isError() const { return Kind == Error; }
73 bool isRegister() const {
74 return Kind == NamedRegister || Kind == underscore;
77 bool isRegisterFlag() const {
78 return Kind == kw_implicit || Kind == kw_implicit_define || Kind == kw_dead;
81 bool is(TokenKind K) const { return Kind == K; }
83 bool isNot(TokenKind K) const { return Kind != K; }
85 StringRef::iterator location() const { return Range.begin(); }
87 StringRef stringValue() const { return Range.drop_front(StringOffset); }
89 const APSInt &integerValue() const { return IntVal; }
91 bool hasIntegerValue() const {
92 return Kind == IntegerLiteral || Kind == MachineBasicBlock ||
97 /// Consume a single machine instruction token in the given source and return
98 /// the remaining source string.
100 StringRef Source, MIToken &Token,
101 function_ref<void(StringRef::iterator, const Twine &)> ErrorCallback);
103 } // end namespace llvm