-
-
Notifications
You must be signed in to change notification settings - Fork 261
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add analyzer RCS0062, put expression body on its own line (#1575) #1593
base: main
Are you sure you want to change the base?
Conversation
@dotnet-policy-service agree |
src/Tests/Formatting.Analyzers.Tests/RCS0062PutExpressionBodyOnItsOwnLineTests.cs
Outdated
Show resolved
Hide resolved
89144ec
to
736c1a7
Compare
@josefpihrt So now I tried to add bool option I decided to go with the bool option instead of adding a third value for the |
src/ConfigOptions.xml
Outdated
<Option Id="ExpressionBodyStyleOnNextLine"> | ||
<ValuePlaceholder>true|false</ValuePlaceholder> | ||
<Description>Place expression body always on next/same line</Description> | ||
</Option> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could you please explain why did you add this option? I think that this option is basically the same as checking if analyzer is enabled or not. If you want to decide whether to wrap line before =>
in RCS1016 (as an example) just check if RCS0062 is effective or not.
See extensions methods IsEffective
for DiagnosticDescriptor
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Basically you are right, but I wouldn't know how to use that information in the CodeFixProvider
.
I found usings of DiagnosticDescriptor.IsEffective
only in analyzers. The respective information is then unambiguous via the created diagnostic.
But configuring the behavior of a single diagnostic (RCS1016) in the CodeFixProvider
is always done via AnalyzerConfigOptions
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You can definitely get the information whether an analyzer is effective from CodeFixProvider
. You need a SyntaxTree
, which is property of a node and CompilationOptions
which is a property of a Project
:
DiagnosticRules.ConfigureAwait.IsEffective(
node.SyntaxTree,
context.Document.Project.CompilationOptions,
cancellationToken);
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks! I'm still making my way through to understand what to get from where.
So that would work, but now I would have dependency problems:
Currently, my attempt for the (not yet working) line breaking is in Workspaces.Common.ConvertBlockBodyToExpressionBodyRefactoring
, but the DiagnosticRules
are defined in Formatting.Analyzers
.
To know, how to refactor that, I would need to know, how the actual new line is inserted. My approach doesn't work, yet.
Probably I would need to call the SyntaxNode ConvertBlockBodyToExpressionBodyRefactoring.Refactor(SyntaxNode, AnalyzerConfigOptions)
from somewhere else, then manipulated the new syntax node, and finally replace the node in the document.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could you call IsEffective
from code fix provider and then pass it to ConvertBlockBodyToExpressionBodyRefactoring
as a parameter? Something like bool wrapLineBeforeArrowToken
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That also doesn't work, because the RCS0062 DiagnosticRule is defined in Formatting.Analyzers
, but the caller of ConvertBlockBodyToExpressionBodyRefactoring.RefactorAsync
, which would then have to evaluate the bool, like UseBlockBodyOrExpressionBodyCodeFixProvider
(RCS1016) or ConstructorDeclarationRefactoring
, can't reference that project.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'll move DiagnosticRules to Common project.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@cbersch I moved DiagnosticRules
and DiagnosticIdentifiers
to Roslynator.Common
so now it's accessible from everywhere. Please re-run generate_code.ps1
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Grest, thanks. I'll rework when I'm back from vacaton
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@josefpihrt Now the ConvertBlockBodyToExpressionBodyRefactoring
respects the RCS0062
diagnostic in order to determine if to wrap on a new line or not.
I added only a single test for RCS1016 and RR0169, because the line wrapping itself doesn't work, yet, for these. There I would again need your help.
3fc981e
to
d016f62
Compare
Fixes #1575
Add new analyzer to put an existing expression body on its own line.