Why Ruby?

Jacob Carlborg doob at me.com
Wed Dec 15 13:23:35 PST 2010


On 2010-12-14 22:04, Nick Sabalausky wrote:
> "Jacob Carlborg"<doob at me.com>  wrote in message
> news:ie8f5f$o6e$1 at digitalmars.com...
>>
>> Probably not, but, for example, Scala allows very compact delegate
>> literals:
>>
>> Array(1, 2, 3, 4, 5).select(_>  3).collect(_ * _)
>>
>> Or more verbose:
>>
>> Array(1, 2, 3, 4, 5).select((x) =>  x>  3).collect((x, y) =>  x * y)
>>
>> I'm not 100% sure I that the syntax is correct.
>>
>
> I'd be surprised if the first one is correct, because that "collect(_ * _)"
> would seem highly limited (how would you use the same value twice, or use
> just the second value, or use them in reverse order?).

I guess for anything more complicated you would have to use the => 
syntax. BTW, I just verified that this works:

Array(1, 2, 3, 4, 5).sortWith(_ > _)

You can try it out for yourself at: http://www.simplyscala.com/

> The second one reminds me of C#'s lambdas and seems like an excellent
> solution to the question of what to do with all the noise of the extra curly
> braces, "return" keyword and trailing semicolon. And given that 1. The =>
> isn't currently a valid D token anyway, and 2. The (x) and (x,y) are already
> being used perfectly fine by the existing delegate literal syntax, I can't
> imagine there would be any ambiguity with it in D.
>
> I'd be absolutely in favor of adding that to D. In fact, I'd love to see it
> happen. Just require that the part after "=>" is an expression, accept that
> the more complex delegates that need statements use the existing syntax
> (which should be fine since it's only the single-expression-and-nothing-else
> delegates that are seen as verbose in D), and call it a day.

I would also love to have that syntax. I also love the syntax I 
previously suggested in this thread, there are many to choose of.

-- 
/Jacob Carlborg


More information about the Digitalmars-d mailing list