You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Please tick these items by placing a cross in the box:
This is not a question (e.g. like one you might ask on StackOverflow) and I have searched StackOverflow for discussions of this issue
This is a language change and not purely a tooling change (e.g. compiler bug, editor support, warning/error messages, new warning, non-breaking optimisation) belonging to the compiler and tooling repository
This is not something which has obviously "already been decided" in previous versions of F#. If you're questioning a fundamental design decision that has obviously already been taken (e.g. "Make F# untyped") then please don't submit it
This is not a breaking change to the F# language design
I or my company would be willing to help implement and/or test this
For Readers
If you would like to see this issue implemented, please click the 👍 emoji on this issue. These counts are used to generally order the suggestions by engagement.
I am marking this as approved in principle for preprocessor regularity with C#.
The detailed proposal should enumerate potential impact on commonly used F# tooling, e.g. on Fantomas.
(breaking existing tooling is a disadvantage and it is good to be aware of it)
I propose we add
#elif
to the preprocessor grammar as part of the#if .. #else .. #endif
block.The existing way of approaching this problem in F# is: Nesting another
#if
under#else
.Pros and Cons
The advantages of making this adjustment to F# are: alignment with C# and simpler syntax.
The disadvantages of making this adjustment to F# are: none (well, it's work to implement).
Motivation
F# seems to have
#elif
preprocessor directive / pragma missing:https://learn.microsoft.com/en-us/dotnet/fsharp/language-reference/compiler-directives#preprocessor-directives
C# has it:
https://learn.microsoft.com/en-us/dotnet/csharp/language-reference/preprocessor-directives#conditional-compilation
I know it's not good practice to use lot of these, I'm not trying to do a templating engine, I would just like to do a simple switch like this:
The current workaround:
Extra information
Estimated cost (XS, S, M, L, XL, XXL): S
Related suggestions: #273
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 👍 emoji on this issue. These counts are used to generally order the suggestions by engagement.
Moved from: dotnet/fsharp#17282
The text was updated successfully, but these errors were encountered: