mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2025-01-04 06:51:56 +00:00
[index] For C++ constructors/destructors, add references to the parent type where its name appears in definitions and declarations
Patch by Nathan Hawes! https://reviews.llvm.org/D30730 llvm-svn: 298170
This commit is contained in:
parent
9424af1b30
commit
573624a9c2
@ -158,6 +158,9 @@ public:
|
|||||||
handleDeclarator(D);
|
handleDeclarator(D);
|
||||||
|
|
||||||
if (const CXXConstructorDecl *Ctor = dyn_cast<CXXConstructorDecl>(D)) {
|
if (const CXXConstructorDecl *Ctor = dyn_cast<CXXConstructorDecl>(D)) {
|
||||||
|
IndexCtx.handleReference(Ctor->getParent(), Ctor->getLocation(),
|
||||||
|
Ctor->getParent(), Ctor->getDeclContext());
|
||||||
|
|
||||||
// Constructor initializers.
|
// Constructor initializers.
|
||||||
for (const auto *Init : Ctor->inits()) {
|
for (const auto *Init : Ctor->inits()) {
|
||||||
if (Init->isWritten()) {
|
if (Init->isWritten()) {
|
||||||
@ -168,6 +171,12 @@ public:
|
|||||||
IndexCtx.indexBody(Init->getInit(), D, D);
|
IndexCtx.indexBody(Init->getInit(), D, D);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} else if (const CXXDestructorDecl *Dtor = dyn_cast<CXXDestructorDecl>(D)) {
|
||||||
|
if (auto TypeNameInfo = Dtor->getNameInfo().getNamedTypeInfo()) {
|
||||||
|
IndexCtx.handleReference(Dtor->getParent(),
|
||||||
|
TypeNameInfo->getTypeLoc().getLocStart(),
|
||||||
|
Dtor->getParent(), Dtor->getDeclContext());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (D->isThisDeclarationADefinition()) {
|
if (D->isThisDeclarationADefinition()) {
|
||||||
|
@ -71,7 +71,7 @@ public:
|
|||||||
bool handleReference(const NamedDecl *D, SourceLocation Loc,
|
bool handleReference(const NamedDecl *D, SourceLocation Loc,
|
||||||
const NamedDecl *Parent,
|
const NamedDecl *Parent,
|
||||||
const DeclContext *DC,
|
const DeclContext *DC,
|
||||||
SymbolRoleSet Roles,
|
SymbolRoleSet Roles = SymbolRoleSet(),
|
||||||
ArrayRef<SymbolRelation> Relations = None,
|
ArrayRef<SymbolRelation> Relations = None,
|
||||||
const Expr *RefE = nullptr,
|
const Expr *RefE = nullptr,
|
||||||
const Decl *RefD = nullptr);
|
const Decl *RefD = nullptr);
|
||||||
|
@ -2,13 +2,20 @@
|
|||||||
|
|
||||||
// CHECK: [[@LINE+1]]:7 | class/C++ | Cls | [[Cls_USR:.*]] | <no-cgname> | Def | rel: 0
|
// CHECK: [[@LINE+1]]:7 | class/C++ | Cls | [[Cls_USR:.*]] | <no-cgname> | Def | rel: 0
|
||||||
class Cls {
|
class Cls {
|
||||||
// CHECK: [[@LINE+2]]:3 | constructor/C++ | Cls | c:@S@Cls@F@Cls#I# | __ZN3ClsC1Ei | Decl,RelChild | rel: 1
|
// CHECK: [[@LINE+3]]:3 | constructor/C++ | Cls | c:@S@Cls@F@Cls#I# | __ZN3ClsC1Ei | Decl,RelChild | rel: 1
|
||||||
// CHECK-NEXT: RelChild | Cls | c:@S@Cls
|
// CHECK-NEXT: RelChild | Cls | c:@S@Cls
|
||||||
|
// CHECK: [[@LINE+1]]:3 | class/C++ | Cls | c:@S@Cls | <no-cgname> | Ref,RelCont | rel: 1
|
||||||
Cls(int x);
|
Cls(int x);
|
||||||
// CHECK: [[@LINE+1]]:3 | constructor/cxx-copy-ctor/C++ | Cls | c:@S@Cls@F@Cls#&1$@S@Cls# | __ZN3ClsC1ERKS_ | Decl,RelChild | rel: 1
|
// CHECK: [[@LINE+2]]:3 | constructor/cxx-copy-ctor/C++ | Cls | c:@S@Cls@F@Cls#&1$@S@Cls# | __ZN3ClsC1ERKS_ | Decl,RelChild | rel: 1
|
||||||
|
// CHECK: [[@LINE+1]]:3 | class/C++ | Cls | c:@S@Cls | <no-cgname> | Ref,RelCont | rel: 1
|
||||||
Cls(const Cls &);
|
Cls(const Cls &);
|
||||||
// CHECK: [[@LINE+1]]:3 | constructor/cxx-move-ctor/C++ | Cls | c:@S@Cls@F@Cls#&&$@S@Cls# | __ZN3ClsC1EOS_ | Decl,RelChild | rel: 1
|
// CHECK: [[@LINE+2]]:3 | constructor/cxx-move-ctor/C++ | Cls | c:@S@Cls@F@Cls#&&$@S@Cls# | __ZN3ClsC1EOS_ | Decl,RelChild | rel: 1
|
||||||
|
// CHECK: [[@LINE+1]]:3 | class/C++ | Cls | c:@S@Cls | <no-cgname> | Ref,RelCont | rel: 1
|
||||||
Cls(Cls &&);
|
Cls(Cls &&);
|
||||||
|
|
||||||
|
// CHECK: [[@LINE+2]]:3 | destructor/C++ | ~Cls | c:@S@Cls@F@~Cls# | __ZN3ClsD1Ev | Decl,RelChild | rel: 1
|
||||||
|
// CHECK: [[@LINE+1]]:4 | class/C++ | Cls | c:@S@Cls | <no-cgname> | Ref,RelCont | rel: 1
|
||||||
|
~Cls();
|
||||||
};
|
};
|
||||||
|
|
||||||
// CHECK: [[@LINE+3]]:7 | class/C++ | SubCls1 | [[SubCls1_USR:.*]] | <no-cgname> | Def | rel: 0
|
// CHECK: [[@LINE+3]]:7 | class/C++ | SubCls1 | [[SubCls1_USR:.*]] | <no-cgname> | Def | rel: 0
|
||||||
@ -24,6 +31,16 @@ typedef Cls ClsAlias;
|
|||||||
// CHECK-NEXT: RelBase,RelCont | SubCls2 | [[SubCls2_USR]]
|
// CHECK-NEXT: RelBase,RelCont | SubCls2 | [[SubCls2_USR]]
|
||||||
class SubCls2 : public ClsAlias {};
|
class SubCls2 : public ClsAlias {};
|
||||||
|
|
||||||
|
Cls::Cls(int x) {}
|
||||||
|
// CHECK: [[@LINE-1]]:6 | constructor/C++ | Cls | c:@S@Cls@F@Cls#I# | __ZN3ClsC1Ei | Def,RelChild | rel: 1
|
||||||
|
// CHECK: [[@LINE-2]]:1 | class/C++ | Cls | c:@S@Cls | <no-cgname> | Ref,RelCont | rel: 1
|
||||||
|
// CHECK: [[@LINE-3]]:6 | class/C++ | Cls | c:@S@Cls | <no-cgname> | Ref,RelCont | rel: 1
|
||||||
|
|
||||||
|
Cls::~/*a comment*/Cls() {}
|
||||||
|
// CHECK: [[@LINE-1]]:6 | destructor/C++ | ~Cls | c:@S@Cls@F@~Cls# | __ZN3ClsD1Ev | Def,RelChild | rel: 1
|
||||||
|
// CHECK: [[@LINE-2]]:1 | class/C++ | Cls | c:@S@Cls | <no-cgname> | Ref,RelCont | rel: 1
|
||||||
|
// CHECK: [[@LINE-3]]:20 | class/C++ | Cls | c:@S@Cls | <no-cgname> | Ref,RelCont | rel: 1
|
||||||
|
|
||||||
template <typename TemplArg>
|
template <typename TemplArg>
|
||||||
class TemplCls {
|
class TemplCls {
|
||||||
// CHECK: [[@LINE-1]]:7 | class(Gen)/C++ | TemplCls | c:@ST>1#T@TemplCls | <no-cgname> | Def | rel: 0
|
// CHECK: [[@LINE-1]]:7 | class(Gen)/C++ | TemplCls | c:@ST>1#T@TemplCls | <no-cgname> | Def | rel: 0
|
||||||
|
Loading…
Reference in New Issue
Block a user