2015-05-27 03:44:52 +08:00
// RUN: %clang_cc1 -triple i686-win32 -fsyntax-only -fms-extensions -verify -std=c++11 -Wunsupported-dll-base-class-template -DMS %s
// RUN: %clang_cc1 -triple x86_64-win32 -fsyntax-only -fms-extensions -verify -std=c++1y -Wunsupported-dll-base-class-template -DMS %s
// RUN: %clang_cc1 -triple i686-mingw32 -fsyntax-only -fms-extensions -verify -std=c++1y -Wunsupported-dll-base-class-template -DGNU %s
// RUN: %clang_cc1 -triple x86_64-mingw32 -fsyntax-only -fms-extensions -verify -std=c++11 -Wunsupported-dll-base-class-template -DGNU %s
2014-02-23 03:47:30 +08:00
// Helper structs to make templates more expressive.
struct ImplicitInst_Imported { } ;
struct ExplicitDecl_Imported { } ;
struct ExplicitInst_Imported { } ;
struct ExplicitSpec_Imported { } ;
struct ExplicitSpec_Def_Imported { } ;
struct ExplicitSpec_InlineDef_Imported { } ;
struct ExplicitSpec_NotImported { } ;
2014-03-31 22:56:58 +08:00
namespace { struct Internal { } ; }
2014-02-23 03:47:30 +08:00
// Invalid usage.
2016-07-16 04:41:10 +08:00
__declspec ( dllimport ) typedef int typedef1 ;
2017-11-27 04:01:12 +08:00
// expected-warning@-1{{'dllimport' attribute only applies to functions, variables, classes, and Objective-C interfaces}}
2016-07-16 04:41:10 +08:00
typedef __declspec ( dllimport ) int typedef2 ;
2017-11-27 04:01:12 +08:00
// expected-warning@-1{{'dllimport' attribute only applies to}}
2016-07-16 04:41:10 +08:00
typedef int __declspec ( dllimport ) typedef3 ;
2017-11-27 04:01:12 +08:00
// expected-warning@-1{{'dllimport' attribute only applies to}}
2016-07-16 04:41:10 +08:00
typedef __declspec ( dllimport ) void ( * FunTy ) ( ) ;
2017-11-27 04:01:12 +08:00
// expected-warning@-1{{'dllimport' attribute only applies to}}
2016-07-16 04:41:10 +08:00
enum __declspec ( dllimport ) Enum { } ;
2017-11-27 04:01:12 +08:00
// expected-warning@-1{{'dllimport' attribute only applies to}}
2014-02-23 03:47:30 +08:00
# if __has_feature(cxx_strong_enums)
2016-07-16 04:41:10 +08:00
enum class __declspec ( dllimport ) EnumClass { } ;
2017-11-27 04:01:12 +08:00
// expected-warning@-1{{'dllimport' attribute only applies to}}
2014-02-23 03:47:30 +08:00
# endif
//===----------------------------------------------------------------------===//
// Globals
//===----------------------------------------------------------------------===//
// Import declaration.
__declspec ( dllimport ) extern int ExternGlobalDecl ;
2014-02-27 05:27:13 +08:00
// dllimport implies a declaration.
__declspec ( dllimport ) int GlobalDecl ;
2014-03-24 05:24:01 +08:00
int * * __attribute__ ( ( dllimport ) ) * GlobalDeclChunkAttr ;
int GlobalDeclAttr __attribute__ ( ( dllimport ) ) ;
2014-02-23 03:47:30 +08:00
// Not allowed on definitions.
2014-02-27 05:27:13 +08:00
__declspec ( dllimport ) extern int ExternGlobalInit = 1 ; // expected-error{{definition of dllimport data}}
__declspec ( dllimport ) int GlobalInit1 = 1 ; // expected-error{{definition of dllimport data}}
int __declspec ( dllimport ) GlobalInit2 = 1 ; // expected-error{{definition of dllimport data}}
2014-02-23 03:47:30 +08:00
// Declare, then reject definition.
2016-05-25 19:32:42 +08:00
# ifdef GNU
// expected-note@+2{{previous attribute is here}}
# endif
__declspec ( dllimport ) extern int ExternGlobalDeclInit ; // expected-note{{previous declaration is here}}
# ifdef MS
// expected-warning@+4{{'ExternGlobalDeclInit' redeclared without 'dllimport' attribute: 'dllexport' attribute added}}
# else
// expected-warning@+2{{'ExternGlobalDeclInit' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
# endif
int ExternGlobalDeclInit = 1 ;
2014-02-23 03:47:30 +08:00
2016-05-25 19:32:42 +08:00
# ifdef GNU
// expected-note@+2{{previous attribute is here}}
# endif
__declspec ( dllimport ) int GlobalDeclInit ; // expected-note{{previous declaration is here}}
# ifdef MS
// expected-warning@+4{{'GlobalDeclInit' redeclared without 'dllimport' attribute: 'dllexport' attribute added}}
# else
// expected-warning@+2{{'GlobalDeclInit' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
# endif
int GlobalDeclInit = 1 ;
2014-03-24 05:24:01 +08:00
2016-05-25 19:32:42 +08:00
# ifdef GNU
// expected-note@+2{{previous attribute is here}}
# endif
int * __attribute__ ( ( dllimport ) ) GlobalDeclChunkAttrInit ; // expected-note{{previous declaration is here}}
# ifdef MS
// expected-warning@+4{{'GlobalDeclChunkAttrInit' redeclared without 'dllimport' attribute: 'dllexport' attribute added}}
# else
// expected-warning@+2{{'GlobalDeclChunkAttrInit' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
# endif
int * GlobalDeclChunkAttrInit = 0 ;
2014-03-24 05:24:01 +08:00
2016-05-25 19:32:42 +08:00
# ifdef GNU
// expected-note@+2{{previous attribute is here}}
# endif
int GlobalDeclAttrInit __attribute__ ( ( dllimport ) ) ; // expected-note{{previous declaration is here}}
# ifdef MS
// expected-warning@+4{{'GlobalDeclAttrInit' redeclared without 'dllimport' attribute: 'dllexport' attribute added}}
# else
// expected-warning@+2{{'GlobalDeclAttrInit' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
# endif
int GlobalDeclAttrInit = 1 ;
2014-03-24 05:24:01 +08:00
2014-02-23 03:47:30 +08:00
// Redeclarations
__declspec ( dllimport ) extern int GlobalRedecl1 ;
__declspec ( dllimport ) extern int GlobalRedecl1 ;
2014-03-24 05:24:01 +08:00
__declspec ( dllimport ) int GlobalRedecl2a ;
__declspec ( dllimport ) int GlobalRedecl2a ;
int * __attribute__ ( ( dllimport ) ) GlobalRedecl2b ;
int * __attribute__ ( ( dllimport ) ) GlobalRedecl2b ;
int GlobalRedecl2c __attribute__ ( ( dllimport ) ) ;
int GlobalRedecl2c __attribute__ ( ( dllimport ) ) ;
2014-03-31 22:56:15 +08:00
__declspec ( dllimport ) extern int GlobalRedecl3 ; // expected-note{{previous declaration is here}} expected-note{{previous attribute is here}}
extern int GlobalRedecl3 ; // expected-warning{{'GlobalRedecl3' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
extern int GlobalRedecl4 ; // expected-note{{previous declaration is here}}
2014-08-28 05:27:40 +08:00
__declspec ( dllimport ) extern int GlobalRedecl4 ; // expected-warning{{redeclaration of 'GlobalRedecl4' should not add 'dllimport' attribute}}
2014-03-31 22:56:15 +08:00
2014-10-30 05:20:57 +08:00
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}}
}
2014-03-31 22:56:58 +08:00
// 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'}}
2019-03-19 22:53:52 +08:00
# ifndef MS
2014-04-02 14:18:49 +08:00
namespace { __declspec ( dllimport ) int InternalGlobal ; } // expected-error{{'(anonymous namespace)::InternalGlobal' must have external linkage when declared 'dllimport'}}
2019-03-19 22:53:52 +08:00
# endif
2014-03-31 22:56:58 +08:00
namespace ns { __declspec ( dllimport ) int ExternalGlobal ; }
__declspec ( dllimport ) auto InternalAutoTypeGlobal = Internal ( ) ; // expected-error{{'InternalAutoTypeGlobal' must have external linkage when declared 'dllimport'}}
// expected-error@-1{{definition of dllimport data}}
2014-10-04 14:51:54 +08:00
// Thread local variables are invalid.
__declspec ( dllimport ) __thread int ThreadLocalGlobal ; // expected-error{{'ThreadLocalGlobal' cannot be thread local when declared 'dllimport'}}
2015-08-29 05:47:01 +08:00
// This doesn't work on MinGW, because there, dllimport on the inline function is ignored.
# ifndef GNU
inline void __declspec ( dllimport ) ImportedInlineWithThreadLocal ( ) {
2015-09-05 03:59:39 +08:00
static __thread int OK ; // no-error
2015-08-29 05:47:01 +08:00
}
# endif
2014-10-04 14:51:54 +08:00
2014-02-23 03:47:30 +08:00
// Import in local scope.
2015-07-15 04:08:49 +08:00
__declspec ( dllimport ) float LocalRedecl1 ; // expected-note{{previous declaration is here}}
__declspec ( dllimport ) float LocalRedecl2 ; // expected-note{{previous declaration is here}}
__declspec ( dllimport ) float LocalRedecl3 ; // expected-note{{previous declaration is here}}
2014-02-23 03:47:30 +08:00
void functionScope ( ) {
2015-07-15 04:08:49 +08:00
__declspec ( dllimport ) int LocalRedecl1 ; // expected-error{{redeclaration of 'LocalRedecl1' with a different type: 'int' vs 'float'}}
int * __attribute__ ( ( dllimport ) ) LocalRedecl2 ; // expected-error{{redeclaration of 'LocalRedecl2' with a different type: 'int *' vs 'float'}}
int LocalRedecl3 __attribute__ ( ( dllimport ) ) ; // expected-error{{redeclaration of 'LocalRedecl3' with a different type: 'int' vs 'float'}}
2014-03-24 05:24:01 +08:00
2014-02-27 05:27:13 +08:00
__declspec ( dllimport ) int LocalVarDecl ;
__declspec ( dllimport ) int LocalVarDef = 1 ; // expected-error{{definition of dllimport data}}
2014-02-23 03:47:30 +08:00
__declspec ( dllimport ) extern int ExternLocalVarDecl ;
2014-02-27 05:27:13 +08:00
__declspec ( dllimport ) extern int ExternLocalVarDef = 1 ; // expected-error{{definition of dllimport data}}
2014-03-31 22:56:58 +08:00
__declspec ( dllimport ) static int StaticLocalVar ; // expected-error{{'StaticLocalVar' must have external linkage when declared 'dllimport'}}
2014-02-23 03:47:30 +08:00
}
2014-05-25 18:34:36 +08:00
//===----------------------------------------------------------------------===//
// Variable templates
//===----------------------------------------------------------------------===//
# if __has_feature(cxx_variable_templates)
// Import declaration.
template < typename T > __declspec ( dllimport ) extern int ExternVarTmplDecl ;
// dllimport implies a declaration.
template < typename T > __declspec ( dllimport ) int VarTmplDecl ;
// Not allowed on definitions.
template < typename T > __declspec ( dllimport ) extern int ExternVarTmplInit = 1 ; // expected-error{{definition of dllimport data}}
template < typename T > __declspec ( dllimport ) int VarTmplInit1 = 1 ; // expected-error{{definition of dllimport data}}
template < typename T > int __declspec ( dllimport ) VarTmplInit2 = 1 ; // expected-error{{definition of dllimport data}}
// Declare, then reject definition.
2016-05-25 19:32:42 +08:00
# ifdef GNU
// expected-note@+3{{previous attribute is here}}
# endif
template < typename T >
__declspec ( dllimport ) extern int ExternVarTmplDeclInit ; // expected-note{{previous declaration is here}}
# ifdef MS
// expected-warning@+5{{'ExternVarTmplDeclInit' redeclared without 'dllimport' attribute: 'dllexport' attribute added}}
# else
// expected-warning@+3{{'ExternVarTmplDeclInit' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
# endif
template < typename T >
int ExternVarTmplDeclInit = 1 ;
2014-05-25 18:34:36 +08:00
2016-05-25 19:32:42 +08:00
# ifdef GNU
// expected-note@+3{{previous attribute is here}}
# endif
template < typename T >
__declspec ( dllimport ) int VarTmplDeclInit ; // expected-note{{previous declaration is here}}
# ifdef MS
// expected-warning@+5{{'VarTmplDeclInit' redeclared without 'dllimport' attribute: 'dllexport' attribute added}}
# else
// expected-warning@+3{{'VarTmplDeclInit' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
# endif
template < typename T >
int VarTmplDeclInit = 1 ;
2014-05-25 18:34:36 +08:00
// Redeclarations
template < typename T > __declspec ( dllimport ) extern int VarTmplRedecl1 ;
template < typename T > __declspec ( dllimport ) extern int VarTmplRedecl1 ;
template < typename T > __declspec ( dllimport ) int VarTmplRedecl2 ;
template < typename T > __declspec ( dllimport ) int VarTmplRedecl2 ;
template < typename T > __declspec ( dllimport ) extern int VarTmplRedecl3 ; // expected-note{{previous declaration is here}} expected-note{{previous attribute is here}}
template < typename T > extern int VarTmplRedecl3 ; // expected-warning{{'VarTmplRedecl3' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
template < typename T > extern int VarTmplRedecl4 ; // expected-note{{previous declaration is here}}
template < typename T > __declspec ( dllimport ) extern int VarTmplRedecl4 ; // expected-error{{redeclaration of 'VarTmplRedecl4' cannot add 'dllimport' attribute}}
// External linkage is required.
template < typename T > __declspec ( dllimport ) static int StaticVarTmpl ; // expected-error{{'StaticVarTmpl' must have external linkage when declared 'dllimport'}}
template < typename T > __declspec ( dllimport ) Internal InternalTypeVarTmpl ; // expected-error{{'InternalTypeVarTmpl' must have external linkage when declared 'dllimport'}}
2019-03-19 22:53:52 +08:00
# ifndef MS
2014-05-25 18:34:36 +08:00
namespace { template < typename T > __declspec ( dllimport ) int InternalVarTmpl ; } // expected-error{{'(anonymous namespace)::InternalVarTmpl' must have external linkage when declared 'dllimport'}}
2019-03-19 22:53:52 +08:00
# endif
2014-05-25 18:34:36 +08:00
namespace ns { template < typename T > __declspec ( dllimport ) int ExternalVarTmpl ; }
template < typename T > __declspec ( dllimport ) auto InternalAutoTypeVarTmpl = Internal ( ) ; // expected-error{{definition of dllimport data}} // expected-error{{'InternalAutoTypeVarTmpl' must have external linkage when declared 'dllimport'}}
template < typename T > int VarTmpl ;
template < typename T > __declspec ( dllimport ) int ImportedVarTmpl ;
// Import implicit instantiation of an imported variable template.
int useVarTmpl ( ) { return ImportedVarTmpl < ImplicitInst_Imported > ; }
// Import explicit instantiation declaration of an imported variable template.
extern template int ImportedVarTmpl < ExplicitDecl_Imported > ;
// An explicit instantiation definition of an imported variable template cannot
// be imported because the template must be defined which is illegal.
// Import specialization of an imported variable template.
template < > __declspec ( dllimport ) int ImportedVarTmpl < ExplicitSpec_Imported > ;
template < > __declspec ( dllimport ) int ImportedVarTmpl < ExplicitSpec_Def_Imported > = 1 ; // expected-error{{definition of dllimport data}}
// Not importing specialization of an imported variable template without
// explicit dllimport.
template < > int ImportedVarTmpl < ExplicitSpec_NotImported > ;
// Import explicit instantiation declaration of a non-imported variable template.
extern template __declspec ( dllimport ) int VarTmpl < ExplicitDecl_Imported > ;
// Import explicit instantiation definition of a non-imported variable template.
template __declspec ( dllimport ) int VarTmpl < ExplicitInst_Imported > ;
// Import specialization of a non-imported variable template.
template < > __declspec ( dllimport ) int VarTmpl < ExplicitSpec_Imported > ;
template < > __declspec ( dllimport ) int VarTmpl < ExplicitSpec_Def_Imported > = 1 ; // expected-error{{definition of dllimport data}}
# endif // __has_feature(cxx_variable_templates)
2014-02-23 03:47:30 +08:00
//===----------------------------------------------------------------------===//
// Functions
//===----------------------------------------------------------------------===//
// Import function declaration. Check different placements.
__attribute__ ( ( dllimport ) ) void decl1A ( ) ; // Sanity check with __attribute__
__declspec ( dllimport ) void decl1B ( ) ;
void __attribute__ ( ( dllimport ) ) decl2A ( ) ;
void __declspec ( dllimport ) decl2B ( ) ;
// Not allowed on function definitions.
2014-05-16 06:07:49 +08:00
__declspec ( dllimport ) void def ( ) { } // expected-error{{dllimport cannot be applied to non-inline function definition}}
2014-02-23 03:47:30 +08:00
// extern "C"
2014-05-24 03:07:09 +08:00
extern " C " __declspec ( dllimport ) void externC ( ) ;
2014-02-23 03:47:30 +08:00
// Import inline function.
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+3{{'dllimport' attribute ignored on inline function}}
// expected-warning@+3{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-16 06:07:49 +08:00
__declspec ( dllimport ) inline void inlineFunc1 ( ) { }
inline void __attribute__ ( ( dllimport ) ) inlineFunc2 ( ) { }
2014-02-23 03:47:30 +08:00
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+2{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-24 03:07:49 +08:00
__declspec ( dllimport ) inline void inlineDecl ( ) ;
void inlineDecl ( ) { }
__declspec ( dllimport ) void inlineDef ( ) ;
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+2{{'inlineDef' redeclared inline; 'dllimport' attribute ignored}}
# endif
2014-05-24 03:07:49 +08:00
inline void inlineDef ( ) { }
2014-02-23 03:47:30 +08:00
// Redeclarations
__declspec ( dllimport ) void redecl1 ( ) ;
__declspec ( dllimport ) void redecl1 ( ) ;
2014-03-31 22:56:15 +08:00
__declspec ( dllimport ) void redecl2 ( ) ; // expected-note{{previous declaration is here}} expected-note{{previous attribute is here}}
void redecl2 ( ) ; // expected-warning{{'redecl2' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
2016-05-25 19:32:42 +08:00
# ifdef GNU
// expected-note@+2{{previous attribute is here}}
# endif
__declspec ( dllimport ) void redecl3 ( ) ; // expected-note{{previous declaration is here}}
// NB: Both MSVC and Clang issue a warning and make redecl3 dllexport.
# ifdef MS
// expected-warning@+4{{'redecl3' redeclared without 'dllimport' attribute: 'dllexport' attribute added}}
# else
// expected-warning@+2{{'redecl3' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
# endif
void redecl3 ( ) { }
2014-02-23 03:47:30 +08:00
2014-03-31 22:56:15 +08:00
void redecl4 ( ) ; // expected-note{{previous declaration is here}}
2014-08-28 05:27:40 +08:00
__declspec ( dllimport ) void redecl4 ( ) ; // expected-warning{{redeclaration of 'redecl4' should not add 'dllimport' attribute}}
2014-03-31 22:56:15 +08:00
2014-10-30 05:20:57 +08:00
extern " C " {
2014-05-24 03:07:49 +08:00
void redecl5 ( ) ; // expected-note{{previous declaration is here}}
2014-10-30 05:20:57 +08:00
__declspec ( dllimport ) void redecl5 ( ) ; // expected-warning{{redeclaration of 'redecl5' should not add 'dllimport' attribute}}
}
2014-11-03 22:24:45 +08:00
# ifdef MS
2014-10-30 05:20:57 +08:00
void redecl6 ( ) ; // expected-note{{previous declaration is here}}
__declspec ( dllimport ) inline void redecl6 ( ) { } // expected-warning{{redeclaration of 'redecl6' should not add 'dllimport' attribute}}
2014-11-03 22:24:45 +08:00
# else
void redecl6 ( ) ;
__declspec ( dllimport ) inline void redecl6 ( ) { } // expected-warning{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-24 03:07:49 +08:00
2014-03-31 22:56:15 +08:00
// Friend functions
struct FuncFriend {
friend __declspec ( dllimport ) void friend1 ( ) ;
friend __declspec ( dllimport ) void friend2 ( ) ; // expected-note{{previous declaration is here}} expected-note{{previous attribute is here}}
2016-05-25 19:32:42 +08:00
# ifdef GNU
// expected-note@+2{{previous attribute is here}}
# endif
friend __declspec ( dllimport ) void friend3 ( ) ; // expected-note{{previous declaration is here}}
2014-03-31 22:56:15 +08:00
friend void friend4 ( ) ; // expected-note{{previous declaration is here}}
2014-11-03 22:24:45 +08:00
# ifdef MS
// expected-note@+2{{previous declaration is here}}
# endif
friend void friend5 ( ) ;
2014-03-31 22:56:15 +08:00
} ;
__declspec ( dllimport ) void friend1 ( ) ;
void friend2 ( ) ; // expected-warning{{'friend2' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
2016-05-25 19:32:42 +08:00
# ifdef MS
// expected-warning@+4{{'friend3' redeclared without 'dllimport' attribute: 'dllexport' attribute added}}
# else
// expected-warning@+2{{'friend3' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
# endif
void friend3 ( ) { }
2014-08-28 05:27:40 +08:00
__declspec ( dllimport ) void friend4 ( ) ; // expected-warning{{redeclaration of 'friend4' should not add 'dllimport' attribute}}
2014-11-03 22:24:45 +08:00
# ifdef MS
2014-08-28 05:27:40 +08:00
__declspec ( dllimport ) inline void friend5 ( ) { } // expected-warning{{redeclaration of 'friend5' should not add 'dllimport' attribute}}
2014-11-03 22:24:45 +08:00
# else
__declspec ( dllimport ) inline void friend5 ( ) { } // expected-warning{{'dllimport' attribute ignored on inline function}}
# endif
2014-03-31 22:56:15 +08:00
2014-08-05 04:54:39 +08:00
void __declspec ( dllimport ) friend6 ( ) ; // expected-note{{previous declaration is here}} expected-note{{previous attribute is here}}
void __declspec ( dllimport ) friend7 ( ) ;
struct FuncFriend2 {
friend void friend6 ( ) ; // expected-warning{{'friend6' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
friend void : : friend7 ( ) ;
} ;
2014-03-31 22:56:15 +08:00
// Implicit declarations can be redeclared with dllimport.
__declspec ( dllimport ) void * operator new ( __SIZE_TYPE__ n ) ;
2014-03-31 22:56:58 +08:00
// External linkage is required.
__declspec ( dllimport ) static int staticFunc ( ) ; // expected-error{{'staticFunc' must have external linkage when declared 'dllimport'}}
__declspec ( dllimport ) Internal internalRetFunc ( ) ; // expected-error{{'internalRetFunc' must have external linkage when declared 'dllimport'}}
2014-04-02 14:18:49 +08:00
namespace { __declspec ( dllimport ) void internalFunc ( ) ; } // expected-error{{'(anonymous namespace)::internalFunc' must have external linkage when declared 'dllimport'}}
2014-03-31 22:56:58 +08:00
namespace ns { __declspec ( dllimport ) void externalFunc ( ) ; }
2014-05-30 00:51:19 +08:00
// Import deleted functions.
// FIXME: Deleted functions are definitions so a missing inline is diagnosed
// here which is irrelevant. But because the delete keyword is parsed later
// there is currently no straight-forward way to avoid this diagnostic.
__declspec ( dllimport ) void deletedFunc ( ) = delete ; // expected-error{{attribute 'dllimport' cannot be applied to a deleted function}} expected-error{{dllimport cannot be applied to non-inline function definition}}
2014-11-03 22:24:45 +08:00
# ifdef MS
2014-05-30 00:51:19 +08:00
__declspec ( dllimport ) inline void deletedInlineFunc ( ) = delete ; // expected-error{{attribute 'dllimport' cannot be applied to a deleted function}}
2014-11-03 22:24:45 +08:00
# else
__declspec ( dllimport ) inline void deletedInlineFunc ( ) = delete ; // expected-warning{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-30 00:51:19 +08:00
2014-02-23 03:47:30 +08:00
//===----------------------------------------------------------------------===//
// Function templates
//===----------------------------------------------------------------------===//
// Import function template declaration. Check different placements.
template < typename T > __declspec ( dllimport ) void funcTmplDecl1 ( ) ;
template < typename T > void __declspec ( dllimport ) funcTmplDecl2 ( ) ;
2014-05-24 03:07:49 +08:00
// Import function template definition.
template < typename T > __declspec ( dllimport ) void funcTmplDef ( ) { } // expected-error{{dllimport cannot be applied to non-inline function definition}}
// Import inline function template.
2017-02-02 02:52:53 +08:00
# ifdef GNU // MinGW always ignores dllimport on inline functions.
2014-05-24 03:07:49 +08:00
2017-02-02 02:52:53 +08:00
template < typename T > __declspec ( dllimport ) inline void inlineFuncTmpl1 ( ) { } // expected-warning{{'dllimport' attribute ignored on inline function}}
template < typename T > inline void __attribute__ ( ( dllimport ) ) inlineFuncTmpl2 ( ) { } // expected-warning{{'dllimport' attribute ignored on inline function}}
template < typename T > __declspec ( dllimport ) inline void inlineFuncTmplDecl ( ) ; // expected-warning{{'dllimport' attribute ignored on inline function}}
2014-05-24 03:07:49 +08:00
template < typename T > void inlineFuncTmplDecl ( ) { }
template < typename T > __declspec ( dllimport ) void inlineFuncTmplDef ( ) ;
2017-02-02 02:52:53 +08:00
template < typename T > inline void inlineFuncTmplDef ( ) { } // expected-warning{{'inlineFuncTmplDef' redeclared inline; 'dllimport' attribute ignored}}
# else // MSVC drops dllimport when the function template is redeclared without it. (It doesn't warn, but we do.)
template < typename T > __declspec ( dllimport ) inline void inlineFuncTmpl1 ( ) { }
template < typename T > inline void __attribute__ ( ( dllimport ) ) inlineFuncTmpl2 ( ) { }
template < typename T > __declspec ( dllimport ) inline void inlineFuncTmplDecl ( ) ; // expected-note{{previous declaration is here}} expected-note{{previous attribute is here}}
template < typename T > void inlineFuncTmplDecl ( ) { } // expected-warning{{'inlineFuncTmplDecl' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
template < typename T > __declspec ( dllimport ) void inlineFuncTmplDef ( ) ; // expected-note{{previous declaration is here}} expected-note{{previous attribute is here}}
template < typename T > inline void inlineFuncTmplDef ( ) { } // expected-warning{{'inlineFuncTmplDef' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
# endif
2014-05-24 03:07:49 +08:00
2014-02-23 03:47:30 +08:00
// Redeclarations
template < typename T > __declspec ( dllimport ) void funcTmplRedecl1 ( ) ;
template < typename T > __declspec ( dllimport ) void funcTmplRedecl1 ( ) ;
2014-03-31 22:56:15 +08:00
template < typename T > __declspec ( dllimport ) void funcTmplRedecl2 ( ) ; // expected-note{{previous declaration is here}} expected-note{{previous attribute is here}}
template < typename T > void funcTmplRedecl2 ( ) ; // expected-warning{{'funcTmplRedecl2' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
2014-02-23 03:47:30 +08:00
2014-03-31 22:56:15 +08:00
template < typename T > __declspec ( dllimport ) void funcTmplRedecl3 ( ) ; // expected-note{{previous declaration is here}} expected-note{{previous attribute is here}}
2014-02-23 03:47:30 +08:00
template < typename T > void funcTmplRedecl3 ( ) { } // expected-warning{{'funcTmplRedecl3' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
2014-03-31 22:56:15 +08:00
template < typename T > void funcTmplRedecl4 ( ) ; // expected-note{{previous declaration is here}}
template < typename T > __declspec ( dllimport ) void funcTmplRedecl4 ( ) ; // expected-error{{redeclaration of 'funcTmplRedecl4' cannot add 'dllimport' attribute}}
2014-11-03 22:24:45 +08:00
# ifdef MS
2014-05-24 03:07:49 +08:00
template < typename T > void funcTmplRedecl5 ( ) ; // expected-note{{previous declaration is here}}
template < typename T > __declspec ( dllimport ) inline void funcTmplRedecl5 ( ) { } // expected-error{{redeclaration of 'funcTmplRedecl5' cannot add 'dllimport' attribute}}
2014-11-03 22:24:45 +08:00
# endif
2014-05-24 03:07:49 +08:00
2014-03-31 22:56:15 +08:00
// Function template friends
struct FuncTmplFriend {
template < typename T > friend __declspec ( dllimport ) void funcTmplFriend1 ( ) ;
template < typename T > friend __declspec ( dllimport ) void funcTmplFriend2 ( ) ; // expected-note{{previous declaration is here}} expected-note{{previous attribute is here}}
template < typename T > friend __declspec ( dllimport ) void funcTmplFriend3 ( ) ; // expected-note{{previous declaration is here}} expected-note{{previous attribute is here}}
template < typename T > friend void funcTmplFriend4 ( ) ; // expected-note{{previous declaration is here}}
2014-11-03 22:24:45 +08:00
# ifdef GNU
2017-02-02 02:52:53 +08:00
// expected-warning@+4{{'dllimport' attribute ignored on inline function}}
# else
// expected-note@+2{{previous declaration is here}} expected-note@+2{{previous attribute is here}}
2014-11-03 22:24:45 +08:00
# endif
2014-05-24 03:07:49 +08:00
template < typename T > friend __declspec ( dllimport ) inline void funcTmplFriend5 ( ) ;
2014-03-31 22:56:15 +08:00
} ;
template < typename T > __declspec ( dllimport ) void funcTmplFriend1 ( ) ;
template < typename T > void funcTmplFriend2 ( ) ; // expected-warning{{'funcTmplFriend2' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
template < typename T > void funcTmplFriend3 ( ) { } // expected-warning{{'funcTmplFriend3' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
template < typename T > __declspec ( dllimport ) void funcTmplFriend4 ( ) ; // expected-error{{redeclaration of 'funcTmplFriend4' cannot add 'dllimport' attribute}}
2017-02-02 02:52:53 +08:00
# ifdef MS
// expected-warning@+2{{'funcTmplFriend5' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
# endif
2014-05-24 03:07:49 +08:00
template < typename T > inline void funcTmplFriend5 ( ) { }
2014-03-31 22:56:15 +08:00
2014-03-31 22:56:58 +08:00
// External linkage is required.
template < typename T > __declspec ( dllimport ) static int staticFuncTmpl ( ) ; // expected-error{{'staticFuncTmpl' must have external linkage when declared 'dllimport'}}
template < typename T > __declspec ( dllimport ) Internal internalRetFuncTmpl ( ) ; // expected-error{{'internalRetFuncTmpl' must have external linkage when declared 'dllimport'}}
2014-04-02 14:18:49 +08:00
namespace { template < typename T > __declspec ( dllimport ) void internalFuncTmpl ( ) ; } // expected-error{{'(anonymous namespace)::internalFuncTmpl' must have external linkage when declared 'dllimport'}}
2014-03-31 22:56:58 +08:00
namespace ns { template < typename T > __declspec ( dllimport ) void externalFuncTmpl ( ) ; }
2014-02-23 03:47:30 +08:00
template < typename T > void funcTmpl ( ) { }
2014-05-24 03:07:49 +08:00
template < typename T > inline void inlineFuncTmpl ( ) { }
template < typename T > __declspec ( dllimport ) void importedFuncTmplDecl ( ) ;
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+2{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-24 03:07:49 +08:00
template < typename T > __declspec ( dllimport ) inline void importedFuncTmpl ( ) { }
// Import implicit instantiation of an imported function template.
void useFunTmplDecl ( ) { importedFuncTmplDecl < ImplicitInst_Imported > ( ) ; }
void useFunTmplDef ( ) { importedFuncTmpl < ImplicitInst_Imported > ( ) ; }
// Import explicit instantiation declaration of an imported function template.
extern template void importedFuncTmpl < ExplicitDecl_Imported > ( ) ;
// Import explicit instantiation definition of an imported function template.
// NB: MSVC fails this instantiation without explicit dllimport which is most
// likely a bug because an implicit instantiation is accepted.
template void importedFuncTmpl < ExplicitInst_Imported > ( ) ;
2014-02-23 03:47:30 +08:00
// Import specialization of an imported function template. A definition must be
// declared inline.
template < > __declspec ( dllimport ) void importedFuncTmpl < ExplicitSpec_Imported > ( ) ;
2014-05-16 06:07:49 +08:00
template < > __declspec ( dllimport ) void importedFuncTmpl < ExplicitSpec_Def_Imported > ( ) { } // expected-error{{dllimport cannot be applied to non-inline function definition}}
2014-11-03 22:24:45 +08:00
# ifdef MS
2014-05-16 06:07:49 +08:00
template < > __declspec ( dllimport ) inline void importedFuncTmpl < ExplicitSpec_InlineDef_Imported > ( ) { }
2014-11-03 22:24:45 +08:00
# endif
2014-02-23 03:47:30 +08:00
// Not importing specialization of an imported function template without
// explicit dllimport.
template < > void importedFuncTmpl < ExplicitSpec_NotImported > ( ) { }
// Import explicit instantiation declaration of a non-imported function template.
extern template __declspec ( dllimport ) void funcTmpl < ExplicitDecl_Imported > ( ) ;
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+2{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-24 03:07:49 +08:00
extern template __declspec ( dllimport ) void inlineFuncTmpl < ExplicitDecl_Imported > ( ) ;
// Import explicit instantiation definition of a non-imported function template.
template __declspec ( dllimport ) void funcTmpl < ExplicitInst_Imported > ( ) ;
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+2{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-24 03:07:49 +08:00
template __declspec ( dllimport ) void inlineFuncTmpl < ExplicitInst_Imported > ( ) ;
2014-02-23 03:47:30 +08:00
// Import specialization of a non-imported function template. A definition must
// be declared inline.
template < > __declspec ( dllimport ) void funcTmpl < ExplicitSpec_Imported > ( ) ;
2014-05-16 06:07:49 +08:00
template < > __declspec ( dllimport ) void funcTmpl < ExplicitSpec_Def_Imported > ( ) { } // expected-error{{dllimport cannot be applied to non-inline function definition}}
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+2{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-16 06:07:49 +08:00
template < > __declspec ( dllimport ) inline void funcTmpl < ExplicitSpec_InlineDef_Imported > ( ) { }
2014-05-25 18:35:03 +08:00
//===----------------------------------------------------------------------===//
// Class members
//===----------------------------------------------------------------------===//
// Import individual members of a class.
struct ImportMembers {
struct Nested {
__declspec ( dllimport ) void normalDecl ( ) ;
2016-05-25 19:32:42 +08:00
# ifdef GNU
// expected-note@+2{{previous attribute is here}}
# endif
__declspec ( dllimport ) void normalDef ( ) ; // expected-note{{previous declaration is here}}
2014-05-25 18:35:03 +08:00
} ;
2014-11-03 22:24:45 +08:00
# ifdef GNU
2016-05-25 19:32:42 +08:00
// expected-note@+5{{previous attribute is here}}
2014-11-03 22:24:45 +08:00
// expected-warning@+5{{'dllimport' attribute ignored on inline function}}
// expected-warning@+6{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-25 18:35:03 +08:00
__declspec ( dllimport ) void normalDecl ( ) ;
2016-05-25 19:32:42 +08:00
__declspec ( dllimport ) void normalDef ( ) ; // expected-note{{previous declaration is here}}
2014-05-25 18:35:03 +08:00
__declspec ( dllimport ) void normalInclass ( ) { }
__declspec ( dllimport ) void normalInlineDef ( ) ;
__declspec ( dllimport ) inline void normalInlineDecl ( ) ;
2014-11-03 22:24:45 +08:00
# ifdef GNU
2016-05-25 19:32:42 +08:00
// expected-note@+5{{previous attribute is here}}
2014-11-03 22:24:45 +08:00
// expected-warning@+5{{'dllimport' attribute ignored on inline function}}
// expected-warning@+6{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-25 18:35:03 +08:00
__declspec ( dllimport ) virtual void virtualDecl ( ) ;
2016-05-25 19:32:42 +08:00
__declspec ( dllimport ) virtual void virtualDef ( ) ; // expected-note{{previous declaration is here}}
2014-05-25 18:35:03 +08:00
__declspec ( dllimport ) virtual void virtualInclass ( ) { }
__declspec ( dllimport ) virtual void virtualInlineDef ( ) ;
__declspec ( dllimport ) virtual inline void virtualInlineDecl ( ) ;
2014-11-03 22:24:45 +08:00
# ifdef GNU
2016-05-25 19:32:42 +08:00
// expected-note@+5{{previous attribute is here}}
2014-11-03 22:24:45 +08:00
// expected-warning@+5{{'dllimport' attribute ignored on inline function}}
// expected-warning@+6{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-25 18:35:03 +08:00
__declspec ( dllimport ) static void staticDecl ( ) ;
2016-05-25 19:32:42 +08:00
__declspec ( dllimport ) static void staticDef ( ) ; // expected-note{{previous declaration is here}}
2014-05-25 18:35:03 +08:00
__declspec ( dllimport ) static void staticInclass ( ) { }
__declspec ( dllimport ) static void staticInlineDef ( ) ;
__declspec ( dllimport ) static inline void staticInlineDecl ( ) ;
protected :
__declspec ( dllimport ) void protectedDecl ( ) ;
private :
__declspec ( dllimport ) void privateDecl ( ) ;
2014-05-30 00:50:20 +08:00
public :
2017-11-27 04:01:12 +08:00
__declspec ( dllimport ) int Field ; // expected-warning{{'dllimport' attribute only applies to}}
2014-05-30 00:50:20 +08:00
__declspec ( dllimport ) static int StaticField ;
__declspec ( dllimport ) static int StaticFieldDef ; // expected-note{{attribute is here}}
__declspec ( dllimport ) static const int StaticConstField ;
__declspec ( dllimport ) static const int StaticConstFieldDef ; // expected-note{{attribute is here}}
__declspec ( dllimport ) static const int StaticConstFieldEqualInit = 1 ;
__declspec ( dllimport ) static const int StaticConstFieldBraceInit { 1 } ;
__declspec ( dllimport ) constexpr static int ConstexprField = 1 ;
__declspec ( dllimport ) constexpr static int ConstexprFieldDef = 1 ; // expected-note{{attribute is here}}
2014-05-25 18:35:03 +08:00
} ;
2016-05-25 19:32:42 +08:00
# ifdef MS
// expected-warning@+4{{'ImportMembers::Nested::normalDef' redeclared without 'dllimport' attribute: 'dllexport' attribute added}}
# else
// expected-warning@+2{{'ImportMembers::Nested::normalDef' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
# endif
void ImportMembers : : Nested : : normalDef ( ) { }
# ifdef MS
// expected-warning@+4{{'ImportMembers::normalDef' redeclared without 'dllimport' attribute: 'dllexport' attribute added}}
# else
// expected-warning@+2{{'ImportMembers::normalDef' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
# endif
void ImportMembers : : normalDef ( ) { }
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+2{{'ImportMembers::normalInlineDef' redeclared inline; 'dllimport' attribute ignored}}
# endif
2014-05-25 18:35:03 +08:00
inline void ImportMembers : : normalInlineDef ( ) { }
void ImportMembers : : normalInlineDecl ( ) { }
2016-05-25 19:32:42 +08:00
# ifdef MS
// expected-warning@+4{{'ImportMembers::virtualDef' redeclared without 'dllimport' attribute: 'dllexport' attribute added}}
# else
// expected-warning@+2{{'ImportMembers::virtualDef' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
# endif
void ImportMembers : : virtualDef ( ) { }
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+2{{'ImportMembers::virtualInlineDef' redeclared inline; 'dllimport' attribute ignored}}
# endif
2014-05-25 18:35:03 +08:00
inline void ImportMembers : : virtualInlineDef ( ) { }
void ImportMembers : : virtualInlineDecl ( ) { }
2016-05-25 19:32:42 +08:00
# ifdef MS
// expected-warning@+4{{'ImportMembers::staticDef' redeclared without 'dllimport' attribute: 'dllexport' attribute added}}
# else
// expected-warning@+2{{'ImportMembers::staticDef' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
# endif
void ImportMembers : : staticDef ( ) { }
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+2{{'ImportMembers::staticInlineDef' redeclared inline; 'dllimport' attribute ignored}}
# endif
2014-05-25 18:35:03 +08:00
inline void ImportMembers : : staticInlineDef ( ) { }
void ImportMembers : : staticInlineDecl ( ) { }
2014-05-30 00:50:20 +08:00
int ImportMembers : : StaticFieldDef ; // expected-error{{definition of dllimport static field not allowed}}
const int ImportMembers : : StaticConstFieldDef = 1 ; // expected-error{{definition of dllimport static field not allowed}}
constexpr int ImportMembers : : ConstexprFieldDef ; // expected-error{{definition of dllimport static field not allowed}}
2014-05-25 18:35:03 +08:00
// Import on member definitions.
struct ImportMemberDefs {
__declspec ( dllimport ) void normalDef ( ) ;
__declspec ( dllimport ) void normalInlineDef ( ) ;
__declspec ( dllimport ) virtual void virtualDef ( ) ;
__declspec ( dllimport ) virtual void virtualInlineDef ( ) ;
__declspec ( dllimport ) static void staticDef ( ) ;
__declspec ( dllimport ) static void staticInlineDef ( ) ;
2014-11-03 22:24:45 +08:00
# ifdef MS
__declspec ( dllimport ) inline void normalInlineDecl ( ) ;
__declspec ( dllimport ) virtual inline void virtualInlineDecl ( ) ;
2014-05-25 18:35:03 +08:00
__declspec ( dllimport ) static inline void staticInlineDecl ( ) ;
2014-11-03 22:24:45 +08:00
# endif
2014-05-30 00:50:20 +08:00
__declspec ( dllimport ) static int StaticField ;
__declspec ( dllimport ) static const int StaticConstField ;
__declspec ( dllimport ) constexpr static int ConstexprField = 1 ;
2014-05-25 18:35:03 +08:00
} ;
__declspec ( dllimport ) void ImportMemberDefs : : normalDef ( ) { } // expected-error{{dllimport cannot be applied to non-inline function definition}}
2014-11-03 22:24:45 +08:00
__declspec ( dllimport ) void ImportMemberDefs : : virtualDef ( ) { } // expected-error{{dllimport cannot be applied to non-inline function definition}}
__declspec ( dllimport ) void ImportMemberDefs : : staticDef ( ) { } // expected-error{{dllimport cannot be applied to non-inline function definition}}
# ifdef MS
2014-05-25 18:35:03 +08:00
__declspec ( dllimport ) inline void ImportMemberDefs : : normalInlineDef ( ) { }
__declspec ( dllimport ) void ImportMemberDefs : : normalInlineDecl ( ) { }
__declspec ( dllimport ) inline void ImportMemberDefs : : virtualInlineDef ( ) { }
__declspec ( dllimport ) void ImportMemberDefs : : virtualInlineDecl ( ) { }
__declspec ( dllimport ) inline void ImportMemberDefs : : staticInlineDef ( ) { }
__declspec ( dllimport ) void ImportMemberDefs : : staticInlineDecl ( ) { }
2014-11-03 22:24:45 +08:00
# endif
2014-05-25 18:35:03 +08:00
2014-05-30 00:50:20 +08:00
__declspec ( dllimport ) int ImportMemberDefs : : StaticField ; // expected-error{{definition of dllimport static field not allowed}} expected-note{{attribute is here}}
__declspec ( dllimport ) const int ImportMemberDefs : : StaticConstField = 1 ; // expected-error{{definition of dllimport static field not allowed}} expected-note{{attribute is here}}
__declspec ( dllimport ) constexpr int ImportMemberDefs : : ConstexprField ; // expected-error{{definition of dllimport static field not allowed}} expected-note{{attribute is here}}
2014-05-25 18:35:03 +08:00
// Import special member functions.
struct ImportSpecials {
__declspec ( dllimport ) ImportSpecials ( ) ;
__declspec ( dllimport ) ~ ImportSpecials ( ) ;
__declspec ( dllimport ) ImportSpecials ( const ImportSpecials & ) ;
__declspec ( dllimport ) ImportSpecials & operator = ( const ImportSpecials & ) ;
__declspec ( dllimport ) ImportSpecials ( ImportSpecials & & ) ;
__declspec ( dllimport ) ImportSpecials & operator = ( ImportSpecials & & ) ;
} ;
2014-05-30 00:51:19 +08:00
// Import deleted member functions.
struct ImportDeleted {
2014-11-03 22:24:45 +08:00
# ifdef MS
2014-05-30 00:51:19 +08:00
__declspec ( dllimport ) ImportDeleted ( ) = delete ; // expected-error{{attribute 'dllimport' cannot be applied to a deleted function}}
__declspec ( dllimport ) ~ ImportDeleted ( ) = delete ; // expected-error{{attribute 'dllimport' cannot be applied to a deleted function}}
__declspec ( dllimport ) ImportDeleted ( const ImportDeleted & ) = delete ; // expected-error{{attribute 'dllimport' cannot be applied to a deleted function}}
__declspec ( dllimport ) ImportDeleted & operator = ( const ImportDeleted & ) = delete ; // expected-error{{attribute 'dllimport' cannot be applied to a deleted function}}
__declspec ( dllimport ) ImportDeleted ( ImportDeleted & & ) = delete ; // expected-error{{attribute 'dllimport' cannot be applied to a deleted function}}
__declspec ( dllimport ) ImportDeleted & operator = ( ImportDeleted & & ) = delete ; // expected-error{{attribute 'dllimport' cannot be applied to a deleted function}}
__declspec ( dllimport ) void deleted ( ) = delete ; // expected-error{{attribute 'dllimport' cannot be applied to a deleted function}}
2014-11-03 22:24:45 +08:00
# else
__declspec ( dllimport ) ImportDeleted ( ) = delete ; // expected-warning{{'dllimport' attribute ignored on inline function}}
__declspec ( dllimport ) ~ ImportDeleted ( ) = delete ; // expected-warning{{'dllimport' attribute ignored on inline function}}
__declspec ( dllimport ) ImportDeleted ( const ImportDeleted & ) = delete ; // expected-warning{{'dllimport' attribute ignored on inline function}}
__declspec ( dllimport ) ImportDeleted & operator = ( const ImportDeleted & ) = delete ; // expected-warning{{'dllimport' attribute ignored on inline function}}
__declspec ( dllimport ) ImportDeleted ( ImportDeleted & & ) = delete ; // expected-warning{{'dllimport' attribute ignored on inline function}}
__declspec ( dllimport ) ImportDeleted & operator = ( ImportDeleted & & ) = delete ; // expected-warning{{'dllimport' attribute ignored on inline function}}
__declspec ( dllimport ) void deleted ( ) = delete ; // expected-warning{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-30 00:51:19 +08:00
} ;
2014-05-25 18:35:03 +08:00
// Import allocation functions.
struct ImportAlloc {
__declspec ( dllimport ) void * operator new ( __SIZE_TYPE__ ) ;
__declspec ( dllimport ) void * operator new [ ] ( __SIZE_TYPE__ ) ;
__declspec ( dllimport ) void operator delete ( void * ) ;
__declspec ( dllimport ) void operator delete [ ] ( void * ) ;
} ;
// Import defaulted member functions.
struct ImportDefaulted {
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+7{{'dllimport' attribute ignored on inline function}}
// expected-warning@+7{{'dllimport' attribute ignored on inline function}}
// expected-warning@+7{{'dllimport' attribute ignored on inline function}}
// expected-warning@+7{{'dllimport' attribute ignored on inline function}}
// expected-warning@+7{{'dllimport' attribute ignored on inline function}}
// expected-warning@+7{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-25 18:35:03 +08:00
__declspec ( dllimport ) ImportDefaulted ( ) = default ;
__declspec ( dllimport ) ~ ImportDefaulted ( ) = default ;
__declspec ( dllimport ) ImportDefaulted ( const ImportDefaulted & ) = default ;
__declspec ( dllimport ) ImportDefaulted & operator = ( const ImportDefaulted & ) = default ;
__declspec ( dllimport ) ImportDefaulted ( ImportDefaulted & & ) = default ;
__declspec ( dllimport ) ImportDefaulted & operator = ( ImportDefaulted & & ) = default ;
} ;
// Import defaulted member function definitions.
struct ImportDefaultedDefs {
__declspec ( dllimport ) ImportDefaultedDefs ( ) ;
2016-05-25 19:32:42 +08:00
# ifdef GNU
// expected-note@+2{{previous attribute is here}}
# endif
__declspec ( dllimport ) ~ ImportDefaultedDefs ( ) ; // expected-note{{previous declaration is here}}
2014-05-25 18:35:03 +08:00
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+3{{'dllimport' attribute ignored on inline function}}
// expected-note@+2{{previous declaration is here}}
# endif
2014-05-25 18:35:03 +08:00
__declspec ( dllimport ) inline ImportDefaultedDefs ( const ImportDefaultedDefs & ) ;
__declspec ( dllimport ) ImportDefaultedDefs & operator = ( const ImportDefaultedDefs & ) ;
__declspec ( dllimport ) ImportDefaultedDefs ( ImportDefaultedDefs & & ) ;
2016-05-25 19:32:42 +08:00
# ifdef GNU
// expected-note@+2{{previous attribute is here}}
# endif
__declspec ( dllimport ) ImportDefaultedDefs & operator = ( ImportDefaultedDefs & & ) ; // expected-note{{previous declaration is here}}
2014-05-25 18:35:03 +08:00
} ;
// Not allowed on definitions.
__declspec ( dllimport ) ImportDefaultedDefs : : ImportDefaultedDefs ( ) = default ; // expected-error{{dllimport cannot be applied to non-inline function definition}}
2016-05-25 19:32:42 +08:00
# ifdef MS
// expected-warning@+5{{'ImportDefaultedDefs::~ImportDefaultedDefs' redeclared without 'dllimport' attribute: 'dllexport' attribute added}}
# else
// expected-warning@+3{{'ImportDefaultedDefs::~ImportDefaultedDefs' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
# endif
2014-05-25 18:35:03 +08:00
// dllimport cannot be dropped.
2016-05-25 19:32:42 +08:00
ImportDefaultedDefs : : ~ ImportDefaultedDefs ( ) = default ;
2014-05-25 18:35:03 +08:00
// Import inline declaration and definition.
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-error@+3{{redeclaration of 'ImportDefaultedDefs::ImportDefaultedDefs' cannot add 'dllimport' attribute}}
// expected-warning@+3{{'ImportDefaultedDefs::operator=' redeclared inline; 'dllimport' attribute ignored}}
# endif
2014-05-25 18:35:03 +08:00
__declspec ( dllimport ) ImportDefaultedDefs : : ImportDefaultedDefs ( const ImportDefaultedDefs & ) = default ;
inline ImportDefaultedDefs & ImportDefaultedDefs : : operator = ( const ImportDefaultedDefs & ) = default ;
__declspec ( dllimport ) ImportDefaultedDefs : : ImportDefaultedDefs ( ImportDefaultedDefs & & ) = default ; // expected-error{{dllimport cannot be applied to non-inline function definition}}
2016-05-25 19:32:42 +08:00
# ifdef MS
// expected-warning@+4{{'ImportDefaultedDefs::operator=' redeclared without 'dllimport' attribute: 'dllexport' attribute added}}
# else
// expected-warning@+2{{'ImportDefaultedDefs::operator=' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
# endif
ImportDefaultedDefs & ImportDefaultedDefs : : operator = ( ImportDefaultedDefs & & ) = default ;
2014-05-25 18:35:03 +08:00
// Redeclarations cannot add dllimport.
struct MemberRedecl {
void normalDef ( ) ; // expected-note{{previous declaration is here}}
inline void normalInlineDecl ( ) ; // expected-note{{previous declaration is here}}
virtual void virtualDef ( ) ; // expected-note{{previous declaration is here}}
virtual inline void virtualInlineDecl ( ) ; // expected-note{{previous declaration is here}}
static void staticDef ( ) ; // expected-note{{previous declaration is here}}
static inline void staticInlineDecl ( ) ; // expected-note{{previous declaration is here}}
2014-05-30 00:50:20 +08:00
2014-11-03 22:24:45 +08:00
# ifdef MS
// expected-note@+4{{previous declaration is here}}
// expected-note@+4{{previous declaration is here}}
// expected-note@+4{{previous declaration is here}}
# endif
void normalInlineDef ( ) ;
virtual void virtualInlineDef ( ) ;
static void staticInlineDef ( ) ;
2014-05-30 00:50:20 +08:00
static int StaticField ; // expected-note{{previous declaration is here}}
static const int StaticConstField ; // expected-note{{previous declaration is here}}
constexpr static int ConstexprField = 1 ; // expected-note{{previous declaration is here}}
2014-05-25 18:35:03 +08:00
} ;
__declspec ( dllimport ) void MemberRedecl : : normalDef ( ) { } // expected-error{{redeclaration of 'MemberRedecl::normalDef' cannot add 'dllimport' attribute}}
// expected-error@-1{{dllimport cannot be applied to non-inline function definition}}
__declspec ( dllimport ) void MemberRedecl : : normalInlineDecl ( ) { } // expected-error{{redeclaration of 'MemberRedecl::normalInlineDecl' cannot add 'dllimport' attribute}}
__declspec ( dllimport ) void MemberRedecl : : virtualDef ( ) { } // expected-error{{redeclaration of 'MemberRedecl::virtualDef' cannot add 'dllimport' attribute}}
// expected-error@-1{{dllimport cannot be applied to non-inline function definition}}
__declspec ( dllimport ) void MemberRedecl : : virtualInlineDecl ( ) { } // expected-error{{redeclaration of 'MemberRedecl::virtualInlineDecl' cannot add 'dllimport' attribute}}
__declspec ( dllimport ) void MemberRedecl : : staticDef ( ) { } // expected-error{{redeclaration of 'MemberRedecl::staticDef' cannot add 'dllimport' attribute}}
// expected-error@-1{{dllimport cannot be applied to non-inline function definition}}
__declspec ( dllimport ) void MemberRedecl : : staticInlineDecl ( ) { } // expected-error{{redeclaration of 'MemberRedecl::staticInlineDecl' cannot add 'dllimport' attribute}}
2014-11-03 22:24:45 +08:00
# ifdef MS
__declspec ( dllimport ) inline void MemberRedecl : : normalInlineDef ( ) { } // expected-error{{redeclaration of 'MemberRedecl::normalInlineDef' cannot add 'dllimport' attribute}}
__declspec ( dllimport ) inline void MemberRedecl : : virtualInlineDef ( ) { } // expected-error{{redeclaration of 'MemberRedecl::virtualInlineDef' cannot add 'dllimport' attribute}}
__declspec ( dllimport ) inline void MemberRedecl : : staticInlineDef ( ) { } // expected-error{{redeclaration of 'MemberRedecl::staticInlineDef' cannot add 'dllimport' attribute}}
# else
__declspec ( dllimport ) inline void MemberRedecl : : normalInlineDef ( ) { } // expected-warning{{'dllimport' attribute ignored on inline function}}
__declspec ( dllimport ) inline void MemberRedecl : : virtualInlineDef ( ) { } // expected-warning{{'dllimport' attribute ignored on inline function}}
__declspec ( dllimport ) inline void MemberRedecl : : staticInlineDef ( ) { } // expected-warning{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-30 00:50:20 +08:00
__declspec ( dllimport ) int MemberRedecl : : StaticField = 1 ; // expected-error{{redeclaration of 'MemberRedecl::StaticField' cannot add 'dllimport' attribute}}
// expected-error@-1{{definition of dllimport static field not allowed}}
// expected-note@-2{{attribute is here}}
__declspec ( dllimport ) const int MemberRedecl : : StaticConstField = 1 ; // expected-error{{redeclaration of 'MemberRedecl::StaticConstField' cannot add 'dllimport' attribute}}
// expected-error@-1{{definition of dllimport static field not allowed}}
// expected-note@-2{{attribute is here}}
__declspec ( dllimport ) constexpr int MemberRedecl : : ConstexprField ; // expected-error{{redeclaration of 'MemberRedecl::ConstexprField' cannot add 'dllimport' attribute}}
// expected-error@-1{{definition of dllimport static field not allowed}}
// expected-note@-2{{attribute is here}}
2014-05-25 18:35:03 +08:00
//===----------------------------------------------------------------------===//
// Class member templates
//===----------------------------------------------------------------------===//
struct ImportMemberTmpl {
template < typename T > __declspec ( dllimport ) void normalDecl ( ) ;
template < typename T > __declspec ( dllimport ) void normalDef ( ) ; // expected-note{{previous declaration is here}} expected-note{{previous attribute is here}}
2017-02-02 02:52:53 +08:00
# ifdef MS
// expected-note@+2{{previous declaration is here}} expected-note@+2{{previous attribute is here}}
# endif
2014-05-25 18:35:03 +08:00
template < typename T > __declspec ( dllimport ) void normalInlineDef ( ) ;
template < typename T > __declspec ( dllimport ) static void staticDecl ( ) ;
template < typename T > __declspec ( dllimport ) static void staticDef ( ) ; // expected-note{{previous declaration is here}} expected-note{{previous attribute is here}}
2017-02-02 02:52:53 +08:00
# ifdef MS
// expected-note@+2{{previous declaration is here}} expected-note@+2{{previous attribute is here}}
# endif
2014-05-25 18:35:03 +08:00
template < typename T > __declspec ( dllimport ) static void staticInlineDef ( ) ;
2014-11-03 22:24:45 +08:00
# ifdef GNU
2017-02-02 02:52:53 +08:00
template < typename T > __declspec ( dllimport ) void normalInclass ( ) { } // expected-warning{{'dllimport' attribute ignored on inline function}}
template < typename T > __declspec ( dllimport ) inline void normalInlineDecl ( ) ; // expected-warning{{'dllimport' attribute ignored on inline function}}
template < typename T > __declspec ( dllimport ) static void staticInclass ( ) { } // expected-warning{{'dllimport' attribute ignored on inline function}}
template < typename T > __declspec ( dllimport ) static inline void staticInlineDecl ( ) ; // expected-warning{{'dllimport' attribute ignored on inline function}}
# else
2014-11-03 22:24:45 +08:00
template < typename T > __declspec ( dllimport ) void normalInclass ( ) { }
2017-02-02 02:52:53 +08:00
template < typename T > __declspec ( dllimport ) inline void normalInlineDecl ( ) ; // expected-note{{previous declaration is here}} expected-note{{previous attribute is here}}
2014-11-03 22:24:45 +08:00
template < typename T > __declspec ( dllimport ) static void staticInclass ( ) { }
2017-02-02 02:52:53 +08:00
template < typename T > __declspec ( dllimport ) static inline void staticInlineDecl ( ) ; // expected-note{{previous declaration is here}} expected-note{{previous attribute is here}}
# endif
2014-05-30 00:50:20 +08:00
# if __has_feature(cxx_variable_templates)
template < typename T > __declspec ( dllimport ) static int StaticField ;
template < typename T > __declspec ( dllimport ) static int StaticFieldDef ; // expected-note{{attribute is here}}
template < typename T > __declspec ( dllimport ) static const int StaticConstField ;
template < typename T > __declspec ( dllimport ) static const int StaticConstFieldDef ; // expected-note{{attribute is here}}
template < typename T > __declspec ( dllimport ) static const int StaticConstFieldEqualInit = 1 ;
template < typename T > __declspec ( dllimport ) static const int StaticConstFieldBraceInit { 1 } ;
template < typename T > __declspec ( dllimport ) constexpr static int ConstexprField = 1 ;
template < typename T > __declspec ( dllimport ) constexpr static int ConstexprFieldDef = 1 ; // expected-note{{attribute is here}}
# endif // __has_feature(cxx_variable_templates)
2014-05-25 18:35:03 +08:00
} ;
template < typename T > void ImportMemberTmpl : : normalDef ( ) { } // expected-warning{{'ImportMemberTmpl::normalDef' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
template < typename T > void ImportMemberTmpl : : staticDef ( ) { } // expected-warning{{'ImportMemberTmpl::staticDef' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
2017-02-02 02:52:53 +08:00
# ifdef GNU // dllimport was ignored above
template < typename T > void ImportMemberTmpl : : normalInlineDecl ( ) { }
2014-05-25 18:35:03 +08:00
template < typename T > void ImportMemberTmpl : : staticInlineDecl ( ) { }
2017-02-02 02:52:53 +08:00
# else // dllimport dropped here
template < typename T > void ImportMemberTmpl : : normalInlineDecl ( ) { } // expected-warning{{'ImportMemberTmpl::normalInlineDecl' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
template < typename T > void ImportMemberTmpl : : staticInlineDecl ( ) { } // expected-warning{{'ImportMemberTmpl::staticInlineDecl' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
# endif
2014-05-25 18:35:03 +08:00
2014-11-03 22:24:45 +08:00
# ifdef GNU
2017-02-02 02:52:53 +08:00
template < typename T > inline void ImportMemberTmpl : : normalInlineDef ( ) { } // expected-warning{{ImportMemberTmpl::normalInlineDef' redeclared inline; 'dllimport' attribute ignored}}
template < typename T > inline void ImportMemberTmpl : : staticInlineDef ( ) { } // expected-warning{{ImportMemberTmpl::staticInlineDef' redeclared inline; 'dllimport' attribute ignored}}
# else
template < typename T > inline void ImportMemberTmpl : : normalInlineDef ( ) { } // expected-warning{{ImportMemberTmpl::normalInlineDef' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
template < typename T > inline void ImportMemberTmpl : : staticInlineDef ( ) { } // expected-warning{{ImportMemberTmpl::staticInlineDef' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
2014-11-03 22:24:45 +08:00
# endif
2014-05-30 00:50:20 +08:00
# if __has_feature(cxx_variable_templates)
template < typename T > int ImportMemberTmpl : : StaticFieldDef ; // expected-error{{definition of dllimport static field not allowed}}
template < typename T > const int ImportMemberTmpl : : StaticConstFieldDef = 1 ; // expected-error{{definition of dllimport static field not allowed}}
template < typename T > constexpr int ImportMemberTmpl : : ConstexprFieldDef ; // expected-error{{definition of dllimport static field not allowed}}
# endif // __has_feature(cxx_variable_templates)
2014-05-25 18:35:03 +08:00
// Redeclarations cannot add dllimport.
struct MemTmplRedecl {
template < typename T > void normalDef ( ) ; // expected-note{{previous declaration is here}}
template < typename T > inline void normalInlineDecl ( ) ; // expected-note{{previous declaration is here}}
template < typename T > static void staticDef ( ) ; // expected-note{{previous declaration is here}}
template < typename T > static inline void staticInlineDecl ( ) ; // expected-note{{previous declaration is here}}
2014-05-30 00:50:20 +08:00
2014-11-03 22:24:45 +08:00
# ifdef MS
// expected-note@+3{{previous declaration is here}}
// expected-note@+3{{previous declaration is here}}
# endif
template < typename T > void normalInlineDef ( ) ;
template < typename T > static void staticInlineDef ( ) ;
2014-05-30 00:50:20 +08:00
# if __has_feature(cxx_variable_templates)
template < typename T > static int StaticField ; // expected-note{{previous declaration is here}}
template < typename T > static const int StaticConstField ; // expected-note{{previous declaration is here}}
template < typename T > constexpr static int ConstexprField = 1 ; // expected-note{{previous declaration is here}}
# endif // __has_feature(cxx_variable_templates)
2014-05-25 18:35:03 +08:00
} ;
template < typename T > __declspec ( dllimport ) void MemTmplRedecl : : normalDef ( ) { } // expected-error{{redeclaration of 'MemTmplRedecl::normalDef' cannot add 'dllimport' attribute}}
// expected-error@-1{{dllimport cannot be applied to non-inline function definition}}
2014-11-03 22:24:45 +08:00
# ifdef MS
2014-05-25 18:35:03 +08:00
template < typename T > __declspec ( dllimport ) inline void MemTmplRedecl : : normalInlineDef ( ) { } // expected-error{{redeclaration of 'MemTmplRedecl::normalInlineDef' cannot add 'dllimport' attribute}}
2014-11-03 22:24:45 +08:00
# else
template < typename T > __declspec ( dllimport ) inline void MemTmplRedecl : : normalInlineDef ( ) { } // expected-warning{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-25 18:35:03 +08:00
template < typename T > __declspec ( dllimport ) void MemTmplRedecl : : normalInlineDecl ( ) { } // expected-error{{redeclaration of 'MemTmplRedecl::normalInlineDecl' cannot add 'dllimport' attribute}}
template < typename T > __declspec ( dllimport ) void MemTmplRedecl : : staticDef ( ) { } // expected-error{{redeclaration of 'MemTmplRedecl::staticDef' cannot add 'dllimport' attribute}}
// expected-error@-1{{dllimport cannot be applied to non-inline function definition}}
2014-11-03 22:24:45 +08:00
# ifdef MS
2014-05-25 18:35:03 +08:00
template < typename T > __declspec ( dllimport ) inline void MemTmplRedecl : : staticInlineDef ( ) { } // expected-error{{redeclaration of 'MemTmplRedecl::staticInlineDef' cannot add 'dllimport' attribute}}
2014-11-03 22:24:45 +08:00
# else
template < typename T > __declspec ( dllimport ) inline void MemTmplRedecl : : staticInlineDef ( ) { } // expected-warning{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-25 18:35:03 +08:00
template < typename T > __declspec ( dllimport ) void MemTmplRedecl : : staticInlineDecl ( ) { } // expected-error{{redeclaration of 'MemTmplRedecl::staticInlineDecl' cannot add 'dllimport' attribute}}
2014-05-30 00:50:20 +08:00
# if __has_feature(cxx_variable_templates)
template < typename T > __declspec ( dllimport ) int MemTmplRedecl : : StaticField = 1 ; // expected-error{{redeclaration of 'MemTmplRedecl::StaticField' cannot add 'dllimport' attribute}}
// expected-error@-1{{definition of dllimport static field not allowed}}
// expected-note@-2{{attribute is here}}
template < typename T > __declspec ( dllimport ) const int MemTmplRedecl : : StaticConstField = 1 ; // expected-error{{redeclaration of 'MemTmplRedecl::StaticConstField' cannot add 'dllimport' attribute}}
// expected-error@-1{{definition of dllimport static field not allowed}}
// expected-note@-2{{attribute is here}}
template < typename T > __declspec ( dllimport ) constexpr int MemTmplRedecl : : ConstexprField ; // expected-error{{redeclaration of 'MemTmplRedecl::ConstexprField' cannot add 'dllimport' attribute}}
// expected-error@-1{{definition of dllimport static field not allowed}}
// expected-note@-2{{attribute is here}}
# endif // __has_feature(cxx_variable_templates)
2014-05-25 18:35:03 +08:00
struct MemFunTmpl {
template < typename T > void normalDef ( ) { }
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+2{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-25 18:35:03 +08:00
template < typename T > __declspec ( dllimport ) void importedNormal ( ) { }
template < typename T > static void staticDef ( ) { }
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+2{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-25 18:35:03 +08:00
template < typename T > __declspec ( dllimport ) static void importedStatic ( ) { }
} ;
// Import implicit instantiation of an imported member function template.
void useMemFunTmpl ( ) {
MemFunTmpl ( ) . importedNormal < ImplicitInst_Imported > ( ) ;
MemFunTmpl ( ) . importedStatic < ImplicitInst_Imported > ( ) ;
}
// Import explicit instantiation declaration of an imported member function
// template.
extern template void MemFunTmpl : : importedNormal < ExplicitDecl_Imported > ( ) ;
extern template void MemFunTmpl : : importedStatic < ExplicitDecl_Imported > ( ) ;
// Import explicit instantiation definition of an imported member function
// template.
// NB: MSVC fails this instantiation without explicit dllimport.
template void MemFunTmpl : : importedNormal < ExplicitInst_Imported > ( ) ;
template void MemFunTmpl : : importedStatic < ExplicitInst_Imported > ( ) ;
// Import specialization of an imported member function template.
template < > __declspec ( dllimport ) void MemFunTmpl : : importedNormal < ExplicitSpec_Imported > ( ) ;
template < > __declspec ( dllimport ) void MemFunTmpl : : importedNormal < ExplicitSpec_Def_Imported > ( ) { } // error on mingw
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+2{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-25 18:35:03 +08:00
template < > __declspec ( dllimport ) inline void MemFunTmpl : : importedNormal < ExplicitSpec_InlineDef_Imported > ( ) { }
2014-10-29 06:15:55 +08:00
# if 1
// FIXME: This should not be an error when targeting MSVC. (PR21406)
2014-11-03 22:24:45 +08:00
// expected-error@-7{{dllimport cannot be applied to non-inline function definition}}
2014-05-25 18:35:03 +08:00
# endif
template < > __declspec ( dllimport ) void MemFunTmpl : : importedStatic < ExplicitSpec_Imported > ( ) ;
template < > __declspec ( dllimport ) void MemFunTmpl : : importedStatic < ExplicitSpec_Def_Imported > ( ) { } // error on mingw
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+2{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-25 18:35:03 +08:00
template < > __declspec ( dllimport ) inline void MemFunTmpl : : importedStatic < ExplicitSpec_InlineDef_Imported > ( ) { }
2014-10-29 06:15:55 +08:00
# if 1
// FIXME: This should not be an error when targeting MSVC. (PR21406)
2014-11-03 22:24:45 +08:00
// expected-error@-7{{dllimport cannot be applied to non-inline function definition}}
2014-05-25 18:35:03 +08:00
# endif
// Not importing specialization of an imported member function template without
// explicit dllimport.
template < > void MemFunTmpl : : importedNormal < ExplicitSpec_NotImported > ( ) { }
template < > void MemFunTmpl : : importedStatic < ExplicitSpec_NotImported > ( ) { }
// Import explicit instantiation declaration of a non-imported member function
// template.
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+3{{'dllimport' attribute ignored on inline function}}
// expected-warning@+3{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-25 18:35:03 +08:00
extern template __declspec ( dllimport ) void MemFunTmpl : : normalDef < ExplicitDecl_Imported > ( ) ;
extern template __declspec ( dllimport ) void MemFunTmpl : : staticDef < ExplicitDecl_Imported > ( ) ;
// Import explicit instantiation definition of a non-imported member function
// template.
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+3{{'dllimport' attribute ignored on inline function}}
// expected-warning@+3{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-25 18:35:03 +08:00
template __declspec ( dllimport ) void MemFunTmpl : : normalDef < ExplicitInst_Imported > ( ) ;
template __declspec ( dllimport ) void MemFunTmpl : : staticDef < ExplicitInst_Imported > ( ) ;
// Import specialization of a non-imported member function template.
template < > __declspec ( dllimport ) void MemFunTmpl : : normalDef < ExplicitSpec_Imported > ( ) ;
template < > __declspec ( dllimport ) void MemFunTmpl : : normalDef < ExplicitSpec_Def_Imported > ( ) { } // error on mingw
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+2{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-25 18:35:03 +08:00
template < > __declspec ( dllimport ) inline void MemFunTmpl : : normalDef < ExplicitSpec_InlineDef_Imported > ( ) { }
2014-10-29 06:15:55 +08:00
# if 1
// FIXME: This should not be an error when targeting MSVC. (PR21406)
2014-11-03 22:24:45 +08:00
// expected-error@-7{{dllimport cannot be applied to non-inline function definition}}
2014-05-25 18:35:03 +08:00
# endif
template < > __declspec ( dllimport ) void MemFunTmpl : : staticDef < ExplicitSpec_Imported > ( ) ;
template < > __declspec ( dllimport ) void MemFunTmpl : : staticDef < ExplicitSpec_Def_Imported > ( ) { } // error on mingw
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+2{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-25 18:35:03 +08:00
template < > __declspec ( dllimport ) inline void MemFunTmpl : : staticDef < ExplicitSpec_InlineDef_Imported > ( ) { }
2014-10-29 06:15:55 +08:00
# if 1
// FIXME: This should not be an error when targeting MSVC. (PR21406)
2014-11-03 22:24:45 +08:00
// expected-error@-7{{dllimport cannot be applied to non-inline function definition}}
2014-05-25 18:35:03 +08:00
# endif
2014-05-30 00:50:20 +08:00
# if __has_feature(cxx_variable_templates)
struct MemVarTmpl {
template < typename T > static const int StaticVar = 1 ;
template < typename T > __declspec ( dllimport ) static const int ImportedStaticVar = 1 ;
} ;
// Import implicit instantiation of an imported member variable template.
int useMemVarTmpl ( ) { return MemVarTmpl : : ImportedStaticVar < ImplicitInst_Imported > ; }
// Import explicit instantiation declaration of an imported member variable
// template.
extern template const int MemVarTmpl : : ImportedStaticVar < ExplicitDecl_Imported > ;
// An explicit instantiation definition of an imported member variable template
// cannot be imported because the template must be defined which is illegal. The
// in-class initializer does not count.
// Import specialization of an imported member variable template.
template < > __declspec ( dllimport ) const int MemVarTmpl : : ImportedStaticVar < ExplicitSpec_Imported > ;
template < > __declspec ( dllimport ) const int MemVarTmpl : : ImportedStaticVar < ExplicitSpec_Def_Imported > = 1 ;
// expected-error@-1{{definition of dllimport static field not allowed}}
// expected-note@-2{{attribute is here}}
// Not importing specialization of a member variable template without explicit
// dllimport.
template < > const int MemVarTmpl : : ImportedStaticVar < ExplicitSpec_NotImported > ;
// Import explicit instantiation declaration of a non-imported member variable
// template.
extern template __declspec ( dllimport ) const int MemVarTmpl : : StaticVar < ExplicitDecl_Imported > ;
// An explicit instantiation definition of a non-imported member variable template
// cannot be imported because the template must be defined which is illegal. The
// in-class initializer does not count.
// Import specialization of a non-imported member variable template.
template < > __declspec ( dllimport ) const int MemVarTmpl : : StaticVar < ExplicitSpec_Imported > ;
template < > __declspec ( dllimport ) const int MemVarTmpl : : StaticVar < ExplicitSpec_Def_Imported > = 1 ;
// expected-error@-1{{definition of dllimport static field not allowed}}
// expected-note@-2{{attribute is here}}
# endif // __has_feature(cxx_variable_templates)
2014-05-25 18:35:03 +08:00
//===----------------------------------------------------------------------===//
// Class template members
//===----------------------------------------------------------------------===//
// Import individual members of a class template.
template < typename T >
struct ImportClassTmplMembers {
__declspec ( dllimport ) void normalDecl ( ) ;
2016-05-25 19:32:42 +08:00
# ifdef GNU
// expected-note@+2{{previous attribute is here}}
# endif
__declspec ( dllimport ) void normalDef ( ) ; // expected-note{{previous declaration is here}}
2014-05-25 18:35:03 +08:00
__declspec ( dllimport ) void normalInlineDef ( ) ;
__declspec ( dllimport ) virtual void virtualDecl ( ) ;
2016-05-25 19:32:42 +08:00
# ifdef GNU
// expected-note@+2{{previous attribute is here}}
# endif
__declspec ( dllimport ) virtual void virtualDef ( ) ; // expected-note{{previous declaration is here}}
2014-05-25 18:35:03 +08:00
__declspec ( dllimport ) virtual void virtualInlineDef ( ) ;
__declspec ( dllimport ) static void staticDecl ( ) ;
2016-05-25 19:32:42 +08:00
# ifdef GNU
// expected-note@+2{{previous attribute is here}}
# endif
__declspec ( dllimport ) static void staticDef ( ) ; // expected-note{{previous declaration is here}}
2014-05-25 18:35:03 +08:00
__declspec ( dllimport ) static void staticInlineDef ( ) ;
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+7{{'dllimport' attribute ignored on inline function}}
// expected-warning@+7{{'dllimport' attribute ignored on inline function}}
// expected-warning@+7{{'dllimport' attribute ignored on inline function}}
// expected-warning@+7{{'dllimport' attribute ignored on inline function}}
// expected-warning@+7{{'dllimport' attribute ignored on inline function}}
// expected-warning@+7{{'dllimport' attribute ignored on inline function}}
# endif
__declspec ( dllimport ) void normalInclass ( ) { }
__declspec ( dllimport ) inline void normalInlineDecl ( ) ;
__declspec ( dllimport ) virtual void virtualInclass ( ) { }
__declspec ( dllimport ) virtual inline void virtualInlineDecl ( ) ;
__declspec ( dllimport ) static void staticInclass ( ) { }
2014-05-25 18:35:03 +08:00
__declspec ( dllimport ) static inline void staticInlineDecl ( ) ;
protected :
__declspec ( dllimport ) void protectedDecl ( ) ;
private :
__declspec ( dllimport ) void privateDecl ( ) ;
2014-05-30 00:50:20 +08:00
public :
2017-11-27 04:01:12 +08:00
__declspec ( dllimport ) int Field ; // expected-warning{{'dllimport' attribute only applies to}}
2014-05-30 00:50:20 +08:00
__declspec ( dllimport ) static int StaticField ;
__declspec ( dllimport ) static int StaticFieldDef ; // expected-note{{attribute is here}}
__declspec ( dllimport ) static const int StaticConstField ;
__declspec ( dllimport ) static const int StaticConstFieldDef ; // expected-note{{attribute is here}}
__declspec ( dllimport ) static const int StaticConstFieldEqualInit = 1 ;
__declspec ( dllimport ) static const int StaticConstFieldBraceInit { 1 } ;
__declspec ( dllimport ) constexpr static int ConstexprField = 1 ;
__declspec ( dllimport ) constexpr static int ConstexprFieldDef = 1 ; // expected-note{{attribute is here}}
2014-05-25 18:35:03 +08:00
} ;
// NB: MSVC is inconsistent here and disallows *InlineDef on class templates,
// but allows it on classes. We allow both.
2016-05-25 19:32:42 +08:00
# ifdef MS
// expected-warning@+5{{'ImportClassTmplMembers::normalDef' redeclared without 'dllimport' attribute: 'dllexport' attribute added}}
# else
// expected-warning@+3{{'ImportClassTmplMembers::normalDef' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
# endif
template < typename T >
void ImportClassTmplMembers < T > : : normalDef ( ) { }
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+2{{'ImportClassTmplMembers::normalInlineDef' redeclared inline; 'dllimport' attribute ignored}}
# endif
2014-05-25 18:35:03 +08:00
template < typename T > inline void ImportClassTmplMembers < T > : : normalInlineDef ( ) { }
template < typename T > void ImportClassTmplMembers < T > : : normalInlineDecl ( ) { }
2016-05-25 19:32:42 +08:00
# ifdef MS
// expected-warning@+5{{'ImportClassTmplMembers::virtualDef' redeclared without 'dllimport' attribute: 'dllexport' attribute added}}
# else
// expected-warning@+3{{'ImportClassTmplMembers::virtualDef' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
# endif
template < typename T >
void ImportClassTmplMembers < T > : : virtualDef ( ) { }
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+2{{'ImportClassTmplMembers::virtualInlineDef' redeclared inline; 'dllimport' attribute ignored}}
# endif
2014-05-25 18:35:03 +08:00
template < typename T > inline void ImportClassTmplMembers < T > : : virtualInlineDef ( ) { }
template < typename T > void ImportClassTmplMembers < T > : : virtualInlineDecl ( ) { }
2016-05-25 19:32:42 +08:00
# ifdef MS
// expected-warning@+5{{'ImportClassTmplMembers::staticDef' redeclared without 'dllimport' attribute: 'dllexport' attribute added}}
# else
// expected-warning@+3{{'ImportClassTmplMembers::staticDef' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
# endif
template < typename T >
void ImportClassTmplMembers < T > : : staticDef ( ) { }
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+2{{'ImportClassTmplMembers::staticInlineDef' redeclared inline; 'dllimport' attribute ignored}}
# endif
2014-05-25 18:35:03 +08:00
template < typename T > inline void ImportClassTmplMembers < T > : : staticInlineDef ( ) { }
template < typename T > void ImportClassTmplMembers < T > : : staticInlineDecl ( ) { }
2014-06-04 08:18:41 +08:00
template < typename T > int ImportClassTmplMembers < T > : : StaticFieldDef ; // expected-warning{{definition of dllimport static field}}
template < typename T > const int ImportClassTmplMembers < T > : : StaticConstFieldDef = 1 ; // expected-warning{{definition of dllimport static field}}
template < typename T > constexpr int ImportClassTmplMembers < T > : : ConstexprFieldDef ; // expected-warning{{definition of dllimport static field}}
2014-05-30 00:50:20 +08:00
2014-05-25 18:35:03 +08:00
// Redeclarations cannot add dllimport.
template < typename T >
struct CTMR /*ClassTmplMemberRedecl*/ {
void normalDef ( ) ; // expected-note{{previous declaration is here}}
inline void normalInlineDecl ( ) ; // expected-note{{previous declaration is here}}
virtual void virtualDef ( ) ; // expected-note{{previous declaration is here}}
virtual inline void virtualInlineDecl ( ) ; // expected-note{{previous declaration is here}}
static void staticDef ( ) ; // expected-note{{previous declaration is here}}
static inline void staticInlineDecl ( ) ; // expected-note{{previous declaration is here}}
2014-05-30 00:50:20 +08:00
2014-11-03 22:24:45 +08:00
# ifdef MS
// expected-note@+4{{previous declaration is here}}
// expected-note@+4{{previous declaration is here}}
// expected-note@+4{{previous declaration is here}}
# endif
void normalInlineDef ( ) ;
virtual void virtualInlineDef ( ) ;
static void staticInlineDef ( ) ;
2014-05-30 00:50:20 +08:00
static int StaticField ; // expected-note{{previous declaration is here}}
static const int StaticConstField ; // expected-note{{previous declaration is here}}
constexpr static int ConstexprField = 1 ; // expected-note{{previous declaration is here}}
2014-05-25 18:35:03 +08:00
} ;
template < typename T > __declspec ( dllimport ) void CTMR < T > : : normalDef ( ) { } // expected-error{{redeclaration of 'CTMR::normalDef' cannot add 'dllimport' attribute}}
// expected-error@-1{{dllimport cannot be applied to non-inline function definition}}
template < typename T > __declspec ( dllimport ) void CTMR < T > : : normalInlineDecl ( ) { } // expected-error{{redeclaration of 'CTMR::normalInlineDecl' cannot add 'dllimport' attribute}}
template < typename T > __declspec ( dllimport ) void CTMR < T > : : virtualDef ( ) { } // expected-error{{redeclaration of 'CTMR::virtualDef' cannot add 'dllimport' attribute}}
// expected-error@-1{{dllimport cannot be applied to non-inline function definition}}
template < typename T > __declspec ( dllimport ) void CTMR < T > : : virtualInlineDecl ( ) { } // expected-error{{redeclaration of 'CTMR::virtualInlineDecl' cannot add 'dllimport' attribute}}
template < typename T > __declspec ( dllimport ) void CTMR < T > : : staticDef ( ) { } // expected-error{{redeclaration of 'CTMR::staticDef' cannot add 'dllimport' attribute}}
// expected-error@-1{{dllimport cannot be applied to non-inline function definition}}
template < typename T > __declspec ( dllimport ) void CTMR < T > : : staticInlineDecl ( ) { } // expected-error{{redeclaration of 'CTMR::staticInlineDecl' cannot add 'dllimport' attribute}}
2014-11-03 22:24:45 +08:00
# ifdef MS
template < typename T > __declspec ( dllimport ) inline void CTMR < T > : : normalInlineDef ( ) { } // expected-error{{redeclaration of 'CTMR::normalInlineDef' cannot add 'dllimport' attribute}}
template < typename T > __declspec ( dllimport ) inline void CTMR < T > : : virtualInlineDef ( ) { } // expected-error{{redeclaration of 'CTMR::virtualInlineDef' cannot add 'dllimport' attribute}}
template < typename T > __declspec ( dllimport ) inline void CTMR < T > : : staticInlineDef ( ) { } // expected-error{{redeclaration of 'CTMR::staticInlineDef' cannot add 'dllimport' attribute}}
# else
template < typename T > __declspec ( dllimport ) inline void CTMR < T > : : normalInlineDef ( ) { } // expected-warning{{'dllimport' attribute ignored on inline function}}
template < typename T > __declspec ( dllimport ) inline void CTMR < T > : : virtualInlineDef ( ) { } // expected-warning{{'dllimport' attribute ignored on inline function}}
template < typename T > __declspec ( dllimport ) inline void CTMR < T > : : staticInlineDef ( ) { } // expected-warning{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-30 00:50:20 +08:00
template < typename T > __declspec ( dllimport ) int CTMR < T > : : StaticField = 1 ; // expected-error{{redeclaration of 'CTMR::StaticField' cannot add 'dllimport' attribute}}
2014-06-04 08:18:41 +08:00
// expected-warning@-1{{definition of dllimport static field}}
2014-05-30 00:50:20 +08:00
// expected-note@-2{{attribute is here}}
template < typename T > __declspec ( dllimport ) const int CTMR < T > : : StaticConstField = 1 ; // expected-error{{redeclaration of 'CTMR::StaticConstField' cannot add 'dllimport' attribute}}
2014-06-04 08:18:41 +08:00
// expected-warning@-1{{definition of dllimport static field}}
2014-05-30 00:50:20 +08:00
// expected-note@-2{{attribute is here}}
template < typename T > __declspec ( dllimport ) constexpr int CTMR < T > : : ConstexprField ; // expected-error{{redeclaration of 'CTMR::ConstexprField' cannot add 'dllimport' attribute}}
2014-06-04 08:18:41 +08:00
// expected-warning@-1{{definition of dllimport static field}}
2014-05-30 00:50:20 +08:00
// expected-note@-2{{attribute is here}}
2014-05-25 18:35:03 +08:00
//===----------------------------------------------------------------------===//
// Class template member templates
//===----------------------------------------------------------------------===//
template < typename T >
struct ImportClsTmplMemTmpl {
template < typename U > __declspec ( dllimport ) void normalDecl ( ) ;
template < typename U > __declspec ( dllimport ) void normalDef ( ) ; // expected-note{{previous declaration is here}} expected-note{{previous attribute is here}}
2017-02-02 02:52:53 +08:00
# ifdef MS
// expected-note@+2{{previous declaration is here}} expected-note@+2{{previous attribute is here}}
# endif
2014-05-25 18:35:03 +08:00
template < typename U > __declspec ( dllimport ) void normalInlineDef ( ) ;
template < typename U > __declspec ( dllimport ) static void staticDecl ( ) ;
template < typename U > __declspec ( dllimport ) static void staticDef ( ) ; // expected-note{{previous declaration is here}} expected-note{{previous attribute is here}}
2017-02-02 02:52:53 +08:00
# ifdef MS
// expected-note@+2{{previous declaration is here}} expected-note@+2{{previous attribute is here}}
# endif
2014-05-25 18:35:03 +08:00
template < typename U > __declspec ( dllimport ) static void staticInlineDef ( ) ;
2014-11-03 22:24:45 +08:00
# ifdef GNU
// expected-warning@+5{{'dllimport' attribute ignored on inline function}}
2017-02-02 02:52:53 +08:00
// expected-warning@+8{{'dllimport' attribute ignored on inline function}}
// expected-warning@+8{{'dllimport' attribute ignored on inline function}}
// expected-warning@+11{{'dllimport' attribute ignored on inline function}}
2014-11-03 22:24:45 +08:00
# endif
template < typename U > __declspec ( dllimport ) void normalInclass ( ) { }
2017-02-02 02:52:53 +08:00
# ifdef MS
// expected-note@+2{{previous declaration is here}} expected-note@+2{{previous attribute is here}}
# endif
2014-11-03 22:24:45 +08:00
template < typename U > __declspec ( dllimport ) inline void normalInlineDecl ( ) ;
template < typename U > __declspec ( dllimport ) static void staticInclass ( ) { }
2017-02-02 02:52:53 +08:00
# ifdef MS
// expected-note@+2{{previous declaration is here}} expected-note@+2{{previous attribute is here}}
# endif
2014-05-25 18:35:03 +08:00
template < typename U > __declspec ( dllimport ) static inline void staticInlineDecl ( ) ;
2014-05-30 00:50:20 +08:00
# if __has_feature(cxx_variable_templates)
template < typename U > __declspec ( dllimport ) static int StaticField ;
template < typename U > __declspec ( dllimport ) static int StaticFieldDef ; // expected-note{{attribute is here}}
template < typename U > __declspec ( dllimport ) static const int StaticConstField ;
template < typename U > __declspec ( dllimport ) static const int StaticConstFieldDef ; // expected-note{{attribute is here}}
template < typename U > __declspec ( dllimport ) static const int StaticConstFieldEqualInit = 1 ;
template < typename U > __declspec ( dllimport ) static const int StaticConstFieldBraceInit { 1 } ;
template < typename U > __declspec ( dllimport ) constexpr static int ConstexprField = 1 ;
template < typename U > __declspec ( dllimport ) constexpr static int ConstexprFieldDef = 1 ; // expected-note{{attribute is here}}
# endif // __has_feature(cxx_variable_templates)
2014-05-25 18:35:03 +08:00
} ;
template < typename T > template < typename U > void ImportClsTmplMemTmpl < T > : : normalDef ( ) { } // expected-warning{{'ImportClsTmplMemTmpl::normalDef' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
template < typename T > template < typename U > void ImportClsTmplMemTmpl < T > : : staticDef ( ) { } // expected-warning{{'ImportClsTmplMemTmpl::staticDef' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
2017-02-02 02:52:53 +08:00
# ifdef GNU
template < typename T > template < typename U > void ImportClsTmplMemTmpl < T > : : normalInlineDecl ( ) { }
2014-05-25 18:35:03 +08:00
template < typename T > template < typename U > void ImportClsTmplMemTmpl < T > : : staticInlineDecl ( ) { }
2017-02-02 02:52:53 +08:00
# else
template < typename T > template < typename U > void ImportClsTmplMemTmpl < T > : : normalInlineDecl ( ) { } // expected-warning{{'ImportClsTmplMemTmpl::normalInlineDecl' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
template < typename T > template < typename U > void ImportClsTmplMemTmpl < T > : : staticInlineDecl ( ) { } // expected-warning{{'ImportClsTmplMemTmpl::staticInlineDecl' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
# endif
2014-05-25 18:35:03 +08:00
2014-11-03 22:24:45 +08:00
# ifdef GNU
2017-02-02 02:52:53 +08:00
template < typename T > template < typename U > inline void ImportClsTmplMemTmpl < T > : : normalInlineDef ( ) { } // expected-warning{{'ImportClsTmplMemTmpl::normalInlineDef' redeclared inline; 'dllimport' attribute ignored}}
template < typename T > template < typename U > inline void ImportClsTmplMemTmpl < T > : : staticInlineDef ( ) { } // expected-warning{{'ImportClsTmplMemTmpl::staticInlineDef' redeclared inline; 'dllimport' attribute ignored}}
# else
template < typename T > template < typename U > inline void ImportClsTmplMemTmpl < T > : : normalInlineDef ( ) { } // expected-warning{{'ImportClsTmplMemTmpl::normalInlineDef' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
template < typename T > template < typename U > inline void ImportClsTmplMemTmpl < T > : : staticInlineDef ( ) { } // expected-warning{{'ImportClsTmplMemTmpl::staticInlineDef' redeclared without 'dllimport' attribute: previous 'dllimport' ignored}}
2014-11-03 22:24:45 +08:00
# endif
2014-05-30 00:50:20 +08:00
# if __has_feature(cxx_variable_templates)
2014-06-04 08:18:41 +08:00
template < typename T > template < typename U > int ImportClsTmplMemTmpl < T > : : StaticFieldDef ; // expected-warning{{definition of dllimport static field}}
template < typename T > template < typename U > const int ImportClsTmplMemTmpl < T > : : StaticConstFieldDef = 1 ; // expected-warning{{definition of dllimport static field}}
template < typename T > template < typename U > constexpr int ImportClsTmplMemTmpl < T > : : ConstexprFieldDef ; // expected-warning{{definition of dllimport static field}}
2014-05-30 00:50:20 +08:00
# endif // __has_feature(cxx_variable_templates)
2014-05-25 18:35:03 +08:00
// Redeclarations cannot add dllimport.
template < typename T >
struct CTMTR /*ClassTmplMemberTmplRedecl*/ {
template < typename U > void normalDef ( ) ; // expected-note{{previous declaration is here}}
template < typename U > inline void normalInlineDecl ( ) ; // expected-note{{previous declaration is here}}
template < typename U > static void staticDef ( ) ; // expected-note{{previous declaration is here}}
template < typename U > static inline void staticInlineDecl ( ) ; // expected-note{{previous declaration is here}}
2014-05-30 00:50:20 +08:00
2014-11-03 22:24:45 +08:00
# ifdef MS
// expected-note@+3{{previous declaration is here}}
// expected-note@+3{{previous declaration is here}}
# endif
template < typename U > void normalInlineDef ( ) ;
template < typename U > static void staticInlineDef ( ) ;
2014-05-30 00:50:20 +08:00
# if __has_feature(cxx_variable_templates)
template < typename U > static int StaticField ; // expected-note{{previous declaration is here}}
template < typename U > static const int StaticConstField ; // expected-note{{previous declaration is here}}
template < typename U > constexpr static int ConstexprField = 1 ; // expected-note{{previous declaration is here}}
# endif // __has_feature(cxx_variable_templates)
2014-05-25 18:35:03 +08:00
} ;
template < typename T > template < typename U > __declspec ( dllimport ) void CTMTR < T > : : normalDef ( ) { } // expected-error{{redeclaration of 'CTMTR::normalDef' cannot add 'dllimport' attribute}}
// expected-error@-1{{dllimport cannot be applied to non-inline function definition}}
template < typename T > template < typename U > __declspec ( dllimport ) void CTMTR < T > : : normalInlineDecl ( ) { } // expected-error{{redeclaration of 'CTMTR::normalInlineDecl' cannot add 'dllimport' attribute}}
template < typename T > template < typename U > __declspec ( dllimport ) void CTMTR < T > : : staticDef ( ) { } // expected-error{{redeclaration of 'CTMTR::staticDef' cannot add 'dllimport' attribute}}
// expected-error@-1{{dllimport cannot be applied to non-inline function definition}}
template < typename T > template < typename U > __declspec ( dllimport ) void CTMTR < T > : : staticInlineDecl ( ) { } // expected-error{{redeclaration of 'CTMTR::staticInlineDecl' cannot add 'dllimport' attribute}}
2014-05-30 00:50:20 +08:00
2014-11-03 22:24:45 +08:00
# ifdef MS
template < typename T > template < typename U > __declspec ( dllimport ) inline void CTMTR < T > : : normalInlineDef ( ) { } // expected-error{{redeclaration of 'CTMTR::normalInlineDef' cannot add 'dllimport' attribute}}
template < typename T > template < typename U > __declspec ( dllimport ) inline void CTMTR < T > : : staticInlineDef ( ) { } // expected-error{{redeclaration of 'CTMTR::staticInlineDef' cannot add 'dllimport' attribute}}
# else
template < typename T > template < typename U > __declspec ( dllimport ) inline void CTMTR < T > : : normalInlineDef ( ) { } // expected-warning{{'dllimport' attribute ignored on inline function}}
template < typename T > template < typename U > __declspec ( dllimport ) inline void CTMTR < T > : : staticInlineDef ( ) { } // expected-warning{{'dllimport' attribute ignored on inline function}}
# endif
2014-05-30 00:50:20 +08:00
# if __has_feature(cxx_variable_templates)
template < typename T > template < typename U > __declspec ( dllimport ) int CTMTR < T > : : StaticField = 1 ; // expected-error{{redeclaration of 'CTMTR::StaticField' cannot add 'dllimport' attribute}}
2014-06-04 08:18:41 +08:00
// expected-warning@-1{{definition of dllimport static field}}
2014-05-30 00:50:20 +08:00
// expected-note@-2{{attribute is here}}
template < typename T > template < typename U > __declspec ( dllimport ) const int CTMTR < T > : : StaticConstField = 1 ; // expected-error{{redeclaration of 'CTMTR::StaticConstField' cannot add 'dllimport' attribute}}
2014-06-04 08:18:41 +08:00
// expected-warning@-1{{definition of dllimport static field}}
2014-05-30 00:50:20 +08:00
// expected-note@-2{{attribute is here}}
template < typename T > template < typename U > __declspec ( dllimport ) constexpr int CTMTR < T > : : ConstexprField ; // expected-error{{redeclaration of 'CTMTR::ConstexprField' cannot add 'dllimport' attribute}}
2014-06-04 08:18:41 +08:00
// expected-warning@-1{{definition of dllimport static field}}
2014-05-30 00:50:20 +08:00
// expected-note@-2{{attribute is here}}
# endif // __has_feature(cxx_variable_templates)
2014-05-31 00:59:42 +08:00
//===----------------------------------------------------------------------===//
// Classes
//===----------------------------------------------------------------------===//
2014-11-04 00:09:16 +08:00
namespace {
struct __declspec ( dllimport ) AnonymousClass { } ; // expected-error{{(anonymous namespace)::AnonymousClass' must have external linkage when declared 'dllimport'}}
}
2014-05-31 00:59:42 +08:00
class __declspec ( dllimport ) ClassDecl ;
class __declspec ( dllimport ) ClassDef { } ;
2014-05-31 10:08:49 +08:00
2014-06-26 02:25:57 +08:00
template < typename T > class ClassTemplate { } ;
2014-05-31 10:08:49 +08:00
# ifdef MS
// expected-note@+5{{previous attribute is here}}
// expected-note@+4{{previous attribute is here}}
// expected-error@+4{{attribute 'dllexport' cannot be applied to member of 'dllimport' class}}
// expected-error@+4{{attribute 'dllimport' cannot be applied to member of 'dllimport' class}}
# endif
class __declspec ( dllimport ) ImportClassWithDllMember {
void __declspec ( dllexport ) foo ( ) ;
void __declspec ( dllimport ) bar ( ) ;
} ;
# ifdef MS
// expected-note@+5{{previous attribute is here}}
// expected-note@+4{{previous attribute is here}}
// expected-error@+4{{attribute 'dllimport' cannot be applied to member of 'dllexport' class}}
// expected-error@+4{{attribute 'dllexport' cannot be applied to member of 'dllexport' class}}
# endif
2014-08-24 08:12:36 +08:00
template < typename T > class __declspec ( dllexport ) ExportClassWithDllMember {
2014-05-31 10:08:49 +08:00
void __declspec ( dllimport ) foo ( ) ;
void __declspec ( dllexport ) bar ( ) ;
} ;
2014-06-04 08:18:41 +08:00
namespace ImportedExplicitSpecialization {
template < typename T > struct S { static int x ; } ;
template < typename T > int S < T > : : x = sizeof ( T ) ;
template < > struct __declspec ( dllimport ) S < int > { static int x ; } ; // expected-note{{attribute is here}}
int S < int > : : x = - 1 ; // expected-error{{definition of dllimport static field not allowed}}
}
2014-06-11 01:53:23 +08:00
namespace PR19988 {
// Don't error about applying delete to dllimport member function when instantiating.
template < typename > struct __declspec ( dllimport ) S {
void foo ( ) = delete ;
} ;
S < int > s ;
}
2014-06-25 07:57:13 +08:00
# ifdef MS
// expected-warning@+3{{'dllimport' attribute ignored}}
# endif
template < typename T > struct PartiallySpecializedClassTemplate { } ;
template < typename T > struct __declspec ( dllimport ) PartiallySpecializedClassTemplate < T * > { void f ( ) { } } ;
template < typename T > struct ExpliciallySpecializedClassTemplate { } ;
template < > struct __declspec ( dllimport ) ExpliciallySpecializedClassTemplate < int > { void f ( ) { } } ;
2014-06-26 02:25:57 +08:00
//===----------------------------------------------------------------------===//
// Classes with template base classes
//===----------------------------------------------------------------------===//
template < typename T > class __declspec ( dllexport ) ExportedClassTemplate { } ;
template < typename T > class __declspec ( dllimport ) ImportedClassTemplate { } ;
// ClassTemplate<int> gets imported.
class __declspec ( dllimport ) DerivedFromTemplate : public ClassTemplate < int > { } ;
// ClassTemplate<int> is already imported.
class __declspec ( dllimport ) DerivedFromTemplate2 : public ClassTemplate < int > { } ;
// ImportedClassTemplate is expliitly imported.
class __declspec ( dllimport ) DerivedFromImportedTemplate : public ImportedClassTemplate < int > { } ;
// ExportedClassTemplate is explicitly exported.
class __declspec ( dllimport ) DerivedFromExportedTemplate : public ExportedClassTemplate < int > { } ;
class DerivedFromTemplateD : public ClassTemplate < double > { } ;
2015-06-09 08:39:03 +08:00
// Base class previously implicitly instantiated without attribute; it will get propagated.
2014-06-26 02:25:57 +08:00
class __declspec ( dllimport ) DerivedFromTemplateD2 : public ClassTemplate < double > { } ;
2015-06-09 08:39:03 +08:00
// Base class has explicit instantiation declaration; the attribute will get propagated.
extern template class ClassTemplate < float > ;
class __declspec ( dllimport ) DerivedFromTemplateF : public ClassTemplate < float > { } ;
2015-06-09 08:38:56 +08:00
class __declspec ( dllimport ) DerivedFromTemplateB : public ClassTemplate < bool > { } ;
// The second derived class doesn't change anything, the attribute that was propagated first wins.
class __declspec ( dllexport ) DerivedFromTemplateB2 : public ClassTemplate < bool > { } ;
2014-06-26 02:25:57 +08:00
template < typename T > struct ExplicitlySpecializedTemplate { void func ( ) { } } ;
# ifdef MS
// expected-note@+2{{class template 'ExplicitlySpecializedTemplate<int>' was explicitly specialized here}}
# endif
template < > struct ExplicitlySpecializedTemplate < int > { void func ( ) { } } ;
template < typename T > struct ExplicitlyExportSpecializedTemplate { void func ( ) { } } ;
template < > struct __declspec ( dllexport ) ExplicitlyExportSpecializedTemplate < int > { void func ( ) { } } ;
template < typename T > struct ExplicitlyImportSpecializedTemplate { void func ( ) { } } ;
template < > struct __declspec ( dllimport ) ExplicitlyImportSpecializedTemplate < int > { void func ( ) { } } ;
template < typename T > struct ExplicitlyInstantiatedTemplate { void func ( ) { } } ;
# ifdef MS
// expected-note@+2{{class template 'ExplicitlyInstantiatedTemplate<int>' was instantiated here}}
# endif
template struct ExplicitlyInstantiatedTemplate < int > ;
template < typename T > struct ExplicitlyExportInstantiatedTemplate { void func ( ) { } } ;
template struct __declspec ( dllexport ) ExplicitlyExportInstantiatedTemplate < int > ;
template < typename T > struct ExplicitlyImportInstantiatedTemplate { void func ( ) { } } ;
template struct __declspec ( dllimport ) ExplicitlyImportInstantiatedTemplate < int > ;
# ifdef MS
2014-07-15 03:16:22 +08:00
// expected-warning@+3{{propagating dll attribute to explicitly specialized base class template without dll attribute is not supported}}
2014-06-26 02:25:57 +08:00
// expected-note@+2{{attribute is here}}
# endif
struct __declspec ( dllimport ) DerivedFromExplicitlySpecializedTemplate : public ExplicitlySpecializedTemplate < int > { } ;
// Base class already specialized with export attribute.
struct __declspec ( dllimport ) DerivedFromExplicitlyExportSpecializedTemplate : public ExplicitlyExportSpecializedTemplate < int > { } ;
// Base class already specialized with import attribute.
struct __declspec ( dllimport ) DerivedFromExplicitlyImportSpecializedTemplate : public ExplicitlyImportSpecializedTemplate < int > { } ;
# ifdef MS
2014-07-15 03:16:22 +08:00
// expected-warning@+3{{propagating dll attribute to already instantiated base class template without dll attribute is not supported}}
2014-06-26 02:25:57 +08:00
// expected-note@+2{{attribute is here}}
# endif
struct __declspec ( dllimport ) DerivedFromExplicitlyInstantiatedTemplate : public ExplicitlyInstantiatedTemplate < int > { } ;
// Base class already instantiated with export attribute.
struct __declspec ( dllimport ) DerivedFromExplicitlyExportInstantiatedTemplate : public ExplicitlyExportInstantiatedTemplate < int > { } ;
// Base class already instantiated with import attribute.
struct __declspec ( dllimport ) DerivedFromExplicitlyImportInstantiatedTemplate : public ExplicitlyImportInstantiatedTemplate < int > { } ;
2015-06-09 08:39:03 +08:00
template < typename T > struct ExplicitInstantiationDeclTemplateBase { void func ( ) { } } ;
extern template struct ExplicitInstantiationDeclTemplateBase < int > ;
struct __declspec ( dllimport ) DerivedFromExplicitInstantiationDeclTemplateBase : public ExplicitInstantiationDeclTemplateBase < int > { } ;
2015-09-16 05:05:30 +08:00
//===----------------------------------------------------------------------===//
// Lambdas
//===----------------------------------------------------------------------===//
// The MS ABI doesn't provide a stable mangling for lambdas, so they can't be imported or exported.
# ifdef MS
// expected-error@+4{{lambda cannot be declared 'dllimport'}}
# else
// expected-warning@+2{{'dllimport' attribute ignored on inline function}}
# endif
auto Lambda = [ ] ( ) __declspec ( dllimport ) - > bool { return true ; } ;