mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-01-11 14:28:42 +00:00
2238536677
Differential Revision: https://phabricator.services.mozilla.com/D4191 --HG-- extra : moz-landing-system : lando
37 lines
1.3 KiB
C++
37 lines
1.3 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/. */
|
|
|
|
#include "ExplicitImplicitChecker.h"
|
|
#include "CustomMatchers.h"
|
|
|
|
void ExplicitImplicitChecker::registerMatchers(MatchFinder *AstMatcher) {
|
|
AstMatcher->addMatcher(
|
|
cxxConstructorDecl(
|
|
isInterestingImplicitCtor(),
|
|
ofClass(allOf(isConcreteClass(), decl().bind("class"))),
|
|
unless(isMarkedImplicit()))
|
|
.bind("ctor"),
|
|
this);
|
|
}
|
|
|
|
void ExplicitImplicitChecker::check(const MatchFinder::MatchResult &Result) {
|
|
// We've already checked everything in the matcher, so we just have to report
|
|
// the error.
|
|
|
|
const CXXConstructorDecl *Ctor =
|
|
Result.Nodes.getNodeAs<CXXConstructorDecl>("ctor");
|
|
const CXXRecordDecl *Declaration =
|
|
Result.Nodes.getNodeAs<CXXRecordDecl>("class");
|
|
|
|
FixItHint FixItHint =
|
|
FixItHint::CreateInsertion(Ctor->getLocation(), "explicit ");
|
|
diag(Ctor->getLocation(), "bad implicit conversion constructor for %0",
|
|
DiagnosticIDs::Error)
|
|
<< Declaration->getDeclName();
|
|
diag(Ctor->getLocation(),
|
|
"consider adding the explicit keyword to the constructor",
|
|
DiagnosticIDs::Note)
|
|
<< FixItHint;
|
|
}
|