зеркало из https://github.com/microsoft/clang-1.git
Check for unexpanded parameter packs in enumeration types and enumerators.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@121928 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Родитель
399ad970a2
Коммит
0c9e4799fd
|
@ -1823,19 +1823,19 @@ def note_template_parameter_pack_here : Note<
|
|||
|
||||
def err_unexpanded_parameter_pack_0 : Error<
|
||||
"%select{expression|base type|declaration type|data member type|bit-field "
|
||||
"size|static assertion}0 "
|
||||
"contains unexpanded parameter pack">;
|
||||
"size|static assertion|fixed underlying type|enumerator value}0 "
|
||||
"contains an unexpanded parameter pack">;
|
||||
def err_unexpanded_parameter_pack_1 : Error<
|
||||
"%select{expression|base type|declaration type|data member type|bit-field "
|
||||
"size|static assertion}0 "
|
||||
"size|static assertion|fixed underlying type|enumerator value}0 "
|
||||
"contains unexpanded parameter pack %1">;
|
||||
def err_unexpanded_parameter_pack_2 : Error<
|
||||
"%select{expression|base type|declaration type|data member type|bit-field "
|
||||
"size|static assertion}0 "
|
||||
"size|static assertion|fixed underlying type|enumerator value}0 "
|
||||
"contains unexpanded parameter packs %1 and %2">;
|
||||
def err_unexpanded_parameter_pack_3_or_more : Error<
|
||||
"%select{expression|base type|declaration type|data member type|bit-field "
|
||||
"size|static assertion}0 "
|
||||
"size|static assertion|fixed underlying type|enumerator value}0 "
|
||||
"contains unexpanded parameter packs %1, %2, ...">;
|
||||
|
||||
def err_unexpected_typedef : Error<
|
||||
|
|
|
@ -3151,7 +3151,13 @@ public:
|
|||
UPPC_BitFieldWidth,
|
||||
|
||||
/// \brief The expression in a static assertion.
|
||||
UPPC_StaticAssertExpression
|
||||
UPPC_StaticAssertExpression,
|
||||
|
||||
/// \brief The fixed underlying type of an enumeration.
|
||||
UPPC_FixedUnderlyingType,
|
||||
|
||||
/// \brief The enumerator value.
|
||||
UPPC_EnumeratorValue
|
||||
};
|
||||
|
||||
/// \brief If the given type contains an unexpanded parameter pack,
|
||||
|
|
|
@ -5771,6 +5771,11 @@ Decl *Sema::ActOnTag(Scope *S, unsigned TagSpec, TagUseKind TUK,
|
|||
// Recover by falling back to int.
|
||||
EnumUnderlying = Context.IntTy.getTypePtr();
|
||||
}
|
||||
|
||||
if (DiagnoseUnexpandedParameterPack(UnderlyingLoc, TI,
|
||||
UPPC_FixedUnderlyingType))
|
||||
EnumUnderlying = Context.IntTy.getTypePtr();
|
||||
|
||||
} else if (getLangOptions().Microsoft)
|
||||
// Microsoft enums are always of int type.
|
||||
EnumUnderlying = Context.IntTy.getTypePtr();
|
||||
|
@ -7319,6 +7324,10 @@ EnumConstantDecl *Sema::CheckEnumConstant(EnumDecl *Enum,
|
|||
unsigned IntWidth = Context.Target.getIntWidth();
|
||||
llvm::APSInt EnumVal(IntWidth);
|
||||
QualType EltTy;
|
||||
|
||||
if (Val && DiagnoseUnexpandedParameterPack(Val, UPPC_EnumeratorValue))
|
||||
Val = 0;
|
||||
|
||||
if (Val) {
|
||||
if (Enum->isDependentType() || Val->isTypeDependent())
|
||||
EltTy = Context.DependentTy;
|
||||
|
|
|
@ -112,6 +112,10 @@ struct TestUnexpandedDecls {
|
|||
static Types static_data_member; // expected-error{{declaration type contains unexpanded parameter pack 'Types'}}
|
||||
unsigned bit_field : static_cast<Types>(0); // expected-error{{bit-field size contains unexpanded parameter pack 'Types'}}
|
||||
static_assert(static_cast<Types>(0), "Boom"); // expected-error{{static assertion contains unexpanded parameter pack 'Types'}}
|
||||
|
||||
enum E0 : Types { // expected-error{{fixed underlying type contains unexpanded parameter pack 'Types'}}
|
||||
EnumValue = static_cast<Types>(0) // expected-error{{enumerator value contains unexpanded parameter pack 'Types'}}
|
||||
};
|
||||
};
|
||||
|
||||
// Test for diagnostics in the presence of multiple unexpanded
|
||||
|
|
Загрузка…
Ссылка в новой задаче