gecko-dev/build/clang-plugin/BaseCheck.h
Andi-Bogdan Postelnicu 5392090016 Bug 1589096 - add registerPPCallbacks to our version of clang-tidy due to a limitation in mozilla-must-override. r=sylvestre
In the future we should re-write this checker but for now this solution is acceptable.

Differential Revision: https://phabricator.services.mozilla.com/D51242

--HG--
extra : moz-landing-system : lando
2019-10-31 12:16:35 +00:00

35 lines
1.1 KiB
C++

/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#ifndef BaseCheck_h__
#define BaseCheck_h__
class MozContext {};
typedef MozContext ContextType;
class BaseCheck : public MatchFinder::MatchCallback {
public:
BaseCheck(StringRef CheckName, ContextType *Context) {}
virtual void registerMatchers(MatchFinder *Finder) {}
virtual void registerPPCallbacks(CompilerInstance &CI) {}
virtual void check(const MatchFinder::MatchResult &Result) {}
DiagnosticBuilder diag(SourceLocation Loc, StringRef Description,
DiagnosticIDs::Level Level = DiagnosticIDs::Warning) {
DiagnosticsEngine &Diag = Context->getDiagnostics();
unsigned ID = Diag.getDiagnosticIDs()->getCustomDiagID(Level, Description);
return Diag.Report(Loc, ID);
}
private:
void run(const MatchFinder::MatchResult &Result) override {
Context = Result.Context;
check(Result);
}
private:
ASTContext *Context;
};
#endif