aboutsummaryrefslogtreecommitdiff
path: root/lib/Sema/SemaTemplate.cpp
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2010-03-26 00:39:40 +0000
committerDouglas Gregor <dgregor@apple.com>2010-03-26 00:39:40 +0000
commit0d4fd8ef35ecd73ce6388cb5a6fdcfb15171f5aa (patch)
treeeb5d31ddd2bc13faededf2b2c0294076ba4d7981 /lib/Sema/SemaTemplate.cpp
parent3e1ae9381b11ed565df6c4f2cbd22a6479af742e (diff)
Revert attempted fix for integral template arguments. It seems to have broken tramp3d-v4.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@99583 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Sema/SemaTemplate.cpp')
-rw-r--r--lib/Sema/SemaTemplate.cpp39
1 files changed, 19 insertions, 20 deletions
diff --git a/lib/Sema/SemaTemplate.cpp b/lib/Sema/SemaTemplate.cpp
index 0102aefa7e..5a1bec927c 100644
--- a/lib/Sema/SemaTemplate.cpp
+++ b/lib/Sema/SemaTemplate.cpp
@@ -2554,39 +2554,38 @@ bool Sema::CheckTemplateArgument(NonTypeTemplateParmDecl *Param,
IntegerType = Context.getCanonicalType(Enum->getDecl()->getIntegerType());
if (!Arg->isValueDependent()) {
- llvm::APSInt OldValue = Value;
-
- // Coerce the template argument's value to the value it will have
- // based on the template parameter's type.
- unsigned AllowedBits = Context.getTypeSize(IntegerType);
- Value.setIsSigned(IntegerType->isSignedIntegerType());
- if (Value.getBitWidth() != AllowedBits)
- Value.extOrTrunc(AllowedBits);
-
- // Complain if an unsigned parameter received a negative value.
+ // Check that an unsigned parameter does not receive a negative
+ // value.
if (IntegerType->isUnsignedIntegerType()
- && (OldValue.isSigned() && OldValue.isNegative())) {
- Diag(Arg->getSourceRange().getBegin(), diag::warn_template_arg_negative)
- << OldValue.toString(10) << Value.toString(10) << Param->getType()
+ && (Value.isSigned() && Value.isNegative())) {
+ Diag(Arg->getSourceRange().getBegin(), diag::err_template_arg_negative)
+ << Value.toString(10) << Param->getType()
<< Arg->getSourceRange();
Diag(Param->getLocation(), diag::note_template_param_here);
+ return true;
}
- // Complain if we overflowed the template parameter's type.
+ // Check that we don't overflow the template parameter type.
+ unsigned AllowedBits = Context.getTypeSize(IntegerType);
unsigned RequiredBits;
if (IntegerType->isUnsignedIntegerType())
- RequiredBits = OldValue.getActiveBits();
- else if (OldValue.isUnsigned())
- RequiredBits = OldValue.getActiveBits() + 1;
+ RequiredBits = Value.getActiveBits();
+ else if (Value.isUnsigned())
+ RequiredBits = Value.getActiveBits() + 1;
else
- RequiredBits = OldValue.getMinSignedBits();
+ RequiredBits = Value.getMinSignedBits();
if (RequiredBits > AllowedBits) {
Diag(Arg->getSourceRange().getBegin(),
- diag::warn_template_arg_too_large)
- << OldValue.toString(10) << Value.toString(10) << Param->getType()
+ diag::err_template_arg_too_large)
+ << Value.toString(10) << Param->getType()
<< Arg->getSourceRange();
Diag(Param->getLocation(), diag::note_template_param_here);
+ return true;
}
+
+ if (Value.getBitWidth() != AllowedBits)
+ Value.extOrTrunc(AllowedBits);
+ Value.setIsSigned(IntegerType->isSignedIntegerType());
}
// Add the value of this argument to the list of converted