From: Rafael Espindola Date: Sat, 29 Dec 2012 23:43:00 +0000 (+0000) Subject: Don't warn for undefined but used decls that are external because of a typedef. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=9f409549fa36f1a69042d4793321e82004dbfea9;p=clang Don't warn for undefined but used decls that are external because of a typedef. This fixes pr14736. It is fairly ugly, but I don't think we can do much better as we have to wait at least until the end of the typedef to know if the function will have external linkage or not. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@171240 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Sema/Sema.cpp b/lib/Sema/Sema.cpp index 4b82069a62..0c5e8db1aa 100644 --- a/lib/Sema/Sema.cpp +++ b/lib/Sema/Sema.cpp @@ -394,6 +394,9 @@ static void checkUndefinedInternals(Sema &S) { // Ignore attributes that have become invalid. if (decl->isInvalidDecl()) continue; + // If we found out that the decl is external, don't warn. + if (decl->getLinkage() == ExternalLinkage) continue; + // __attribute__((weakref)) is basically a definition. if (decl->hasAttr()) continue; diff --git a/test/SemaCXX/undefined-internal.cpp b/test/SemaCXX/undefined-internal.cpp index 154172001e..e8ee4c1e90 100644 --- a/test/SemaCXX/undefined-internal.cpp +++ b/test/SemaCXX/undefined-internal.cpp @@ -181,3 +181,21 @@ namespace OverloadUse { template void t(long*) { x(10); } // expected-note {{used here}} void g() { long a; t(&a); } } + +namespace test7 { + typedef struct { + void bar(); + void foo() { + bar(); + } + } A; +} + +namespace test8 { + typedef struct { + void bar(); // expected-warning {{function 'test8::::bar' has internal linkage but is not defined}} + void foo() { + bar(); // expected-note {{used here}} + } + } *A; +}