Code behaves incorrectly if it is compiled in std.functional

ketmar via Digitalmars-d digitalmars-d at puremagic.com
Fri Jun 5 23:10:32 PDT 2015


On Fri, 05 Jun 2015 20:36:19 +0000, Mafi wrote:

> On Friday, 5 June 2015 at 10:56:36 UTC, ketmar wrote:
> 
> 
>> p.s. if "auto" is a storage class, the following code should be
>> accepted (while it isn't):
>>
>>   int foo () { return 42; }
>>
>>   void main () {
>>     auto auto i = foo();
>>   }
>>
>> as it's logically "an auto-typed var with "auto" storage class".
> 
> Here lies your mistake. There is no such thing as "auto"-typed (leaving
> aside function signatures, which might be special-cased and are
> different beast altogether). Auto is not a type. auto* or auto[] aren't
> valied either. Auto is just a storage class, no more, no less. You use
> it if the grammar needs a storage class but you don't want to give
> special attributes to the variable (like const or static). To make a
> declaration with inferred type you need at least one storage class. To
> make it work with "normal" variables you use "auto".

so either `const auto` should not be accepted, or `auto auto` should be 
accepted. if `auto` plays a role of "default storage class", the `const 
auto` should trigger the error about redundant storage specifier. if 
`auto` can play a role of type placeholder, then `auto auto` should be 
accepted, as it's clearly the "default storage class with type 
placeholder".

current situation is inconsistent and that inconsistency must be fixed.
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 181 bytes
Desc: not available
URL: <http://lists.puremagic.com/pipermail/digitalmars-d/attachments/20150606/6f0e69ba/attachment.sig>


More information about the Digitalmars-d mailing list