forked from OSchip/llvm-project
Follow-up to r216619: use isCXXCLassMember() instead of trying to
check the context ourselves when selectively allowing late-added dll attributes on unused free functions and variables (PR20746) llvm-svn: 220874
This commit is contained in:
parent
323d57336c
commit
ac6073bb1f
|
@ -5140,7 +5140,7 @@ static void checkDLLAttributeRedeclaration(Sema &S, NamedDecl *OldDecl,
|
|||
// If the declaration hasn't been used yet, allow with a warning for
|
||||
// free functions and global variables.
|
||||
bool JustWarn = false;
|
||||
if (!OldDecl->isUsed() && OldDecl->getDeclContext()->isFileContext()) {
|
||||
if (!OldDecl->isUsed() && !OldDecl->isCXXClassMember()) {
|
||||
auto *VD = dyn_cast<VarDecl>(OldDecl);
|
||||
if (VD && !VD->getDescribedVarTemplate())
|
||||
JustWarn = true;
|
||||
|
|
|
@ -55,6 +55,11 @@ __declspec(dllexport) extern int GlobalRedecl2;
|
|||
extern int GlobalRedecl3; // expected-note{{previous declaration is here}}
|
||||
__declspec(dllexport) extern int GlobalRedecl3; // expected-warning{{redeclaration of 'GlobalRedecl3' should not add 'dllexport' attribute}}
|
||||
|
||||
extern "C" {
|
||||
extern int GlobalRedecl4; // expected-note{{previous declaration is here}}
|
||||
__declspec(dllexport) extern int GlobalRedecl4; // expected-warning{{redeclaration of 'GlobalRedecl4' should not add 'dllexport' attribute}}
|
||||
}
|
||||
|
||||
// External linkage is required.
|
||||
__declspec(dllexport) static int StaticGlobal; // expected-error{{'StaticGlobal' must have external linkage when declared 'dllexport'}}
|
||||
__declspec(dllexport) Internal InternalTypeGlobal; // expected-error{{'InternalTypeGlobal' must have external linkage when declared 'dllexport'}}
|
||||
|
@ -191,8 +196,13 @@ __declspec(dllexport) void redecl2();
|
|||
void redecl3(); // expected-note{{previous declaration is here}}
|
||||
__declspec(dllexport) void redecl3(); // expected-warning{{redeclaration of 'redecl3' should not add 'dllexport' attribute}}
|
||||
|
||||
extern "C" {
|
||||
void redecl4(); // expected-note{{previous declaration is here}}
|
||||
__declspec(dllexport) inline void redecl4() {} // expected-warning{{redeclaration of 'redecl4' should not add 'dllexport' attribute}}
|
||||
__declspec(dllexport) void redecl4(); // expected-warning{{redeclaration of 'redecl4' should not add 'dllexport' attribute}}
|
||||
}
|
||||
|
||||
void redecl5(); // expected-note{{previous declaration is here}}
|
||||
__declspec(dllexport) inline void redecl5() {} // expected-warning{{redeclaration of 'redecl5' should not add 'dllexport' attribute}}
|
||||
|
||||
// Friend functions
|
||||
struct FuncFriend {
|
||||
|
|
|
@ -77,6 +77,11 @@ __declspec(dllimport) extern int GlobalRedecl3; // expected-note{{previous decla
|
|||
extern int GlobalRedecl4; // expected-note{{previous declaration is here}}
|
||||
__declspec(dllimport) extern int GlobalRedecl4; // expected-warning{{redeclaration of 'GlobalRedecl4' should not add 'dllimport' attribute}}
|
||||
|
||||
extern "C" {
|
||||
extern int GlobalRedecl5; // expected-note{{previous declaration is here}}
|
||||
__declspec(dllimport) extern int GlobalRedecl5; // expected-warning{{redeclaration of 'GlobalRedecl5' should not add 'dllimport' attribute}}
|
||||
}
|
||||
|
||||
// External linkage is required.
|
||||
__declspec(dllimport) static int StaticGlobal; // expected-error{{'StaticGlobal' must have external linkage when declared 'dllimport'}}
|
||||
__declspec(dllimport) Internal InternalTypeGlobal; // expected-error{{'InternalTypeGlobal' must have external linkage when declared 'dllimport'}}
|
||||
|
@ -229,8 +234,13 @@ __declspec(dllimport) void redecl3(); // expected-note{{previous declaration is
|
|||
void redecl4(); // expected-note{{previous declaration is here}}
|
||||
__declspec(dllimport) void redecl4(); // expected-warning{{redeclaration of 'redecl4' should not add 'dllimport' attribute}}
|
||||
|
||||
extern "C" {
|
||||
void redecl5(); // expected-note{{previous declaration is here}}
|
||||
__declspec(dllimport) inline void redecl5() {} // expected-warning{{redeclaration of 'redecl5' should not add 'dllimport' attribute}}
|
||||
__declspec(dllimport) void redecl5(); // expected-warning{{redeclaration of 'redecl5' should not add 'dllimport' attribute}}
|
||||
}
|
||||
|
||||
void redecl6(); // expected-note{{previous declaration is here}}
|
||||
__declspec(dllimport) inline void redecl6() {} // expected-warning{{redeclaration of 'redecl6' should not add 'dllimport' attribute}}
|
||||
|
||||
// Friend functions
|
||||
struct FuncFriend {
|
||||
|
|
Loading…
Reference in New Issue