On Tue, 10 Aug 2010 10:11:21 -0400, Michel Fortin <[email protected]> wrote:

On 2010-08-10 08:11:21 -0400, "Steven Schveighoffer" <[email protected]> said:

Undefined, undefined, undefined :)

So we agree on that. That's exactly what I was trying to prove to Andrei. Using clear() can break program invariants, break the type system (immutable members) and so on, even though I admit it can be useful at times.

**** So why give it a so innocuous-looking name such as "clear" !! ****

I think that book has shipped.

Call it destroy() at the very very least, and put it in a module where no one will find it by accident and think it is safe for general use. For instance, it could be made part of the GC API, allowing the GC to adjust the memory block to avoid calling the destructor a second time upon collection. GC.destroy() sounds like a good name for that kind functionality.

delete is currently available whenever you want it and is twice as dangerous. It might as well be in object.di. I think that's where clear belongs too.

Hiding it from users is not the right thing to do. Once you find something, you aren't going to forget where it is. Maybe we can move it to a random module on each release ;)

Placing danger warnings around it on all sides, with a legal disclaimer you must sign in order to use it, and make IDEs highlight it in red is probably all that is necessary. Disallowing it in safeD might be a better deterrent than naming it a certain way or putting it in an obscure module.

-Steve

Reply via email to