If the given argument to the out parameter is not correctly initialized (eg. void initialized variable), calling dtor for the argument is absolutely unsafe. That's the reason why my patch was rejected by Walter.

Alternative language semantics in my thought is:
---
If an out parameter typed T exists, and
  1. T has elaborate destructor
  2. T.init represents logically invalid object (T is nested struct, and/or T has @disable this();)
Automatic blit initializing for the out parameter would be unsafe.

So semantic analysis would reject such a out parameter declaration.
---

But I'm still not sure the rule is enough useful for many cases...

Kenji Hara

2013/10/3 Benjamin Thaut <code@benjamin-thaut.de>
http://d.puremagic.com/issues/show_bug.cgi?id=6186

This bug is open since two years and nothing has happend so far.

If you look at it its really funny:

Kenji: Heres a Bug and a fix
Walter: I don't like your fix but I don't have a better idea
Kenji: closes pull request
-- silence -- (for over 2 years)

We should really find a solution for this problem.

Kind Regards
Benjamin Thaut