Bug 9423 – Missed conversion of lambda literal with ref argument

Status
RESOLVED
Resolution
DUPLICATE
Severity
enhancement
Priority
P4
Component
dmd
Product
D
Version
D2
Platform
All
OS
All
Creation time
2013-01-29T02:51:30Z
Last change time
2023-01-07T22:25:06Z
Keywords
pull, rejects-valid
Assigned to
No Owner
Creator
bearophile_hugs
See also
https://issues.dlang.org/show_bug.cgi?id=10602

Comments

Comment #0 by bearophile_hugs — 2013-01-29T02:51:30Z
void foo(int delegate(ref int[1]) spam) {} void main() { foo((ref int[1] x) => 0); // OK foo(x => 0); // Error } DMD 2.062alpha gives: test.d(4): Error: function test.foo (int delegate(ref int[1u]) spam)(null) is not callable using argument types (void) test.d(4): Error: cannot implicitly convert expression (__lambda3) of type int delegate(int[1u] x) pure nothrow @safe to int delegate(ref int[1u])
Comment #1 by k.hara.pg — 2013-01-29T09:23:54Z
When I fixed bug7705, I decided that lambda inference does not infer parameter storage classes. Instead, users should specify `ref`/`out`/`lazy` explicitly. https://github.com/D-Programming-Language/dmd/pull/809/files#L1R496 Because, explicit specifying of `ref` in call site is sometimes required in newsgroup. void foo(ref int x) {} int n; foo(ref n); // not allowed in today So, current behavior is intended. You should write it as follows: void foo(int delegate(ref int[1]) spam) {} void main() { foo((ref x) => 0); // OK } However, I cannot say clearly whether it's right behavior. I think that the opinion "parameter storage classes should be inferred" is also worth. Therefore, I'll mark this as 'enhancement'. ===== A pull to implement this feature: https://github.com/D-Programming-Language/dmd/pull/1580
Comment #2 by bearophile_hugs — 2013-01-29T10:00:15Z
(In reply to comment #1) > Therefore, I'll mark this as 'enhancement'. > > ===== > > A pull to implement this feature: > https://github.com/D-Programming-Language/dmd/pull/1580 Thank you Hara.
Comment #3 by bearophile_hugs — 2013-01-30T10:26:15Z
A discussion thread, the answers are mixed: http://forum.dlang.org/thread/[email protected] A comment from Timon Gehr: > BTW, the pull does not contain a test for the case > > void foo(int delegate(int) dg){ ... } // 1 > void foo(int delegate(ref int) dg){ ... } // 2 > > void main(){ foo(x=>0); } // call 1
Comment #4 by pro.mathias.lang — 2020-08-26T17:27:59Z
*** Issue 12830 has been marked as a duplicate of this issue. ***
Comment #5 by snarwin+bugzilla — 2023-01-07T22:25:06Z
Closing in favor of 11316, since that one covers all storage classes, not just ref. *** This issue has been marked as a duplicate of issue 11316 ***