summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--test/Index/get-cursor.m3
-rw-r--r--tools/libclang/CIndex.cpp2
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();
}