]> granicus.if.org Git - clang/commitdiff
Access control for overloaded call operators. Not for surrogates yet,
authorJohn McCall <rjmccall@apple.com>
Thu, 28 Jan 2010 01:54:34 +0000 (01:54 +0000)
committerJohn McCall <rjmccall@apple.com>
Thu, 28 Jan 2010 01:54:34 +0000 (01:54 +0000)
mostly because we're going to want a better diagnostic for conversions.

Also this API needs to go back to sanity.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@94730 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Sema/SemaOverload.cpp
test/CXX/class.access/p4.cpp

index 5506eeb4b2dc8d0d1e60935c9d7fc8da8308ac36..55259fca4f2ad8682c2bebbd5790a787faf344c1 100644 (file)
@@ -6231,6 +6231,8 @@ Sema::BuildCallToObjectOfClassType(Scope *S, Expr *Object,
       = cast<CXXConversionDecl>(
                          Best->Conversions[0].UserDefined.ConversionFunction);
 
+    // FIXME: access control
+
     // We selected one of the surrogate functions that converts the
     // object parameter to a function pointer. Perform the conversion
     // on the object argument, then let ActOnCallExpr finish the job.
@@ -6244,6 +6246,9 @@ Sema::BuildCallToObjectOfClassType(Scope *S, Expr *Object,
                          CommaLocs, RParenLoc).release();
   }
 
+  if (getLangOptions().AccessControl)
+    CheckAccess(R, Best->Function, Best->getAccess());
+
   // We found an overloaded operator(). Build a CXXOperatorCallExpr
   // that calls this method, using Object for the implicit object
   // parameter and passing along the remaining arguments.
index 3f4397a28b4bf6cebb88c1b7fe2a54bb3397fbc3..0df17919a30d60f8eb96edcd8dae0ad90ae8cf18 100644 (file)
@@ -38,12 +38,15 @@ namespace test1 {
   public:
     void operator+(Public&);
     void operator[](Public&);
+    void operator()(Public&);
   protected:
     void operator+(Protected&); // expected-note {{declared protected here}}
     void operator[](Protected&); // expected-note {{declared protected here}}
+    void operator()(Protected&); // expected-note {{declared protected here}}
   private:
     void operator+(Private&); // expected-note {{declared private here}}
     void operator[](Private&); // expected-note {{declared private here}}
+    void operator()(Private&); // expected-note {{declared private here}}
     void operator-(); // expected-note {{declared private here}}
   };
   void operator+(const A &, Public&);
@@ -58,6 +61,9 @@ namespace test1 {
     a[pub];
     a[prot]; // expected-error {{access to protected member}}
     a[priv]; // expected-error {{access to private member}}
+    a(pub);
+    a(prot); // expected-error {{access to protected member}}
+    a(priv); // expected-error {{access to private member}}
     -a;       // expected-error {{access to private member}}
 
     const A &ca = a;