]> granicus.if.org Git - clang/commitdiff
When collecting types for built-in candidates, make arrays decay to pointers. Otherwi...
authorSebastian Redl <sebastian.redl@getdesigned.at>
Thu, 5 Nov 2009 16:36:20 +0000 (16:36 +0000)
committerSebastian Redl <sebastian.redl@getdesigned.at>
Thu, 5 Nov 2009 16:36:20 +0000 (16:36 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@86140 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Sema/SemaOverload.cpp
test/SemaCXX/overloaded-operator.cpp

index 24c3ae391b56dc7507c619b4530988a58bac3bfc..3e6778bc4770f4da85254cccf3206470a4f57bae 100644 (file)
@@ -3052,6 +3052,10 @@ BuiltinCandidateTypeSet::AddTypesConvertedFrom(QualType Ty,
   // We don't care about qualifiers on the type.
   Ty = Ty.getUnqualifiedType();
 
+  // If we're dealing with an array type, decay to the pointer.
+  if (Ty->isArrayType())
+    Ty = SemaRef.Context.getArrayDecayedType(Ty);
+
   if (const PointerType *PointerTy = Ty->getAs<PointerType>()) {
     QualType PointeeTy = PointerTy->getPointeeType();
 
index 0f723ad206b9bf44e3caebb689d3695be8968046..750038d4ab519f4ae420140e9cc8394a6307cba0 100644 (file)
@@ -268,3 +268,14 @@ void circ() {
   CircA a;
   a->val = 0; // expected-error {{circular pointer delegation detected}}
 }
+
+// PR5360: Arrays should lead to built-in candidates for subscript.
+typedef enum {
+  LastReg = 23,
+} Register;
+class RegAlloc {
+  int getPriority(Register r) {
+    return usepri[r];
+  }
+  int usepri[LastReg + 1];
+};