blob: 569d4eecec75725cfefd731e5919ef5cd0663429 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
|
/* 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 "RefCountedCopyConstructorChecker.h"
#include "CustomMatchers.h"
void RefCountedCopyConstructorChecker::registerMatchers(
MatchFinder *AstMatcher) {
AstMatcher->addMatcher(
cxxConstructExpr(
hasDeclaration(cxxConstructorDecl(isCompilerProvidedCopyConstructor(),
ofClass(hasRefCntMember()))))
.bind("node"),
this);
}
void RefCountedCopyConstructorChecker::check(
const MatchFinder::MatchResult &Result) {
const char *Error =
"Invalid use of compiler-provided copy constructor on refcounted type";
const char *Note = "The default copy constructor also copies the "
"default mRefCnt property, leading to reference "
"count imbalance issues. Please provide your own "
"copy constructor which only copies the fields which "
"need to be copied";
// Everything we needed to know was checked in the matcher - we just report
// the error here
const CXXConstructExpr *E = Result.Nodes.getNodeAs<CXXConstructExpr>("node");
diag(E->getLocation(), Error, DiagnosticIDs::Error);
diag(E->getLocation(), Note, DiagnosticIDs::Note);
}
|