Add support for calls to dependent names within templates, e.g.,

  template<typename T> void f(T x) {
    g(x); // g is a dependent name, so don't even bother to look it up
    g(); // error: g is not a dependent name
  }

Note that when we see "g(", we build a CXXDependentNameExpr. However,
if none of the call arguments are type-dependent, we will force the
resolution of the name "g" and replace the CXXDependentNameExpr with
its result.

GCC actually produces a nice error message when you make this
mistake, and even offers to compile your code with -fpermissive. I'll
do the former next, but I don't plan to do the latter.


git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@60618 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/Driver/PrintParserCallbacks.cpp b/Driver/PrintParserCallbacks.cpp
index 2ee113f..f3ddb23 100644
--- a/Driver/PrintParserCallbacks.cpp
+++ b/Driver/PrintParserCallbacks.cpp
@@ -459,7 +459,8 @@
     /// This provides the location of the left/right parens and a list of comma
     /// locations.  There are guaranteed to be one fewer commas than arguments,
     /// unless there are zero arguments.
-    virtual ExprResult ActOnCallExpr(ExprTy *Fn, SourceLocation LParenLoc,
+    virtual ExprResult ActOnCallExpr(Scope *S, ExprTy *Fn, 
+                                     SourceLocation LParenLoc,
                                      ExprTy **Args, unsigned NumArgs,
                                      SourceLocation *CommaLocs,
                                      SourceLocation RParenLoc) {