"explicit specialization of %0 in function scope">;
def err_template_spec_decl_class_scope : Error<
"explicit specialization of %0 in class scope">;
-def war_template_spec_decl_class_scope : ExtWarn<
- "Allowing explicit specialization of %0 in class scope is a Microsoft "
- "extension">, InGroup<Microsoft>;
def err_template_spec_decl_friend : Error<
"cannot declare an explicit specialization in a friend">;
def err_template_spec_decl_out_of_scope_global : Error<
if (OldMethod && NewMethod) {
// Preserve triviality.
NewMethod->setTrivial(OldMethod->isTrivial());
-
- // MSVC allows explicit template specialization at class scope.
- bool IsMSExplicitSpecialization = getLangOptions().Microsoft &&
- NewMethod->isFunctionTemplateSpecialization();
+
bool isFriend = NewMethod->getFriendObjectKind();
- if (!isFriend && NewMethod->getLexicalDeclContext()->isRecord() &&
- !IsMSExplicitSpecialization) {
+ if (!isFriend && NewMethod->getLexicalDeclContext()->isRecord()) {
// -- Member function declarations with the same name and the
// same parameter types cannot be overloaded if any of them
// is a static member function declaration.
NewFD->setInvalidDecl();
} else if (isFunctionTemplateSpecialization) {
if (CurContext->isDependentContext() && CurContext->isRecord()
- && !isFriend) {
+ && !isFriend && !getLangOptions().Microsoft) {
Diag(NewFD->getLocation(), diag::err_function_specialization_in_class)
<< NewFD->getDeclName();
NewFD->setInvalidDecl();
}
if (S.CurContext->isRecord() && !IsPartialSpecialization) {
- if (S.getLangOptions().Microsoft)
- S.Diag(Loc, diag::war_template_spec_decl_class_scope) << Specialized;
- else {
- S.Diag(Loc, diag::err_template_spec_decl_class_scope) << Specialized;
- return true;
- }
+ S.Diag(Loc, diag::err_template_spec_decl_class_scope)
+ << Specialized;
+ return true;
}
// C++ [temp.class.spec]p6: