From a283f2bcd24061f257565aee1d2a90e7377ca779 Mon Sep 17 00:00:00 2001 From: webwarrior Date: Tue, 5 Dec 2023 15:10:16 +0100 Subject: [PATCH] SuggestUseAutoProperty: implement fix suggestion Implement quick fix suggestion for the rule. --- .../Rules/Conventions/SuggestUseAutoProperty.fs | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) diff --git a/src/FSharpLint.Core/Rules/Conventions/SuggestUseAutoProperty.fs b/src/FSharpLint.Core/Rules/Conventions/SuggestUseAutoProperty.fs index da7598383..ddf393330 100644 --- a/src/FSharpLint.Core/Rules/Conventions/SuggestUseAutoProperty.fs +++ b/src/FSharpLint.Core/Rules/Conventions/SuggestUseAutoProperty.fs @@ -58,8 +58,8 @@ let private runner (args: AstNodeRuleParams) = false, _attributes, _xmlDoc, - SynValData(Some(memberFlags), _, _), - SynPat.LongIdent (_, _, _, argPats, _, _), + SynValData (Some memberFlags, _, _), + SynPat.LongIdent (memberIdentifier, _, _, argPats, _, _), _returnInfo, expr, _bindingRange, @@ -72,9 +72,19 @@ let private runner (args: AstNodeRuleParams) = | _, SynArgPats.Pats pats when pats.Length > 0 -> // non-property member Array.empty | expression, _ when isImmutableValueExpression args expression -> + let suggestedFix = + lazy + (match memberIdentifier.Lid with + | [ _; memberName ] -> + Some + { FromText = args.FileContent + FromRange = memberIdentifier.Range + ToText = "val " + memberName.idText } + | _ -> None) + { Range = memberRange Message = Resources.GetString "RulesSuggestUseAutoProperty" - SuggestedFix = None + SuggestedFix = Some suggestedFix TypeChecks = List.Empty } |> Array.singleton | _ -> Array.empty