mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2025-01-28 12:30:22 +00:00
When producing a name of a partial specialization in a diagnostic, use the
template arguments as written rather than the canonical template arguments, so we print more user-friendly names for template parameters. llvm-svn: 290483
This commit is contained in:
parent
db0931880a
commit
792c22dbd4
@ -596,6 +596,10 @@ public:
|
||||
return getTrailingObjects<TemplateArgumentLoc>();
|
||||
}
|
||||
|
||||
llvm::ArrayRef<TemplateArgumentLoc> arguments() const {
|
||||
return llvm::makeArrayRef(getTemplateArgs(), NumTemplateArgs);
|
||||
}
|
||||
|
||||
const TemplateArgumentLoc &operator[](unsigned I) const {
|
||||
return getTemplateArgs()[I];
|
||||
}
|
||||
|
@ -4103,9 +4103,9 @@ def note_template_class_instantiation_was_here : Note<
|
||||
def note_template_class_explicit_specialization_was_here : Note<
|
||||
"class template %0 was explicitly specialized here">;
|
||||
def note_template_class_instantiation_here : Note<
|
||||
"in instantiation of template class %0 requested here">;
|
||||
"in instantiation of template class %q0 requested here">;
|
||||
def note_template_member_class_here : Note<
|
||||
"in instantiation of member class %0 requested here">;
|
||||
"in instantiation of member class %q0 requested here">;
|
||||
def note_template_member_function_here : Note<
|
||||
"in instantiation of member function %q0 requested here">;
|
||||
def note_function_template_spec_here : Note<
|
||||
|
@ -725,10 +725,17 @@ void ClassTemplateSpecializationDecl::getNameForDiagnostic(
|
||||
raw_ostream &OS, const PrintingPolicy &Policy, bool Qualified) const {
|
||||
NamedDecl::getNameForDiagnostic(OS, Policy, Qualified);
|
||||
|
||||
auto *PS = dyn_cast<ClassTemplatePartialSpecializationDecl>(this);
|
||||
if (const ASTTemplateArgumentListInfo *ArgsAsWritten =
|
||||
PS ? PS->getTemplateArgsAsWritten() : nullptr) {
|
||||
TemplateSpecializationType::PrintTemplateArgumentList(
|
||||
OS, ArgsAsWritten->arguments(), Policy);
|
||||
} else {
|
||||
const TemplateArgumentList &TemplateArgs = getTemplateArgs();
|
||||
TemplateSpecializationType::PrintTemplateArgumentList(
|
||||
OS, TemplateArgs.asArray(), Policy);
|
||||
}
|
||||
}
|
||||
|
||||
ClassTemplateDecl *
|
||||
ClassTemplateSpecializationDecl::getSpecializedTemplate() const {
|
||||
@ -1057,10 +1064,17 @@ void VarTemplateSpecializationDecl::getNameForDiagnostic(
|
||||
raw_ostream &OS, const PrintingPolicy &Policy, bool Qualified) const {
|
||||
NamedDecl::getNameForDiagnostic(OS, Policy, Qualified);
|
||||
|
||||
auto *PS = dyn_cast<VarTemplatePartialSpecializationDecl>(this);
|
||||
if (const ASTTemplateArgumentListInfo *ArgsAsWritten =
|
||||
PS ? PS->getTemplateArgsAsWritten() : nullptr) {
|
||||
TemplateSpecializationType::PrintTemplateArgumentList(
|
||||
OS, ArgsAsWritten->arguments(), Policy);
|
||||
} else {
|
||||
const TemplateArgumentList &TemplateArgs = getTemplateArgs();
|
||||
TemplateSpecializationType::PrintTemplateArgumentList(
|
||||
OS, TemplateArgs.asArray(), Policy);
|
||||
}
|
||||
}
|
||||
|
||||
VarTemplateDecl *VarTemplateSpecializationDecl::getSpecializedTemplate() const {
|
||||
if (SpecializedPartialSpecialization *PartialSpec =
|
||||
|
@ -6638,8 +6638,7 @@ Sema::ActOnClassTemplateSpecialization(Scope *S, unsigned TagSpec,
|
||||
TUK = TUK_Declaration;
|
||||
} else if (Def) {
|
||||
SourceRange Range(TemplateNameLoc, RAngleLoc);
|
||||
Diag(TemplateNameLoc, diag::err_redefinition)
|
||||
<< Context.getTypeDeclType(Specialization) << Range;
|
||||
Diag(TemplateNameLoc, diag::err_redefinition) << Specialization << Range;
|
||||
Diag(Def->getLocation(), diag::note_previous_definition);
|
||||
Specialization->setInvalidDecl();
|
||||
return true;
|
||||
|
@ -423,8 +423,7 @@ void Sema::PrintInstantiationStack() {
|
||||
if (isa<ClassTemplateSpecializationDecl>(Record))
|
||||
DiagID = diag::note_template_class_instantiation_here;
|
||||
Diags.Report(Active->PointOfInstantiation, DiagID)
|
||||
<< Context.getTypeDeclType(Record)
|
||||
<< Active->InstantiationRange;
|
||||
<< Record << Active->InstantiationRange;
|
||||
} else if (FunctionDecl *Function = dyn_cast<FunctionDecl>(D)) {
|
||||
unsigned DiagID;
|
||||
if (Function->getPrimaryTemplate())
|
||||
@ -490,7 +489,7 @@ void Sema::PrintInstantiationStack() {
|
||||
dyn_cast<ClassTemplatePartialSpecializationDecl>(Active->Entity)) {
|
||||
Diags.Report(Active->PointOfInstantiation,
|
||||
diag::note_partial_spec_deduct_instantiation_here)
|
||||
<< Context.getTypeDeclType(PartialSpec)
|
||||
<< PartialSpec
|
||||
<< getTemplateArgumentBindingsText(
|
||||
PartialSpec->getTemplateParameters(),
|
||||
Active->TemplateArgs,
|
||||
|
@ -283,7 +283,7 @@ namespace spec_vs_expl_inst {
|
||||
template <typename STRING_TYPE> class BasicStringPiece {};
|
||||
template class BasicStringPiece<int>; // expected-note {{explicit instantiation definition is here}} expected-note {{previous definition is here}}
|
||||
extern template class BasicStringPiece<int>; // expected-error {{explicit instantiation declaration (with 'extern') follows explicit instantiation definition (without 'extern')}}
|
||||
template <> class BasicStringPiece<int> { }; // expected-error {{redefinition of 'spec_vs_expl_inst::IDS_WithDefinedTemplate::BasicStringPiece<int>'}}
|
||||
template <> class BasicStringPiece<int> { }; // expected-error {{redefinition of 'BasicStringPiece<int>'}}
|
||||
}
|
||||
|
||||
namespace DIS_WithDefinedTemplate {
|
||||
@ -313,14 +313,14 @@ namespace spec_vs_expl_inst {
|
||||
template <typename STRING_TYPE> class BasicStringPiece;
|
||||
template <> class BasicStringPiece<int> { }; // expected-note {{previous definition is here}} expected-note {{previous}}
|
||||
template class BasicStringPiece<int>; // expected-warning {{has no effect}}
|
||||
template <> class BasicStringPiece<int> { }; // expected-error {{redefinition of 'spec_vs_expl_inst::SIS::BasicStringPiece<int>'}}
|
||||
template <> class BasicStringPiece<int> { }; // expected-error {{redefinition of 'BasicStringPiece<int>'}}
|
||||
}
|
||||
|
||||
namespace SDS {
|
||||
template <typename STRING_TYPE> class BasicStringPiece;
|
||||
template <> class BasicStringPiece<int> { }; // expected-note {{previous definition is here}}
|
||||
extern template class BasicStringPiece<int>;
|
||||
template <> class BasicStringPiece<int> { }; // expected-error {{redefinition of 'spec_vs_expl_inst::SDS::BasicStringPiece<int>'}}
|
||||
template <> class BasicStringPiece<int> { }; // expected-error {{redefinition of 'BasicStringPiece<int>'}}
|
||||
}
|
||||
|
||||
namespace SDIS {
|
||||
@ -328,7 +328,7 @@ namespace spec_vs_expl_inst {
|
||||
template <> class BasicStringPiece<int> { }; // expected-note {{previous definition is here}}
|
||||
extern template class BasicStringPiece<int>;
|
||||
template class BasicStringPiece<int>;
|
||||
template <> class BasicStringPiece<int> { }; // expected-error {{redefinition of 'spec_vs_expl_inst::SDIS::BasicStringPiece<int>'}}
|
||||
template <> class BasicStringPiece<int> { }; // expected-error {{redefinition of 'BasicStringPiece<int>'}}
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -195,8 +195,8 @@ namespace hidden_specializations {
|
||||
cls<void>::nested_cls_t<int> *nk2; // ok
|
||||
cls<void>::nested_cls_t<char> *nk3; // ok
|
||||
cls<int> uk1; // expected-error 1+{{explicit specialization of 'cls<int>' must be imported}} expected-error 1+{{definition of}}
|
||||
cls<int*> uk3; // expected-error 1+{{partial specialization of 'cls<type-parameter-0-0 *>' must be imported}} expected-error 1+{{definition of}}
|
||||
cls<char*> uk4; // expected-error 1+{{partial specialization of 'cls<type-parameter-0-0 *>' must be imported}} expected-error 1+{{definition of}}
|
||||
cls<int*> uk3; // expected-error 1+{{partial specialization of 'cls<T *>' must be imported}} expected-error 1+{{definition of}}
|
||||
cls<char*> uk4; // expected-error 1+{{partial specialization of 'cls<T *>' must be imported}} expected-error 1+{{definition of}}
|
||||
cls<void>::nested_cls unk1; // expected-error 1+{{explicit specialization of 'nested_cls' must be imported}} expected-error 1+{{definition of}}
|
||||
cls<void>::nested_cls_t<int> unk2; // expected-error 1+{{explicit specialization of 'nested_cls_t' must be imported}} expected-error 1+{{definition of}}
|
||||
cls<void>::nested_cls_t<char> unk3; // expected-error 1+{{explicit specialization of 'nested_cls_t' must be imported}}
|
||||
@ -211,8 +211,8 @@ namespace hidden_specializations {
|
||||
(void)sizeof(var<void>); // ok
|
||||
(void)sizeof(var<char>); // ok
|
||||
(void)sizeof(var<int>); // expected-error 1+{{explicit specialization of 'var<int>' must be imported}}
|
||||
(void)sizeof(var<int*>); // expected-error 1+{{partial specialization of 'var<type-parameter-0-0 *>' must be imported}}
|
||||
(void)sizeof(var<char*>); // expected-error 1+{{partial specialization of 'var<type-parameter-0-0 *>' must be imported}}
|
||||
(void)sizeof(var<int*>); // expected-error 1+{{partial specialization of 'var<T *>' must be imported}}
|
||||
(void)sizeof(var<char*>); // expected-error 1+{{partial specialization of 'var<T *>' must be imported}}
|
||||
(void)sizeof(cls<void>::nested_var); // ok
|
||||
(void)cls<void>::nested_var; // expected-error 1+{{explicit specialization of 'nested_var' must be imported}}
|
||||
(void)sizeof(cls<void>::nested_var_t<int>); // expected-error 1+{{explicit specialization of 'nested_var_t' must be imported}}
|
||||
@ -224,10 +224,10 @@ namespace hidden_specializations {
|
||||
int cls<int>::nested_var; // expected-error 1+{{explicit specialization of 'cls<int>' must be imported}} expected-error 1+{{definition of}}
|
||||
enum cls<int>::nested_enum : int {}; // expected-error 1+{{explicit specialization of 'cls<int>' must be imported}} expected-error 1+{{definition of}}
|
||||
|
||||
template<typename T> void cls<T*>::nested_fn() {} // expected-error 1+{{partial specialization of 'cls<type-parameter-0-0 *>' must be imported}}
|
||||
template<typename T> struct cls<T*>::nested_cls {}; // expected-error 1+{{partial specialization of 'cls<type-parameter-0-0 *>' must be imported}}
|
||||
template<typename T> int cls<T*>::nested_var; // expected-error 1+{{partial specialization of 'cls<type-parameter-0-0 *>' must be imported}}
|
||||
template<typename T> enum cls<T*>::nested_enum : int {}; // expected-error 1+{{partial specialization of 'cls<type-parameter-0-0 *>' must be imported}}
|
||||
template<typename T> void cls<T*>::nested_fn() {} // expected-error 1+{{partial specialization of 'cls<T *>' must be imported}}
|
||||
template<typename T> struct cls<T*>::nested_cls {}; // expected-error 1+{{partial specialization of 'cls<T *>' must be imported}}
|
||||
template<typename T> int cls<T*>::nested_var; // expected-error 1+{{partial specialization of 'cls<T *>' must be imported}}
|
||||
template<typename T> enum cls<T*>::nested_enum : int {}; // expected-error 1+{{partial specialization of 'cls<T *>' must be imported}}
|
||||
}
|
||||
|
||||
namespace Std {
|
||||
|
@ -336,3 +336,18 @@ namespace member_pointer {
|
||||
};
|
||||
C<B<int, &A::f>> c;
|
||||
}
|
||||
|
||||
namespace deduction_substitution_failure {
|
||||
template<typename T> struct Fail { typedef typename T::error error; }; // expected-error {{prior to '::'}}
|
||||
|
||||
template<typename T, typename U> struct A {};
|
||||
template<typename T> struct A<T, typename Fail<T>::error> {}; // expected-note {{instantiation of}}
|
||||
A<int, int> ai; // expected-note {{during template argument deduction for class template partial specialization 'A<T, typename Fail<T>::error>' [with T = int]}}
|
||||
|
||||
// FIXME: This tickles an assertion.
|
||||
#if 0
|
||||
template<typename T, typename U> int B; // expected-warning 0-1 {{extension}}
|
||||
template<typename T> int B<T, typename Fail<T>::error> {};
|
||||
int bi = B<char, char>;
|
||||
#endif
|
||||
}
|
||||
|
@ -36,7 +36,7 @@ typedef int& int_ref_t;
|
||||
Def2<int_ref_t> *d2; // expected-note{{in instantiation of default argument for 'Def2<int &>' required here}}
|
||||
|
||||
|
||||
template<> struct Def1<const int, const int> { }; // expected-error{{redefinition of 'Def1<const int>'}}
|
||||
template<> struct Def1<const int> { }; // expected-error{{redefinition of 'Def1<const int, const int>'}}
|
||||
|
||||
template<typename T, typename T2 = T&> struct Def3;
|
||||
|
||||
|
@ -19,7 +19,7 @@ public:
|
||||
X<double>::y c;
|
||||
|
||||
template<> struct X<float> {}; // expected-note {{previous definition is here}}
|
||||
template<> struct X<float> {}; // expected-error {{redefinition of 'A::X<float>'}}
|
||||
template<> struct X<float> {}; // expected-error {{redefinition of 'X<float>'}}
|
||||
};
|
||||
|
||||
A::X<void>::x axv;
|
||||
|
Loading…
x
Reference in New Issue
Block a user