[cfe-commits] r136161 - in /cfe/trunk: include/clang/Basic/DiagnosticSemaKinds.td lib/Sema/SemaExprCXX.cpp test/SemaCXX/new-delete.cpp
Douglas Gregor
dgregor at apple.com
Tue Jul 26 21:54:52 PDT 2011
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++. You're probably thinking of C, where "incomplete types" are distinct from "object types".
Besides, check out [expr.delete]p5:
If the object being deleted has incomplete class type at the point of deletion and the complete class has a
non-trivial destructor or a deallocation function, the behavior is undefined.
- Doug
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20110726/026ada4a/attachment.html>
More information about the cfe-commits
mailing list