OikawaKirie updated this revision to Diff 347581. OikawaKirie added a comment.
Update the test case to avoid a crash in the Windows version of the `c-index-test` tool. CHANGES SINCE LAST ACTION https://reviews.llvm.org/D102614/new/ https://reviews.llvm.org/D102614 Files: clang/lib/Index/USRGeneration.cpp clang/test/Index/USR/MemberFunctionPtr.cpp Index: clang/test/Index/USR/MemberFunctionPtr.cpp =================================================================== --- /dev/null +++ clang/test/Index/USR/MemberFunctionPtr.cpp @@ -0,0 +1,33 @@ +// RUN: c-index-test -index-file %s | FileCheck %s + +struct C { + int X; + void f(char); +}; + +void f(int C::*) {} +// CHECK: name: f | USR: c:@F@f#$@S@C::*I# +void f(void (C::*)(char)) {} +// CHECK: name: f | USR: c:@F@f#$@S@C::*Fv(#C)# + +typedef int C::*Xtd; +void ftd(Xtd) {} +// CHECK: name: ftd | USR: c:@F@ftd#$@S@C::*I# +typedef void (C::*Ftd)(char); +void ftd(Ftd) {} +// CHECK: name: ftd | USR: c:@F@ftd#$@S@C::*Fv(#C)# + +using Xus = int C::*; +void fus(Xus) {} +// CHECK: name: fus | USR: c:@F@fus#$@S@C::*I# +using Fus = void (C::*)(char); +void fus(Fus) {} +// CHECK: name: fus | USR: c:@F@fus#$@S@C::*Fv(#C)# + +template <typename T> struct S; +template <typename T, typename U> struct S<T U::*> { + static const bool V = true; + // CHECK: name: V | USR: c:@SP>2#T#T@S>#t0.1::*t0.0@V + void f() {} + // CHECK: name: f | USR: c:@SP>2#T#T@S>#t0.1::*t0.0@F@f# +}; Index: clang/lib/Index/USRGeneration.cpp =================================================================== --- clang/lib/Index/USRGeneration.cpp +++ clang/lib/Index/USRGeneration.cpp @@ -893,6 +893,12 @@ T = AT->getElementType(); continue; } + if (const MemberPointerType *MPT = T->getAs<MemberPointerType>()) { + VisitType(QualType(MPT->getClass(), 0)); + Out << "::*"; + T = MPT->getPointeeType(); + continue; + } // Unhandled type. Out << ' ';
Index: clang/test/Index/USR/MemberFunctionPtr.cpp =================================================================== --- /dev/null +++ clang/test/Index/USR/MemberFunctionPtr.cpp @@ -0,0 +1,33 @@ +// RUN: c-index-test -index-file %s | FileCheck %s + +struct C { + int X; + void f(char); +}; + +void f(int C::*) {} +// CHECK: name: f | USR: c:@F@f#$@S@C::*I# +void f(void (C::*)(char)) {} +// CHECK: name: f | USR: c:@F@f#$@S@C::*Fv(#C)# + +typedef int C::*Xtd; +void ftd(Xtd) {} +// CHECK: name: ftd | USR: c:@F@ftd#$@S@C::*I# +typedef void (C::*Ftd)(char); +void ftd(Ftd) {} +// CHECK: name: ftd | USR: c:@F@ftd#$@S@C::*Fv(#C)# + +using Xus = int C::*; +void fus(Xus) {} +// CHECK: name: fus | USR: c:@F@fus#$@S@C::*I# +using Fus = void (C::*)(char); +void fus(Fus) {} +// CHECK: name: fus | USR: c:@F@fus#$@S@C::*Fv(#C)# + +template <typename T> struct S; +template <typename T, typename U> struct S<T U::*> { + static const bool V = true; + // CHECK: name: V | USR: c:@SP>2#T#T@S>#t0.1::*t0.0@V + void f() {} + // CHECK: name: f | USR: c:@SP>2#T#T@S>#t0.1::*t0.0@F@f# +}; Index: clang/lib/Index/USRGeneration.cpp =================================================================== --- clang/lib/Index/USRGeneration.cpp +++ clang/lib/Index/USRGeneration.cpp @@ -893,6 +893,12 @@ T = AT->getElementType(); continue; } + if (const MemberPointerType *MPT = T->getAs<MemberPointerType>()) { + VisitType(QualType(MPT->getClass(), 0)); + Out << "::*"; + T = MPT->getPointeeType(); + continue; + } // Unhandled type. Out << ' ';
_______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits