summaryrefslogtreecommitdiffstats
path: root/clang
diff options
context:
space:
mode:
authorKaelyn Uhrain <rikka@google.com>2011-08-04 23:30:54 +0000
committerKaelyn Uhrain <rikka@google.com>2011-08-04 23:30:54 +0000
commitea350180d2560ae338dacfeb454910fefcecf291 (patch)
treeb050296a29b68cddfb61169fd40960c4e224694f /clang
parent08d4bb0f1264a12290d8cfd613c2469da7fd3213 (diff)
downloadbcm5719-llvm-ea350180d2560ae338dacfeb454910fefcecf291.tar.gz
bcm5719-llvm-ea350180d2560ae338dacfeb454910fefcecf291.zip
Fix a small bug where DiagnoseEmptyLookup would no longer print any messages
when performing typo correction involving any overloaded template functions. The added test cases, while currently demontrating sub-optimal behavior, will not trigger any messages without the 1-line change to SemaExpr.cpp. llvm-svn: 136943
Diffstat (limited to 'clang')
-rw-r--r--clang/lib/Sema/SemaExpr.cpp3
-rw-r--r--clang/test/SemaCXX/function-overload-typo-crash.cpp19
2 files changed, 20 insertions, 2 deletions
diff --git a/clang/lib/Sema/SemaExpr.cpp b/clang/lib/Sema/SemaExpr.cpp
index 6ace3e92e60..ffa092aad1e 100644
--- a/clang/lib/Sema/SemaExpr.cpp
+++ b/clang/lib/Sema/SemaExpr.cpp
@@ -1468,8 +1468,7 @@ bool Sema::DiagnoseEmptyLookup(Scope *S, CXXScopeSpec &SS, LookupResult &R,
ND = Best->Function;
break;
default:
- // Don't try to recover; it won't work.
- return true;
+ break;
}
}
R.addDecl(ND);
diff --git a/clang/test/SemaCXX/function-overload-typo-crash.cpp b/clang/test/SemaCXX/function-overload-typo-crash.cpp
index 580f27a12af..a0f70dfbdb9 100644
--- a/clang/test/SemaCXX/function-overload-typo-crash.cpp
+++ b/clang/test/SemaCXX/function-overload-typo-crash.cpp
@@ -10,3 +10,22 @@ void f() {
fin(); //expected-error {{use of undeclared identifier 'fin'; did you mean 'min'}}
fax(0); //expected-error {{use of undeclared identifier 'fax'; did you mean 'max'}}
}
+
+// TODO: Add proper function overloading resolution for template functions
+template <typename T> void somefunc(T*, T*);
+template <typename T> void somefunc(const T[]);
+template <typename T1, typename T2> void somefunc(T1*, T2*);
+template <typename T1, typename T2> void somefunc(T1*, const T2[]); //expected-note 5 {{'somefunc' declared here}} \
+ //expected-note {{candidate function template not viable: requires 2 arguments, but 1 was provided}} TODO this shouldn't happen
+
+void c() {
+ int *i = 0, *j = 0;
+ const int x[] = {1, 2, 3};
+ long *l = 0;
+ somefun(i, j); //expected-error {{use of undeclared identifier 'somefun'; did you mean 'somefunc'?}}
+ somefun(x); //expected-error {{use of undeclared identifier 'somefun'; did you mean 'somefunc'?}} \
+ //expected-error {{no matching function for call to 'somefunc'}} TODO this shouldn't happen
+ somefun(i, l); //expected-error {{use of undeclared identifier 'somefun'; did you mean 'somefunc'?}}
+ somefun(l, x); //expected-error {{use of undeclared identifier 'somefun'; did you mean 'somefunc'?}}
+ somefun(i, x); //expected-error {{use of undeclared identifier 'somefun'; did you mean 'somefunc'?}}
+}
OpenPOWER on IntegriCloud