Closed lucasteles closed 6 months ago
cc @vzarytovskii
["foo"; "42"; ""].Select(_.Length)
:x:
["foo"; "42"; ""].Select _.Length
✔️
@Happypig375 I believe both should work, the first is important to not break the fluent chain
["foo"; "42"; ""].Select(_.Length).Where(isEven)
@lucasteles only needed when there is a fluent chain.
This already has an issue: #506
Edit: Oh wait, is this specifically for Func
/Expression
?
@cmeeren This is for any delegate, not F# function types.
Yes, then I definitely second this.
This was done as part of https://github.com/dotnet/fsharp/pull/16339 (it is in main, not yet in the released product) The following three syntax options of doing the same now work, does it cover all of this suggestion?
open System.Linq
let _ = [""; ""; ""].Select(fun x -> x.Length)
let _ = [""; ""; ""].Select(_.Length)
let _ = [""; ""; ""].Select _.Length
From what I can see, this would fix the issue, though I'm not the OP.
Works like a charm (in main
)!
I propose we enable to use of the new
_.Property
shorthand for accessor withinFunc<>
andExpression<Func<>>
as normal lambdasThe existing way of approaching this problem in F# is:
Using normal lambdas
Pros and Cons
The advantages of making this adjustment to F# are : make the syntax consistent
The disadvantages of making this adjustment to F# are : N/A
Extra information
Estimated cost (XS, S, M, L, XL, XXL):
Related suggestions: https://github.com/fsharp/fslang-suggestions/issues/506
Affidavit (please submit!)
Please tick these items by placing a cross in the box:
Please tick all that apply:
For Readers
If you would like to see this issue implemented, please click the :+1: emoji on this issue. These counts are used to generally order the suggestions by engagement.