summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJohn McCall <rjmccall@apple.com>2010-08-12 07:09:11 +0000
committerJohn McCall <rjmccall@apple.com>2010-08-12 07:09:11 +0000
commit8246e350be7c49c9a574c922d8c44fca58c90d91 (patch)
treec18737ac10a52c3d220d821fb89dbde0336e93be
parentac40d49c700731d4686bff7b85dfe5e89ff7b809 (diff)
downloadbcm5719-llvm-8246e350be7c49c9a574c922d8c44fca58c90d91.tar.gz
bcm5719-llvm-8246e350be7c49c9a574c922d8c44fca58c90d91.zip
Handle the obvious case for diagnosing redeclarations of extern "C" functions.
Fixes PR7859. llvm-svn: 110906
-rw-r--r--clang/lib/Sema/SemaOverload.cpp5
-rw-r--r--clang/test/SemaCXX/linkage-spec.cpp11
2 files changed, 16 insertions, 0 deletions
diff --git a/clang/lib/Sema/SemaOverload.cpp b/clang/lib/Sema/SemaOverload.cpp
index 339a79384c2..047a5d9ba58 100644
--- a/clang/lib/Sema/SemaOverload.cpp
+++ b/clang/lib/Sema/SemaOverload.cpp
@@ -573,6 +573,11 @@ Sema::CheckOverload(Scope *S, FunctionDecl *New, const LookupResult &Old,
bool Sema::IsOverload(FunctionDecl *New, FunctionDecl *Old,
bool UseUsingDeclRules) {
+ // If both of the functions are extern "C", then they are not
+ // overloads.
+ if (Old->isExternC() && New->isExternC())
+ return false;
+
FunctionTemplateDecl *OldTemplate = Old->getDescribedFunctionTemplate();
FunctionTemplateDecl *NewTemplate = New->getDescribedFunctionTemplate();
diff --git a/clang/test/SemaCXX/linkage-spec.cpp b/clang/test/SemaCXX/linkage-spec.cpp
index 0d1c166dcb3..fdb642c78fc 100644
--- a/clang/test/SemaCXX/linkage-spec.cpp
+++ b/clang/test/SemaCXX/linkage-spec.cpp
@@ -57,3 +57,14 @@ extern "C"
// PR6991
extern "C" typedef int (*PutcFunc_t)(int);
+
+
+// PR7859
+extern "C" void pr7859_a(int) {} // expected-note {{previous definition}}
+extern "C" void pr7859_a(int) {} // expected-error {{redefinition}}
+
+extern "C" void pr7859_b() {} // expected-note {{previous definition}}
+extern "C" void pr7859_b(int) {} // expected-error {{conflicting}}
+
+extern "C" void pr7859_c(short) {} // expected-note {{previous definition}}
+extern "C" void pr7859_c(int) {} // expected-error {{conflicting}}
OpenPOWER on IntegriCloud