-
Notifications
You must be signed in to change notification settings - Fork 205
Add Style Guideline Example for How Braces in Switch Block should be Used #483
Comments
You left the style necessary for complex cases. For example
And here you see my preferred style too. :-) |
Thanks @swngdnz - added to the list 😁 |
This issue has been automatically marked as stale because it has not had activity from the community in the last 30 days. It will be closed if no further activity occurs within 10 days. If the issue is labelled with any of the work labels (e.g bug, enhancement, documentation, or tests) then the issue will not auto-close. |
Bump |
I'm not a fan with enforcing this, as different usage of the switch statement might call for different layout. $value = switch($blah) {
'a' { 'A' }
1 { 'A' }
default { 'B' }
} My point is that we should recommend some format, but probably let the maintainers decide if they want to enforce a way or another in their repository. |
We have the style guideline that says open brace should be in a separate row, so then the code gets stretched out in scenarios like these. I’m always open to style changes if it improves that everyone writes the code the same and supports “easily written” future PSSA rules and auto-formatting. |
I do prefer the more concise layout at @gaelcolas mentioned. But only if there is a single line of code in each block. So perhaps the rule could be "Compact" when only a single line in each block is used. E.g. $value = switch($blah)
{
'a' { 'A' }
1 { 'A' }
default { 'B' }
} And expanded otherwise:
That said, sometimes we use switch blocks when we should possibly have defined an enumeration instead. So that kind of block may be an indicator that some refactoring could be made. I'd suggest thought that this isn't allowed: $value = switch($blah) {
'a' { 'A' }
1 { 'A' }
default { 'B' }
} |
My example was only to illustrate that enforcing is not necessarily better than recommending (though, agreed, it's a 1-line content edge case). As for having one and unique standard across all repositories (for cosmetic changes that don't affect quality), I'd argue that it mainly serves you both (not many people are doing as much work across so many repositories). I also agree that it helps people contributing to multiple repositories, and it should be enforced by the maintainers in any given repository. But it repulses some would-be contributors/maintainers (I had this direct feedback), not in existing repository because people happily comply with established standards, but for new resources they want to share and include in the Resource Kit. In conclusion, I'd say that unless we can configure specific auto-formatting in vscode (aligned with options 1,2,3) and someone to ask for it specifically, I'm happy to have the guidelines updated and enforced with option 2 and 3 only as suggested by @PlagueHO. Should we bring this update to next Community call? |
I’m not sure we can ask the repositories outside of DSC Resource Kit that they must enforce the formatting guidelines. I know we say they should follow the guidelines, but that should be just that, a guideline. Maybe they can just run there own guideline which overrides the “central” one. But repos owned by the PowerShell GitHub account I think should enforce the guideline for all PRs. |
There is currently no example of how braces in a switch block should look.
Options:
1.
@mhendric, @johlju - your thoughts? Should we add this and what is the preferred method. I've used 2, but only because I assumed that was covered - which it isn't. I'm good with either way.
I think 2 is easier to enforce because 1 will result in two styles potentially:
1.
and
1.
What is everyone's thoughts?
The text was updated successfully, but these errors were encountered: