Skip to content
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

Do not check XmlDocs unless required #14156

Merged
merged 7 commits into from
Nov 22, 2022
Merged
Show file tree
Hide file tree
Changes from 6 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 5 additions & 1 deletion src/Compiler/Checking/CheckBasics.fs
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ module internal FSharp.Compiler.CheckBasics

open System.Collections.Generic

open FSharp.Compiler.Diagnostics
open Internal.Utilities.Library
open Internal.Utilities.Library.Extras
open FSharp.Compiler
Expand Down Expand Up @@ -310,6 +311,8 @@ type TcFileState =

isInternalTestSpanStackReferring: bool

diagnosticOptions: FSharpDiagnosticOptions

// forward call
TcPat: WarnOnUpperFlag -> TcFileState -> TcEnv -> PrelimValReprInfo option -> TcPatValFlags -> TcPatLinearEnv -> TType -> SynPat -> (TcPatPhase2Input -> Pattern) * TcPatLinearEnv

Expand All @@ -328,7 +331,7 @@ type TcFileState =

/// Create a new compilation environment
static member Create
(g, isScript, amap, thisCcu, isSig, haveSig, conditionalDefines, tcSink, tcVal, isInternalTestSpanStackReferring,
(g, isScript, amap, thisCcu, isSig, haveSig, conditionalDefines, tcSink, tcVal, isInternalTestSpanStackReferring, diagnosticOptions,
tcPat,
tcSimplePats,
tcSequenceExpressionEntry,
Expand Down Expand Up @@ -358,6 +361,7 @@ type TcFileState =
compilingCanonicalFslibModuleType = (isSig || not haveSig) && g.compilingFSharpCore
conditionalDefines = conditionalDefines
isInternalTestSpanStackReferring = isInternalTestSpanStackReferring
diagnosticOptions = diagnosticOptions
TcPat = tcPat
TcSimplePats = tcSimplePats
TcSequenceExpressionEntry = tcSequenceExpressionEntry
Expand Down
4 changes: 4 additions & 0 deletions src/Compiler/Checking/CheckBasics.fsi
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
module internal FSharp.Compiler.CheckBasics

open System.Collections.Generic
open FSharp.Compiler.Diagnostics
open Internal.Utilities.Library
open FSharp.Compiler.AccessibilityLogic
open FSharp.Compiler.CompilerGlobalState
Expand Down Expand Up @@ -260,6 +261,8 @@ type TcFileState =

isInternalTestSpanStackReferring: bool

diagnosticOptions: FSharpDiagnosticOptions

// forward call
TcPat: WarnOnUpperFlag
-> TcFileState
Expand Down Expand Up @@ -319,6 +322,7 @@ type TcFileState =
tcSink: TcResultsSink *
tcVal: TcValF *
isInternalTestSpanStackReferring: bool *
diagnosticOptions: FSharpDiagnosticOptions *
tcPat: (WarnOnUpperFlag -> TcFileState -> TcEnv -> PrelimValReprInfo option -> TcPatValFlags -> TcPatLinearEnv -> TType -> SynPat -> (TcPatPhase2Input -> Pattern) * TcPatLinearEnv) *
tcSimplePats: (TcFileState -> bool -> CheckConstraints -> TType -> TcEnv -> TcPatLinearEnv -> SynSimplePats -> string list * TcPatLinearEnv) *
tcSequenceExpressionEntry: (TcFileState -> TcEnv -> OverallTy -> UnscopedTyparEnv -> bool * SynExpr -> range -> Expr * UnscopedTyparEnv) *
Expand Down
51 changes: 36 additions & 15 deletions src/Compiler/Checking/CheckDeclarations.fs
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ module internal FSharp.Compiler.CheckDeclarations
open System
open System.Collections.Generic

open FSharp.Compiler.Diagnostics
open Internal.Utilities.Collections
open Internal.Utilities.Library
open Internal.Utilities.Library.Extras
Expand Down Expand Up @@ -455,14 +456,17 @@ module TcRecdUnionAndEnumDeclarations =
let TcAnonFieldDecl cenv env parent tpenv nm (SynField(Attributes attribs, isStatic, idOpt, ty, isMutable, xmldoc, vis, m, _)) =
let mName = m.MakeSynthetic()
let id = match idOpt with None -> mkSynId mName nm | Some id -> id
let xmlDoc = xmldoc.ToXmlDoc(true, Some [])

let checkXmlDocs = cenv.diagnosticOptions.CheckXmlDocs
let xmlDoc = xmldoc.ToXmlDoc(checkXmlDocs, Some [])
TcFieldDecl cenv env parent false tpenv (isStatic, attribs, id, idOpt.IsNone, ty, isMutable, xmlDoc, vis, m)

let TcNamedFieldDecl cenv env parent isIncrClass tpenv (SynField(Attributes attribs, isStatic, id, ty, isMutable, xmldoc, vis, m, _)) =
match id with
| None -> error (Error(FSComp.SR.tcFieldRequiresName(), m))
| Some id ->
let xmlDoc = xmldoc.ToXmlDoc(true, Some [])
let checkXmlDocs = cenv.diagnosticOptions.CheckXmlDocs
let xmlDoc = xmldoc.ToXmlDoc(checkXmlDocs, Some [])
TcFieldDecl cenv env parent isIncrClass tpenv (isStatic, attribs, id, false, ty, isMutable, xmlDoc, vis, m)

let TcNamedFieldDecls cenv env parent isIncrClass tpenv fields =
Expand Down Expand Up @@ -551,7 +555,8 @@ module TcRecdUnionAndEnumDeclarations =
|> Seq.map (fun f -> f.DisplayNameCore)
|> Seq.toList

let xmlDoc = xmldoc.ToXmlDoc(true, Some names)
let checkXmlDocs = cenv.diagnosticOptions.CheckXmlDocs
let xmlDoc = xmldoc.ToXmlDoc(checkXmlDocs, Some names)
Construct.NewUnionCase id rfields recordTy attrs xmlDoc vis

let TcUnionCaseDecls (cenv: cenv) env (parent: ParentRef) (thisTy: TType) (thisTyInst: TypeInst) hasRQAAttribute tpenv unionCases =
Expand All @@ -570,7 +575,8 @@ module TcRecdUnionAndEnumDeclarations =
let vis, _ = ComputeAccessAndCompPath env None m None None parent
let vis = CombineReprAccess parent vis
if id.idText = "value__" then errorR(Error(FSComp.SR.tcNotValidEnumCaseName(), id.idRange))
let xmlDoc = xmldoc.ToXmlDoc(true, Some [])
let checkXmlDocs = cenv.diagnosticOptions.CheckXmlDocs
let xmlDoc = xmldoc.ToXmlDoc(checkXmlDocs, Some [])
Construct.NewRecdField true (Some v) id false thisTy false false [] attrs xmlDoc vis false

let TcEnumDecls (cenv: cenv) env parent thisTy enumCases =
Expand Down Expand Up @@ -2182,7 +2188,9 @@ module TcExceptionDeclarations =
CheckForDuplicateConcreteType env (id.idText + "Exception") id.idRange
CheckForDuplicateConcreteType env id.idText id.idRange
let repr = TExnFresh (Construct.MakeRecdFieldsTable [])
let xmlDoc = xmlDoc.ToXmlDoc(true, Some [])

let checkXmlDocs = cenv.diagnosticOptions.CheckXmlDocs
let xmlDoc = xmlDoc.ToXmlDoc(checkXmlDocs, Some [])
Construct.NewExn cpath id vis repr attrs xmlDoc

let TcExnDefnCore_Phase1G_EstablishRepresentation (cenv: cenv) (env: TcEnv) parent (exnc: Entity) (SynExceptionDefnRepr(_, SynUnionCase(caseType=args), reprIdOpt, _, _, m)) =
Expand Down Expand Up @@ -2516,7 +2524,9 @@ module EstablishTypeDefinitionCores =

let envForDecls, moduleTyAcc = MakeInnerEnv true envInitial id moduleKind
let moduleTy = Construct.NewEmptyModuleOrNamespaceType moduleKind
let xmlDoc = xml.ToXmlDoc(true, Some [])

let checkXmlDocs = cenv.diagnosticOptions.CheckXmlDocs
let xmlDoc = xml.ToXmlDoc(checkXmlDocs, Some [])
let moduleEntity = Construct.NewModuleOrNamespace (Some envInitial.eCompPath) vis id xmlDoc modAttrs (MaybeLazy.Strict moduleTy)
let innerParent = Parent (mkLocalModuleRef moduleEntity)
let innerTypeNames = TypeNamesInMutRecDecls cenv envForDecls decls
Expand Down Expand Up @@ -2584,7 +2594,9 @@ module EstablishTypeDefinitionCores =

patNames
| _ -> []
let xmlDoc = xmlDoc.ToXmlDoc(true, Some paramNames )

let checkXmlDocs = cenv.diagnosticOptions.CheckXmlDocs
let xmlDoc = xmlDoc.ToXmlDoc(checkXmlDocs, Some paramNames )
Construct.NewTycon
(cpath, id.idText, id.idRange, vis, visOfRepr, TyparKind.Type, LazyWithContext.NotLazy checkedTypars,
xmlDoc, preferPostfix, preEstablishedHasDefaultCtor, hasSelfReferentialCtor, lmodTy)
Expand Down Expand Up @@ -4423,7 +4435,9 @@ let rec TcSignatureElementNonMutRec (cenv: cenv) parent typeNames endm (env: TcE
let id = ident (modName, id.idRange)

let moduleTy = Construct.NewEmptyModuleOrNamespaceType moduleKind
let xmlDoc = xml.ToXmlDoc(true, Some [])

let checkXmlDocs = cenv.diagnosticOptions.CheckXmlDocs
let xmlDoc = xml.ToXmlDoc(checkXmlDocs, Some [])
let moduleEntity = Construct.NewModuleOrNamespace (Some env.eCompPath) vis id xmlDoc attribs (MaybeLazy.Strict moduleTy)

let! moduleTy, _ = TcModuleOrNamespaceSignatureElementsNonMutRec cenv (Parent (mkLocalModuleRef moduleEntity)) env (id, moduleKind, moduleDefs, m, xml)
Expand Down Expand Up @@ -4528,8 +4542,9 @@ let rec TcSignatureElementNonMutRec (cenv: cenv) parent typeNames endm (env: TcE
and TcSignatureElements cenv parent endm env xml mutRecNSInfo defs =
cancellable {
// Ensure the .Deref call in UpdateAccModuleOrNamespaceType succeeds
if cenv.compilingCanonicalFslibModuleType then
let xmlDoc = xml.ToXmlDoc(true, Some [])
if cenv.compilingCanonicalFslibModuleType then
let checkXmlDocs = cenv.diagnosticOptions.CheckXmlDocs
let xmlDoc = xml.ToXmlDoc(checkXmlDocs, Some [])
ensureCcuHasModuleOrNamespaceAtPath cenv.thisCcu env.ePath env.eCompPath xmlDoc

let typeNames = EstablishTypeDefinitionCores.TypeNamesInNonMutRecSigDecls defs
Expand Down Expand Up @@ -4755,7 +4770,9 @@ let rec TcModuleOrNamespaceElementNonMutRec (cenv: cenv) parent typeNames scopem
// Create the new module specification to hold the accumulated results of the type of the module
// Also record this in the environment as the accumulator
let moduleTy = Construct.NewEmptyModuleOrNamespaceType moduleKind
let xmlDoc = xml.ToXmlDoc(true, Some [])

let checkXmlDocs = cenv.diagnosticOptions.CheckXmlDocs
let xmlDoc = xml.ToXmlDoc(checkXmlDocs, Some [])
let moduleEntity = Construct.NewModuleOrNamespace (Some env.eCompPath) vis id xmlDoc modAttrs (MaybeLazy.Strict moduleTy)

// Now typecheck.
Expand Down Expand Up @@ -4975,8 +4992,9 @@ and TcMutRecDefsFinish cenv defs m =
and TcModuleOrNamespaceElements cenv parent endm env xml mutRecNSInfo openDecls0 synModuleDecls =
cancellable {
// Ensure the deref_nlpath call in UpdateAccModuleOrNamespaceType succeeds
if cenv.compilingCanonicalFslibModuleType then
let xmlDoc = xml.ToXmlDoc(true, Some [])
if cenv.compilingCanonicalFslibModuleType then
let checkXmlDocs = cenv.diagnosticOptions.CheckXmlDocs
let xmlDoc = xml.ToXmlDoc(checkXmlDocs, Some [])
ensureCcuHasModuleOrNamespaceAtPath cenv.thisCcu env.ePath env.eCompPath xmlDoc

// Collect the type names so we can implicitly add the compilation suffix to module names
Expand Down Expand Up @@ -5202,7 +5220,8 @@ let CheckOneImplFile
isInternalTestSpanStackReferring,
env,
rootSigOpt: ModuleOrNamespaceType option,
synImplFile) =
synImplFile,
diagnosticOptions) =

let (ParsedImplFileInput (_, isScript, qualNameOfFile, scopedPragmas, _, implFileFrags, isLastCompiland, _)) = synImplFile
let infoReader = InfoReader(g, amap)
Expand All @@ -5211,6 +5230,7 @@ let CheckOneImplFile
let cenv =
cenv.Create (g, isScript, amap, thisCcu, false, Option.isSome rootSigOpt,
conditionalDefines, tcSink, (LightweightTcValForUsingInBuildMethodCall g), isInternalTestSpanStackReferring,
diagnosticOptions,
tcPat=TcPat,
tcSimplePats=TcSimplePats,
tcSequenceExpressionEntry=TcSequenceExpressionEntry,
Expand Down Expand Up @@ -5333,12 +5353,13 @@ let CheckOneImplFile


/// Check an entire signature file
let CheckOneSigFile (g, amap, thisCcu, checkForErrors, conditionalDefines, tcSink, isInternalTestSpanStackReferring) tcEnv (sigFile: ParsedSigFileInput) =
let CheckOneSigFile (g, amap, thisCcu, checkForErrors, conditionalDefines, tcSink, isInternalTestSpanStackReferring, diagnosticOptions) tcEnv (sigFile: ParsedSigFileInput) =
cancellable {
let cenv =
cenv.Create
(g, false, amap, thisCcu, true, false, conditionalDefines, tcSink,
(LightweightTcValForUsingInBuildMethodCall g), isInternalTestSpanStackReferring,
diagnosticOptions,
tcPat=TcPat,
tcSimplePats=TcSimplePats,
tcSequenceExpressionEntry=TcSequenceExpressionEntry,
Expand Down
13 changes: 11 additions & 2 deletions src/Compiler/Checking/CheckDeclarations.fsi
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

module internal FSharp.Compiler.CheckDeclarations

open FSharp.Compiler.Diagnostics
open Internal.Utilities.Library
open FSharp.Compiler.CheckBasics
open FSharp.Compiler.CompilerGlobalState
Expand Down Expand Up @@ -58,11 +59,19 @@ val CheckOneImplFile:
bool *
TcEnv *
ModuleOrNamespaceType option *
ParsedImplFileInput ->
ParsedImplFileInput *
FSharpDiagnosticOptions ->
Cancellable<TopAttribs * CheckedImplFile * TcEnv * bool>

val CheckOneSigFile:
TcGlobals * ImportMap * CcuThunk * (unit -> bool) * ConditionalDefines option * TcResultsSink * bool ->
TcGlobals *
ImportMap *
CcuThunk *
(unit -> bool) *
ConditionalDefines option *
TcResultsSink *
bool *
FSharpDiagnosticOptions ->
TcEnv ->
ParsedSigFileInput ->
Cancellable<TcEnv * ModuleOrNamespaceType * bool>
Expand Down
6 changes: 4 additions & 2 deletions src/Compiler/Checking/CheckExpressions.fs
Original file line number Diff line number Diff line change
Expand Up @@ -2430,7 +2430,8 @@ module BindingNormalization =
let (NormalizedBindingPat(pat, rhsExpr, valSynData, typars)) =
NormalizeBindingPattern cenv cenv.nameResolver isObjExprBinding env valSynData headPat (NormalizedBindingRhs ([], retInfo, rhsExpr))
let paramNames = Some valSynData.SynValInfo.ArgNames
let xmlDoc = xmlDoc.ToXmlDoc(true, paramNames)
let checkXmlDocs = cenv.diagnosticOptions.CheckXmlDocs
let xmlDoc = xmlDoc.ToXmlDoc(checkXmlDocs, paramNames)
NormalizedBinding(vis, kind, isInline, isMutable, attrs, xmlDoc, typars, valSynData, pat, rhsExpr, mBinding, debugPoint)

//-------------------------------------------------------------------------
Expand Down Expand Up @@ -12070,7 +12071,8 @@ let TcAndPublishValSpec (cenv: cenv, env, containerInfo: ContainerInfo, declKind
| None -> None
| Some valReprInfo -> Some valReprInfo.ArgNames

let xmlDoc = xmlDoc.ToXmlDoc(true, paramNames)
let checkXmlDocs = cenv.diagnosticOptions.CheckXmlDocs
let xmlDoc = xmlDoc.ToXmlDoc(checkXmlDocs, paramNames)
let vspec = MakeAndPublishVal cenv env (altActualParent, true, declKind, ValNotInRecScope, valscheme, attrs, xmlDoc, literalValue, false)

assert(vspec.InlineInfo = inlineFlag)
Expand Down
5 changes: 4 additions & 1 deletion src/Compiler/Checking/CheckIncrementalClasses.fs
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ module internal FSharp.Compiler.CheckIncrementalClasses

open System

open FSharp.Compiler.Diagnostics
open Internal.Utilities.Collections
open Internal.Utilities.Library
open Internal.Utilities.Library.Extras
Expand Down Expand Up @@ -135,7 +136,9 @@ let TcImplicitCtorLhs_Phase2A(cenv: cenv, env, tpenv, tcref: TyconRef, vis, attr
let varReprInfo = InferGenericArityFromTyScheme prelimTyschemeG prelimValReprInfo
let ctorValScheme = ValScheme(id, prelimTyschemeG, Some varReprInfo, None, Some memberInfo, false, ValInline.Never, NormalVal, vis, false, true, false, false)
let paramNames = varReprInfo.ArgNames
let xmlDoc = xmlDoc.ToXmlDoc(true, Some paramNames)

let checkXmlDocs = cenv.diagnosticOptions.CheckXmlDocs
let xmlDoc = xmlDoc.ToXmlDoc(checkXmlDocs, Some paramNames)
let ctorVal = MakeAndPublishVal cenv env (Parent tcref, false, ModuleOrMemberBinding, ValInRecScope isComplete, ctorValScheme, attribs, xmlDoc, None, false)
ctorValScheme, ctorVal

Expand Down
9 changes: 6 additions & 3 deletions src/Compiler/Driver/ParseAndCheckInputs.fs
Original file line number Diff line number Diff line change
Expand Up @@ -1228,7 +1228,8 @@ let CheckOneInputAux
checkForErrors,
conditionalDefines,
tcSink,
tcConfig.internalTestSpanStackReferring)
tcConfig.internalTestSpanStackReferring,
tcConfig.diagnosticsOptions)
tcState.tcsTcSigEnv
file

Expand Down Expand Up @@ -1306,7 +1307,8 @@ let CheckOneInputAux
tcConfig.internalTestSpanStackReferring,
tcState.tcsTcImplEnv,
rootSigOpt,
file
file,
tcConfig.diagnosticsOptions
)

let tcState =
Expand Down Expand Up @@ -1511,7 +1513,8 @@ let CheckMultipleInputsInParallel
tcConfig.internalTestSpanStackReferring,
tcStateForImplFile.tcsTcImplEnv,
Some rootSig,
file
file,
tcConfig.diagnosticsOptions
)
|> Cancellable.runWithoutCancellation

Expand Down
3 changes: 3 additions & 0 deletions src/Compiler/Facilities/DiagnosticOptions.fs
Original file line number Diff line number Diff line change
Expand Up @@ -31,3 +31,6 @@ type FSharpDiagnosticOptions =
WarnAsError = []
WarnAsWarn = []
}

member x.CheckXmlDocs =
List.contains 3390 x.WarnOn && not (List.contains 3390 x.WarnOff)
T-Gro marked this conversation as resolved.
Show resolved Hide resolved
2 changes: 2 additions & 0 deletions src/Compiler/Facilities/DiagnosticOptions.fsi
Original file line number Diff line number Diff line change
Expand Up @@ -22,3 +22,5 @@ type FSharpDiagnosticOptions =
WarnAsWarn: int list }

static member Default: FSharpDiagnosticOptions

member CheckXmlDocs: bool
11 changes: 11 additions & 0 deletions tests/FSharp.Compiler.ComponentTests/Language/XmlComments.fs
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,17 @@ module M =
"This XML comment is invalid: unknown parameter 'b'");
]

[<Fact>]
let ``diagnostic is not reported when disabled`` () =
Fsx"""
/// <summary> F </summary>
/// <param name="x"> the parameter </param>
let f a = a
"""
|> compile
|> shouldSucceed
|> withDiagnostics []

[<Fact>]
let ``invalid parameter name is reported`` () =
Fsx"""
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2339,10 +2339,12 @@ FSharp.Compiler.Diagnostics.FSharpDiagnosticKind: Int32 Tag
FSharp.Compiler.Diagnostics.FSharpDiagnosticKind: Int32 get_Tag()
FSharp.Compiler.Diagnostics.FSharpDiagnosticKind: System.String ToString()
FSharp.Compiler.Diagnostics.FSharpDiagnosticOptions
FSharp.Compiler.Diagnostics.FSharpDiagnosticOptions: Boolean CheckXmlDocs
FSharp.Compiler.Diagnostics.FSharpDiagnosticOptions: Boolean Equals(FSharp.Compiler.Diagnostics.FSharpDiagnosticOptions)
FSharp.Compiler.Diagnostics.FSharpDiagnosticOptions: Boolean Equals(System.Object)
FSharp.Compiler.Diagnostics.FSharpDiagnosticOptions: Boolean Equals(System.Object, System.Collections.IEqualityComparer)
FSharp.Compiler.Diagnostics.FSharpDiagnosticOptions: Boolean GlobalWarnAsError
FSharp.Compiler.Diagnostics.FSharpDiagnosticOptions: Boolean get_CheckXmlDocs()
FSharp.Compiler.Diagnostics.FSharpDiagnosticOptions: Boolean get_GlobalWarnAsError()
FSharp.Compiler.Diagnostics.FSharpDiagnosticOptions: FSharp.Compiler.Diagnostics.FSharpDiagnosticOptions Default
FSharp.Compiler.Diagnostics.FSharpDiagnosticOptions: FSharp.Compiler.Diagnostics.FSharpDiagnosticOptions get_Default()
Expand Down