[cfe-commits] r136161 - in /cfe/trunk: include/clang/Basic/DiagnosticSemaKinds.td lib/Sema/SemaExprCXX.cpp test/SemaCXX/new-delete.cpp

John McCall rjmccall at apple.com
Tue Jul 26 23:03:04 PDT 2011


On Jul 26, 2011, at 9:54 PM, Douglas Gregor wrote:
> On Jul 26, 2011, at 3:34 PM, Eli Friedman wrote:
>> On Tue, Jul 26, 2011 at 3:28 PM, Sean Hunt <scshunt at csclub.uwaterloo.ca> wrote:
>>> On Tue, Jul 26, 2011 at 15:25, Eli Friedman <eli.friedman at gmail.com> wrote:
>>>> Author: efriedma
>>>> Date: Tue Jul 26 17:25:31 2011
>>>> New Revision: 136161
>>>> 
>>>> URL: http://llvm.org/viewvc/llvm-project?rev=136161&view=rev
>>>> Log:
>>>> A couple minor issues with Sema for delete:
>>>> 
>>>> 1. Attempting to delete an expression of incomplete class type should be an error, not a warning.
>>>> 
>>>> 2. If someone tries to delete a pointer to an incomplete class type, make sure we actually emit
>>>> the delete expression after we warn.
>>> 
>>> Deleting an object of incomplete class type is well-formed;
>>> [expr.delete]/5. This should not be an error.
>> 
>> [expr.delete]/1: "The operand shall have a pointer to object type, or
>> a class type having a single non-explicit conversion function (12.3.2)
>> to a pointer to object type."  An expression of incomplete class type
>> isn't either of those.
> 
> 
> An incomplete class type is an object type in C++.

But it's not a pointer to object type.  The "object being deleted" per [expr.delete]p1 is not the operand of the delete function;  if the operand is a pointer, then it's the object pointed to by that pointer, and otherwise it's the object pointed to by the pointer produced by the operand's requisite single non-explicit conversion function.

Did you check out the actual patch?  DiagnosticSemaKinds.td had err_delete_incomplete_class_type listed as a warning, not an error, and the warning path on deleting pointers to incomplete type was returning ExprError().

John.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20110726/c498cf49/attachment.html>


More information about the cfe-commits mailing list