9#ifndef LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_UTILS_LEXERUTILS_H
10#define LLVM_CLANG_TOOLS_EXTRA_CLANG_TIDY_UTILS_LEXERUTILS_H
12#include "clang/AST/ASTContext.h"
13#include "clang/Basic/TokenKinds.h"
14#include "clang/Lex/Lexer.h"
26 const SourceManager &SM,
27 const LangOptions &LangOpts,
28 bool SkipComments =
true);
30std::pair<std::optional<Token>, SourceLocation>
32 const LangOptions &LangOpts,
bool SkipComments =
true);
35 const SourceManager &SM,
36 const LangOptions &LangOpts);
39 const SourceManager &SM,
40 const LangOptions &LangOpts,
44 const LangOptions &LangOpts);
46template <
typename TokenKind,
typename... TokenKinds>
48 const SourceManager &SM,
49 const LangOptions &LangOpts,
50 TokenKind TK, TokenKinds... TKs) {
51 if (Start.isInvalid() || Start.isMacroID())
55 if (L.isInvalid() || L.isMacroID())
60 if (Lexer::getRawToken(L, T, SM, LangOpts,
true))
63 if (T.isOneOf(TK, TKs...))
64 return T.getLocation();
70template <
typename TokenKind,
typename... TokenKinds>
72 const SourceManager &SM,
73 const LangOptions &LangOpts, TokenKind TK,
76 std::optional<Token> CurrentToken =
77 Lexer::findNextToken(Start, SM, LangOpts);
82 const Token PotentialMatch = *CurrentToken;
83 if (PotentialMatch.isOneOf(TK, TKs...))
84 return PotentialMatch.getLocation();
89 if (PotentialMatch.is(tok::eof))
91 Start = PotentialMatch.getLastLoc();
96inline std::optional<Token>
98 const LangOptions &LangOpts) {
99 return Lexer::findNextToken(Start, SM, LangOpts,
true);
103inline std::optional<Token>
105 const LangOptions &LangOpts) {
106 return Lexer::findNextToken(Start, SM, LangOpts,
false);
113 const SourceManager &SM,
114 const LangOptions &LangOpts);
122 CharSourceRange Range,
123 const ASTContext &Context,
124 const SourceManager &SM);
129 const LangOptions &LangOpts);
134 const SourceManager &SM);
std::pair< std::optional< Token >, SourceLocation > getPreviousTokenAndStart(SourceLocation Location, const SourceManager &SM, const LangOptions &LangOpts, bool SkipComments)
SourceLocation getLocationForNoexceptSpecifier(const FunctionDecl *FuncDecl, const SourceManager &SM)
For a given FunctionDecl returns the location where you would need to place the noexcept specifier.
SourceLocation getUnifiedEndLoc(const Stmt &S, const SourceManager &SM, const LangOptions &LangOpts)
Stmt->getEndLoc does not always behave the same way depending on Token type.
bool rangeContainsExpansionsOrDirectives(SourceRange Range, const SourceManager &SM, const LangOptions &LangOpts)
Re-lex the provide Range and return false if either a macro spans multiple tokens,...
SourceLocation findNextTerminator(SourceLocation Start, const SourceManager &SM, const LangOptions &LangOpts)
std::optional< Token > getPreviousToken(SourceLocation Location, const SourceManager &SM, const LangOptions &LangOpts, bool SkipComments)
Returns previous token or std::nullopt if not found.
SourceLocation findNextAnyTokenKind(SourceLocation Start, const SourceManager &SM, const LangOptions &LangOpts, TokenKind TK, TokenKinds... TKs)
std::optional< Token > findNextTokenSkippingComments(SourceLocation Start, const SourceManager &SM, const LangOptions &LangOpts)
SourceLocation findPreviousTokenStart(SourceLocation Start, const SourceManager &SM, const LangOptions &LangOpts)
SourceLocation findPreviousTokenKind(SourceLocation Start, const SourceManager &SM, const LangOptions &LangOpts, tok::TokenKind TK)
std::optional< Token > getQualifyingToken(tok::TokenKind TK, CharSourceRange Range, const ASTContext &Context, const SourceManager &SM)
Assuming that Range spans a CVR-qualified type, returns the token in Range that is responsible for th...
std::optional< Token > findNextTokenIncludingComments(SourceLocation Start, const SourceManager &SM, const LangOptions &LangOpts)
SourceLocation findPreviousAnyTokenKind(SourceLocation Start, const SourceManager &SM, const LangOptions &LangOpts, TokenKind TK, TokenKinds... TKs)
===– Representation.cpp - ClangDoc Representation --------—*- C++ -*-===//
static constexpr const char FuncDecl[]