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
I might be in a minority for that, but i think dotnet format should not populate missing switch branches with throw new NotImplementedException(). Scenario:
Even though there is TasksSortBy.Unspecified - this code is just fine, since we have the wildcard _ in the place to handle it. But i still want to keep the diagnostic to avoid missing enum values that are "real". So the diagnostic is fine, maybe Unspecified is too much (but it's a good practise from gRPC protocol, so we are using it there). My issue is with the automatic fix. After running the dotnet format i ended up with:
which for me it is outright dangerous. Fortunately for us - the integration test suite quickly caught the issue in CI pipeline, but the developer did not check the code after running the dotnet format (which is understandable, it should be just format). In this case format command changed the code behaviour. I'm opening this thread to figure out if more people think like me here :).
To be clear - the "solution" isn't that clear either, but from my perspective it would be better if dotnet format left the code "uncompilable" at this point. So:
query=tasksSortByswitch{TasksSortBy.Name=>query.OrderBy(e =>e.Name),TasksSortBy.Completed=>query.OrderBy(e =>e.Completed),TasksSortBy.Unspecified=>// TODO : implement that
_ =>query.OrderBy(e =>e.CreatedAt)};
is much better, since it's forcing the developer to implement the missing branch. What do you all think about that?
The text was updated successfully, but these errors were encountered:
jakoss
changed the title
Automatic fix for IDE0072 is wrong
Automatic fix for IDE0072 is changing code behaviour
Nov 21, 2024
I might be in a minority for that, but i think
dotnet format
should not populate missing switch branches withthrow new NotImplementedException()
. Scenario:I had this code in codebase:
Even though there is TasksSortBy.Unspecified - this code is just fine, since we have the wildcard
_
in the place to handle it. But i still want to keep the diagnostic to avoid missing enum values that are "real". So the diagnostic is fine, maybe Unspecified is too much (but it's a good practise from gRPC protocol, so we are using it there). My issue is with the automatic fix. After running thedotnet format
i ended up with:which for me it is outright dangerous. Fortunately for us - the integration test suite quickly caught the issue in CI pipeline, but the developer did not check the code after running the
dotnet format
(which is understandable, it should be just format). In this caseformat
command changed the code behaviour. I'm opening this thread to figure out if more people think like me here :).To be clear - the "solution" isn't that clear either, but from my perspective it would be better if
dotnet format
left the code "uncompilable" at this point. So:is much better, since it's forcing the developer to implement the missing branch. What do you all think about that?
The text was updated successfully, but these errors were encountered: