diff options
author | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2012-03-30 00:19:13 +0000 |
---|---|---|
committer | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2012-03-30 00:19:13 +0000 |
commit | d0469525581a851b68f5b4f960ee4190dcc7c932 (patch) | |
tree | 272ee67d409ac2e70cdc69a7420597f88f15653b | |
parent | 66373dd2d508407ed5894ad65f654eea8d892319 (diff) |
[libclang] A MemberRefExpr cursor for a property dot syntax should have as
its location the location of the property.
Part of rdar://11113120
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@153708 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | test/Index/get-cursor.m | 3 | ||||
-rw-r--r-- | tools/libclang/CIndex.cpp | 2 |
2 files changed, 5 insertions, 0 deletions
diff --git a/test/Index/get-cursor.m b/test/Index/get-cursor.m index 830f9828b9..d343e66a00 100644 --- a/test/Index/get-cursor.m +++ b/test/Index/get-cursor.m @@ -36,6 +36,8 @@ struct S { int x; }; -(void)mm:(struct S*)s { rdar10902015 *i = 0; s->x = 0; + Test1 *test1; + test1.name = 0; } @end @@ -54,3 +56,4 @@ struct S { int x; }; // RUN: c-index-test -cursor-at=%s:38:6 -cursor-at=%s:40:11 %s | FileCheck -check-prefix=CHECK-MEMBERREF %s // CHECK-MEMBERREF: 38:6 MemberRefExpr=x:34:16 SingleRefName=[38:6 - 38:7] RefName=[38:6 - 38:7] Extent=[38:3 - 38:7] +// CHECK-MEMBERREF: 40:9 MemberRefExpr=name:23:21 Extent=[40:3 - 40:13] Spelling=name diff --git a/tools/libclang/CIndex.cpp b/tools/libclang/CIndex.cpp index e8acfd9df2..972beaf9e7 100644 --- a/tools/libclang/CIndex.cpp +++ b/tools/libclang/CIndex.cpp @@ -2944,6 +2944,8 @@ static SourceLocation getLocationFromExpr(Expr *E) { return Ivar->getLocation(); if (SizeOfPackExpr *SizeOfPack = dyn_cast<SizeOfPackExpr>(E)) return SizeOfPack->getPackLoc(); + if (ObjCPropertyRefExpr *PropRef = dyn_cast<ObjCPropertyRefExpr>(E)) + return PropRef->getLocation(); return E->getLocStart(); } |