[Issue 6714] [tdpl] Type inference for parameters of function and delegate literals

d-bugmail at puremagic.com d-bugmail at puremagic.com
Mon Dec 26 17:10:44 PST 2011


http://d.puremagic.com/issues/show_bug.cgi?id=6714


Don <clugdbug at yahoo.com.au> changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
           Keywords|                            |rejects-valid, spec
            Version|unspecified                 |D2
            Summary|[tdpl] Function literal     |[tdpl] Type inference for
                   |does not convert to         |parameters of function and
                   |"function" and "delegate"   |delegate literals
                   |types                       |
         OS/Version|Mac OS X                    |All
           Severity|normal                      |enhancement


--- Comment #4 from Don <clugdbug at yahoo.com.au> 2011-12-26 17:10:36 PST ---
(In reply to comment #3)
> (In reply to comment #2)
> > (In reply to comment #0)
> > > Consider:
> > > 
> > > 
> > > void foo (int function (int, int) a){}
> > > void bar (int delegate (int, int) a){}
> > > 
> > > void main ()
> > > {
> > >     foo((a, b) { return a +b;});
> > >     bar((a, b) { return a +b;});
> > > }
> > Are argument types supposed to be deduced? If so, that's a major,
> > complicated feature and difficult to implement, I think it requires an extra
> > level of argument matching.
> 
> When I discussed with Walter the matter a while ago, a possible approach was
> that the literal relying on deduction defines a local template function. 

Changing bug title from the original ´Function literal does not convert to
"function" and "delegate" types´, since this seems to be type inference
enhancement, which requires a spec change.

> For example, the code:
> 
>     foo((a, b) { return a +b;});
> 
> would be lowered into:
> 
>     static auto __lambda(T1, T2)(T1 a, T2 b) { return a + b; }
>     foo(__lambda);
> 
> The "static" is present because the compiler figured the lambda uses no state
> from the enclosing context. Built-in conversion mechanisms should take over
> from here on.

I don't understand how this works. Where does the template get instantiated?

In the examples at the end of comment 3, it seems to be deducing the parameters
of __lambda from parameters of foo. This seems very complicated. 
If foo is a template function, in every existing situation, all the types of
the arguments are known. Here, they aren't. For example if foo is:

void foo(T = int, R)( R function(T, T) f)

then we'd expect T1, T2 to be deduced as int (because of the default value of
T). We now have enough information to instantiate __lambda, which then allows
us to determine R. We can then finally instantiate foo. We're instantiating two
templates at once, and they're kind of interlocked. The interlocking continues
further: if the parameter deduction or template constraint of foo fails, then
the instantiation of __lambda must also be discarded.
The 4-step template argument deduction process described in template.html is
gone.

> This also brings the issue of automatically converting a function to a
> delegate. Walter disagrees with that, but I disagree with the basis of his
> disagreement.

Obviously this needs to be resolved.

-- 
Configure issuemail: http://d.puremagic.com/issues/userprefs.cgi?tab=email
------- You are receiving this mail because: -------


More information about the Digitalmars-d-bugs mailing list