!FH`?      !"#$%&'()*+,-./0123456789:;<=>8None$HVW?hlintAdjust the input @ to take into account language extensions to explicitly enable/disable as well as language extensions enabled by pragma in the source.Ahlint'isAtom e' if e requires no bracketing ever.Bhlint'addParen e' wraps e in parens.Chlint'paren e' wraps e in parens if e is non-atomic.Dhlint 'isApp e' if e is a (regular) application.Ehlint'isOpApp e' if e is an operator application.Fhlint'isAnyApp e' if e3 is either an application or operator application.Ghlint'isDot e' if e is the unqualifed variable H.Ihlint'isSection e' if e is a section.Jhlint'isForD d' if d is a foreign declaration.Khlint'isDotApp e' if e is dot application.LhlintParse a GHC extensionMhlintAccess to a comment's text.Nhlint6Test if two AST elements are equal modulo annotations.OhlintFCompare two 'Maybe (Located a)' values for equality modulo locations.PQRSTUVW?XABCDEFGIJKLMYZ[O\]^_NoneA`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRNone>P)ShlintnLike needBracket, but with a special case for a . b . b, which was removed from haskell-src-exts-util-0.2.2ThlintHDescend, and if something changes then add/remove brackets appropriatelyUhlint/This extension implies the following extensionsVhlint5This extension is implied by the following extensionsWhlint;(a, bs) means extension a implies all of bs. Taken from Xhttps://downloads.haskell.org/~ghc/master/users-guide/glasgow_exts.html#language-optionsiXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~STUVWNone%M4hlintMData type representing the modules in scope within a module. Created with  and queried with  and . Note that the   is not equivalent to 6 on an empty module, due to the implicit import of Prelude.hlint Create a 3 value from a module, based on the modules imports.hlinthGiven a two names in scopes, could they possibly refer to the same thing. This property is reflexive.hlintGiven a name in a scope, and a new scope, create a name for the new scope that will refer to the same thing. If the resulting name is ambiguous, it picks a plausible candidate.None%=?@A6hlintQfromNamed will return "" when it cannot be represented toNamed may crash on ""None%73 Safe7v None7 Safe7 None8O NoneESX8None%>WS!hlint Result of , representing a parsed module.hlintA parse error.hlintLocation of the error.hlint%Message about the cause of the error.hlint3Snippet of several lines (typically 5) including a >' character pointing at the faulty line.hlint Created with  , used by .hlint*How the file is preprocessed (defaults to  ). hlint8How the file is parsed (defaults to all fixities in the base. package and most non-conflicting extensions). hlint$What C pre processor should be used. hlintNo pre processing is done. hlintLines prefixed with # are stripped. hlintThe cpphs library is used.hlint0Convert a GHC source loc into an HSE equivalent.hlint1Convert a GHC source span into an HSE equivalent.hlintDefault value for .hlint:Given some fixities, add them to the existing fixities in .hlint4Extract a list of all of a parsed module's comments.hlintUtility called from  and .hlint>Error handler dispatcher. Invoked when HSE parsing has failed.hlintiAn error handler of last resort. This is invoked when HSE parsing has failed but apparently GHC has not!hlint6The error handler invoked when GHC parsing has failed.hlintProduce a pair of lists from a F value representing language extensions to explicitly enable/disable.hlintParse a Haskell module. Applies the C pre processor, and uses best-guess fixity resolution if there are ambiguities. The filename - is treated as stdin. Requires some flags (often k), the filename, and optionally the contents of that file. This version uses both hs-src-exts AND ghc-lib.hlintUGiven a line number, and some source code, put bird ticks around the appropriate bit.X`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~STUVW NoneWgm hlintHDon't crash in case ghc gives us a "fake" span, opting instead to show 0 0 0 0 coordinates.    None%k hlintGenerate a lambda, but prettier (if possible). Generally no lambda is good, but removing just some arguments isn't so useful.hlint{Convert expressions which have redundant junk in them away. Mainly so that later stages can match on fewer alternatives. NonehlintExtra command-line argumenthlintA  LHS ==> RHS style hint rule.hlintDefault severity for the hint.hlintName for the hint.hlint(Module scope in which the hint operates.hlintLHShlintRHShlint)Side condition, typically specified with  where _ = ....hlint$Notes about application of the hint.hlintHow to classify an Idea. If any matching field is "" then it matches everything.hlintSeverity to set the Idea to.hlint Match on Idea field ideaHint.hlint Match on Idea field  ideaModule.hlint Match on Idea field ideaDecl.hlint0A note describing the impact of the replacement.hlint=The replacement is increases laziness, for example replacing reverse (reverse x) with x makes the code lazier.hlint=The replacement is decreases laziness, for example replacing (fst x, snd x) with x makes the code stricter.hlint6The replacement removes errors, for example replacing  foldr1 (+) with sum removes an error on [], and might contain the text "on []".hlintIThe replacement assumes standard type class lemmas, a hint with the note ValidInstance "Eq" "x" might only be valid if the x variable has a reflexive Eq instance.hlint8The replacement requires this extension to be available.hlintAn arbitrary note.hlintHow severe an issue is.hlintGThe issue has been explicitly ignored and will usually be hidden (pass --show+ on the command line to see ignored ideas). hlintTSuggestions are things that some people may consider improvements, but some may not.!hlintEWarnings are suggestions that are nearly always a good idea to apply."hlint$Available as a setting for the user.: !"#$%&'()*+,-./01"! 234567None"#>8hlintGuess why a theorem is missing9None"#WL #hlintAn idea suggest by a Hint.%hlint1The modules the idea is for, usually a singleton.&hlintkThe declarations the idea is for, usually a singleton, typically the function name, but may be a type name.'hlintThe severity of the idea, e.g. !.(hlint3The name of the hint that generated the idea, e.g.  "Use reverse".)hlint$The source code the idea relates to.*hlint4The contents of the source code the idea relates to.+hlintThe suggested replacement, or :+ for no replacement (e.g. on parse errors).,hlint3Notes about the effect of applying the replacement.-hlintHow to perform this idea("! 6#$,(%&')*+-;<=>?@ABCDEFGHIJNone"#MKhlint$Returns the number of failing tests.LKMNOPQRNonelShlint:Given a set of hints, do all the HintRule hints type checkThlintBGiven a set of hints, do all the HintRule hints satisfy QuickCheckSTNone"#%XUhlint,First string may have stars in it (the want)VNone"#WNone"#sXhlint Print an Y* with trailing null-terminator and newlineHThe trailing newline will be ignored, but makes the output more readableZhlintConvert an hlint #, to a datatype more easily serialized for CCXZNoneW.hlint0Functions to generate hints, combined using the [ instance.\hlintDGiven a list of modules (and their scope information) generate some #s.]hlint>Given a single module and its scope information generate some #s.^hlint<Given a declaration (with a module and scope) generate some #[s. This function will be partially applied with one module/scope, then used on multiple   values.X`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~STUVW     "! 6#$,(%&')*+-;<=>?@ABCDEFGHIJ._\]`^abcdNonebeNone%>fNone%gNone$WhhlintwGiven a declaration, returns the suggested "newtype"ized declaration following these guidelines: * Types ending in a "Q\" are __ignored__, because they are usually unboxed primitives - @data X = X Int * ExistentialQuantification stuff is ignored - data X = forall t. X t1 * Constructors with (nonempty) constraints are ignored - data X a = (Eq a) => X a- * Single field constructors get newtyped - data X = X Int -> newtype X = X Int4 * Single record field constructors get newtyped - data X = X {getX :: Int} -> Cnewtype X = X {getX :: Int}@ * All other declarations are ignored.ihlintGChecks whether its argument is a "simple constructor" (see criteria in singleSimpleFieldNew^) returning the type inside the constructor if it is. This is needed for strictness analysis.jhlintThe "Bang" here refers to k, which notably also includes UNPACK pragmas!lNone%>WUmNone%>nhlint do ...; x  -return y; ... == do ...; let x = y; ...ohlintMatch return x to Just x.p None%aq!None%>Ŭr"None%s#None"#WXRt$NoneXʱuhlint+Classes that can't require newtype derivingvhlint>Classes that can appear as stock, and can't appear as anyclasswhlint0What is derived on newtype, and on data type  'deriving'J declarations may be on either, so we approximate as both newtype and datax%NoneWy&NoneX͵zhlintThe position to return if we match at this point, and the map of where to go next If two runs have the same vals, always use the first pos you find{'NoneW|(None%XK})None%Ύ~*None"#+None%>MX}hlintCA list of substitutions. A key may be duplicated, you need to call check( to ensure the substitution is valid.hlintUnpack the substitutionhlintPerform a substitutionhlint(Unification, obeys the property that if  unify a b = s, then substitute s a = b.,None"#%>X-None؂hlintWA list of the builtin hints wired into HLint. This list is likely to grow over time.hlint=A list of builtin hints, currently including entries such as "List" and  "Bracket".hlintTransform a list of  or  into a ..hlintTransform a list of  into a .. ._\]`^bd.None"#%MPܑhlintRead a config file in YAML format. Takes a filename, and optionally the contents. Fails if the YAML doesn't parse or isn't valid HLint YAMLhlintBFailed when parsing some value, give an informative error message./None%PWXhlint@Given a module containing HLint settings information return the  rules and the | expressions. Any fixity declarations will be discarded, but any other unrecognised elements will result in an exception.hlint Read an {- ANN }-} pragma and determine if it is intended for HLint. Return Nothing if it is not an HLint pragma, otherwise what it means.0None1None"#hlintGiven a source file, guess some hints that might apply. Returns the text of the hints (if you want to save it down) along with the settings to be used.2NoneWhlintDApply hints to a single file, you may have the contents of the file.hlintAApply hints to multiple files, allowing cross-file hints to fire.hlint*Given a way of classifying results, and a .1, apply to a set of modules generating a list of # s. The #& values will be ordered within a file.9Given a set of modules, it may be faster to pass each to  in a singleton list. When given multiple modules at once this function attempts to find hints between modules, which is slower and often pointless (by default HLint passes modules singularly, using --cross to pass all modules together).hlintbGiven a list of settings (a way to classify) and a list of hints, run them over a list of modules.hlintbReturn either an idea (a parse error) or the module. In IO because might call the C pre processor.hlint,Find which hints a list of settings implies.hlintIGiven some settings, make sure the severity field of the Idea is correct.3None"#%C4None~5None2j hlint.which files to run it on, nothing = none givenhlintwhere to generate reportshlint)which settignsfiles were explicitly givenhlint(hints that are given on the command linehlint)groups that are given on the command linehlintuse git ls-files to find fileshlintcolor the resulthlint/Numbmer of threads to use, 0 = whatever GHC hashlintthe hints to ignorehlintdisplay all skipped itemshlint extensionshlint#the extensions (may be prefixed by No)hlintRwork between source files, applies to hints such as duplicate code between moduleshlint!source files to look for hints inhlintthe data directoryhlintPrint a default file to stdouthlintdisplay hint data as JSONhlint(display hint data as Code Climate Issueshlintdo not show the summary infohlintspecify which hints explicitlyhlint%Display hints in serialisation formathlintRun the refactor* executable to automatically perform hintshlintOptions to pass to the refactor executable.hlintPath to refactor toolhlinta proof script to check againsthlint'temporary directory to put the files inhlintWhen to colour terminal output.hlint'Terminal output will never be coloured.hlint(Terminal output will always be coloured.hlintJTerminal output will be coloured if $TERM and stdout appear to support it.hlintWhere should we find the configuration files? * If someone passes cmdWithHints, only look at files they explicitly request * If someone passes an explicit hint name, automatically merge in data/hlint.yaml We want more important hints to go last, since they overridehlint(Determines whether to use colour or not.hlintTemporary filehlint%File to resolve, may be "-" for stdin5 6None"#7None"#P/hlintvThis function takes a list of command line arguments, and returns the given hints. To see a list of arguments type  hlint --helpN at the console. This function writes to the stdout/stderr streams, unless --quiet is specified.As an example: ldo hints <- hlint ["src", "--ignore=Use map","--quiet"] when (length hints > 3) $ error "Too many hints!"Warning: The flags provided by HLint are relatively stable, but do not have the same API stability guarantees as the rest of the strongly-typed API. Do not run this function on your server with untrusted input./None"#]8 "! #$,(%&')*+-./01234567NoneH8hlintA suggestion - the Show instance is of particular use.9hlint|This function takes a list of command line arguments, and returns the given suggestions. To see a list of arguments type  hlint --helpN at the console. This function writes to the stdout/stderr streams, unless --quiet is specified.As an example: ldo hints <- hlint ["src", "--ignore=Use map","--quiet"] when (length hints > 3) $ error "Too many hints!":hlint:From a suggestion, extract the file location it refers to.;hlint.From a suggestion, determine how severe it is. "! 89:; 98:;"! 9::;<=>>?@ABCDEFGHHIJKLMNOPQRMSTUVWXYZ[\]^_`a7bcdefghijUbklmnopqrrstuvwxyz{|}~qqqqqqq      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"##$%&'())*+,-./01223456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abccdefghijklmnopqrstuuvwxyz{|}~IG      !"#$$%&&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKGLMNOPPQQRSTUVWXYZ[\]^_`abcdefghijklmnoopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?=>@=>A=>B=>C=>D=>D=>E=>F=>G=>HIJKIJLIJMIJNIJOIJPIJQIJRIJSIJTIJUIJVIJWIJXIJYIJZIJ[IJ\IJ]IJ^IJ_IJ`IJaIJbIJcIdeIdfIdghijklmnopqrstuvwxyz{|}~vx}yz{                       u  ts    9 !"#$%&'()*+,-./01234566789:;<=>?@"ABCDEFGHzIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijz{klmnaopqrstuvwxyqz{|}~ !"#$$$$%&&'())*++++++,---e-..../////01222i2222345555555555555555555555555555555555555555555555555555567"hlint-2.2.2-ImUPxLbbldCCdIlJRdf798Language.Haskell.HLint4Language.Haskell.HLintGHC.UtilHSE.TypeHSE.Util HSE.Scope HSE.Match HSE.ReduceHsColourParallel Paths_hlintTimingUtilHSE.AllRefact Hint.Util Config.Type Test.ProofIdea Test.UtilTest.TranslateTest.InputOutputReportCC Hint.Type Hint.Unsafe Hint.Pragma Hint.Pattern Hint.NewType Hint.Naming Hint.Monad Hint.ListRec Hint.List Hint.Lambda Hint.ImportHint.Extensions Hint.ExportHint.Duplicate Hint.Comment Hint.Bracket Hint.Smell Hint.Restrict HSE.Unify Hint.MatchHint.All Config.YamlConfig.Haskell Config.ReadConfig.ComputeApplyTest.AnnotationsGrepCmdLineTest.AllHLintLanguage.Haskell.HLint3ModuleEx ParseErrorparseErrorLocationparseErrorMessageparseErrorContents ParseFlagscppFlagshseFlagsCppFlagsNoCpp CppSimpleCpphsdefaultParseFlagsparseFlagsAddFixities parseModuleExClassifyclassifySeverity classifyHintclassifyModule classifyDeclNoteIncreasesLazinessDecreasesLaziness RemovesError ValidInstanceRequiresExtensionSeverityIgnore SuggestionWarningError ideaModuleideaDecl ideaSeverityideaHintideaSpanideaFromideaToideaNoteideaRefactoringHinthlintgetHLintDataDir autoSettings resolveHints argsSettingsreadSettingsFile findSettings applyHintscreateModuleExsuggestionLocationsuggestionSeverity$fShowSuggestion$fEqSuggestion$fOrdSuggestionparsePragmasIntoDynFlags4ghc-lib-parser-8.8.0.20190723-14fBYQ4e3C66NB4eVXQYRgDynFlagsisAtomaddParenparenisAppisOpAppisAnyAppisDotbaseGHC.Base. isSectionisForDisDotApp readExtension commentText=~=eqMaybeLexer getMessages ParseResultPOkPFailedErrUtilspprErrMsgBagWithLocSrcLocLocated OutputableSDoc baseDynFlagsparseFileGhcLibisCommentMultilinedeclNameunsafePrettyPrintnolocunlocgetlocnoext.haskell-src-exts-1.21.0-1MqMUIJU7y29AVS9NHxlR4Language.Haskell.ExtsreadExtensionsparseFileContentsWithCommentsparseFileContentsWithModeparseFileContentsWithExtsparseFileContentsparseFileWithCommentsAndPragmasparseFileWithCommentsparseFileWithModeparseFileWithExts parseFileLanguage.Haskell.Exts.Build metaConPat metaFunctionnameBind patBindWherepatBind simpleFunsfungenNameswildcardnoBindsbindsletStmtgenStmtqualStmtpParenpeListeListlistEaltGWaltcaseEletElamEdoEintPcharPstrPintEcharEstrEfunction pvarTuplevarTuplepTupletuplepAppappFuninfixAppapppvarqvaropvarsymname Language.Haskell.Exts.ExactPrint exactPrintExactPLanguage.Haskell.Exts.ParserunListOf getTopPragmasparseImportDeclWithCommentsparseImportDeclWithModeparseImportDeclparseStmtWithCommentsparseStmtWithMode parseStmtparseTypeWithCommentsparseTypeWithMode parseTypeparseDeclWithCommentsparseDeclWithMode parseDeclparsePatWithCommentsparsePatWithModeparsePatparseExpWithCommentsparseExpWithModeparseExpparseModuleWithCommentsparseModuleWithMode parseModulePragmasAndModuleNamePragmasAndModuleHeadModuleHeadAndImports NonGreedy unNonGreedyListOfLanguage.Haskell.Exts.LexerlexTokenStreamWithModelexTokenStream#Language.Haskell.Exts.InternalLexerTokenEOFAtSCCVarId LabelVarIdQVarId IDupVarId ILinVarIdConIdQConIdDVarIdVarSymConSymQVarSymQConSymIntTokFloatTok Character StringTok IntTokHash WordTokHash FloatTokHash DoubleTokHash CharacterHash StringHash LeftParen RightParen LeftHashParenRightHashParen SemiColon LeftCurly RightCurly VRightCurly LeftSquare RightSquareParArrayLeftSquareParArrayRightSquareComma Underscore BackQuoteDotDotDotColon QuoteColon DoubleColonEquals BackslashBar LeftArrow RightArrowTAppTilde DoubleArrowMinus ExclamationStar LeftArrowTailRightArrowTailLeftDblArrowTailRightDblArrowTail THExpQuote THPatQuote THDecQuote THTypQuote THCloseQuote THIdEscape THParenEscape THVarQuote THTyQuote THQuasiQuote RPGuardOpen RPGuardCloseRPCAt XCodeTagOpen XCodeTagClose XStdTagOpen XStdTagClose XCloseTagOpenXEmptyTagClose XChildTagOpenXPCDATA XRPatOpen XRPatClose PragmaEndRULESINLINEINLINE_CONLIKE SPECIALISESPECIALISE_INLINESOURCE DEPRECATEDWARNING GENERATEDCOREUNPACKNOUNPACKOPTIONSLANGUAGEANNMINIMAL NO_OVERLAPOVERLAP OVERLAPPING OVERLAPPABLEOVERLAPS INCOHERENTCOMPLETEKW_AsKW_ByKW_CaseKW_ClassKW_Data KW_Default KW_DerivingKW_DoKW_MDoKW_Else KW_Family KW_ForallKW_Group KW_HidingKW_If KW_ImportKW_InKW_Infix KW_InfixL KW_InfixR KW_InstanceKW_Let KW_Module KW_NewTypeKW_OfKW_ProcKW_RecKW_RoleKW_ThenKW_TypeKW_UsingKW_Where KW_Qualified KW_PatternKW_Stock KW_AnyclassKW_Via KW_Foreign KW_ExportKW_Safe KW_Unsafe KW_ThreadsafeKW_Interruptible KW_StdCallKW_CCall KW_CPlusPlus KW_DotNetKW_JvmKW_Js KW_JavaScriptKW_CApi Language.Haskell.Exts.ParseMonaddefaultParseModefromParseResult Parseable parseWithModeparseWithCommentsParseOk ParseFailed ParseMode extensions parseFilename baseLanguageignoreLanguagePragmasignoreLinePragmasfixitiesignoreFunctionArityLanguage.Haskell.Exts.CommentsassociateHaddockComment UnknownPragmaLanguage.Haskell.Exts.Fixityinfix_infixl_infixr_ baseFixitiespreludeFixitiesFixity AppFixity applyFixitiesLanguage.Haskell.Exts.PrettyprettyPrimWithMode prettyPrim prettyPrintprettyPrintWithModeprettyPrintStyleMode defaultModePPLayout PPOffsideRule PPSemiColonPPInLine PPNoLayoutIndentPPHsModelayout classIndentdoIndent multiIfIndent caseIndent letIndent whereIndent onsideIndentspacing linePragmasPrettyLanguage.Haskell.Exts.Syntax tuple_tyconunboxed_singleton_tycon list_tycon fun_tycon unit_tycontuple_tycon_nameunboxed_singleton_tycon_namelist_tycon_namefun_tycon_nameunit_tycon_namevia_name anyclass_name stock_name role_name family_name forall_name capi_namejavascript_namejs_namejvm_name dotnet_namecplusplus_name ccall_name stdcall_namethreadsafe_nameinterruptible_name unsafe_name safe_name export_name hole_name star_namedot_name bang_name minus_name hiding_namequalified_nameas_nameunboxed_singleton_con tuple_conunit_conunboxed_singleton_con_namelist_cons_name list_con_nametuple_con_name unit_con_name main_namemain_mod prelude_mod ModuleName SpecialConConsExprHoleUnitConListConFunConTupleConUnboxedSingleConQNameQualUnQualSpecialNameSymbolIdentIPNameIPDupIPLinQOpQVarOpQConOpOpVarOpConOpCNameVarNameConNameModuleXmlPage XmlHybrid ModuleHeadExportSpecList ExportSpecEVarEAbs EThingWithEModuleContents EWildcard NoWildcard Namespace NoNamespace TypeNamespacePatternNamespace ImportDecl importAnn importModuleimportQualified importSrc importSafe importPkgimportAs importSpecsImportSpecList ImportSpecIVarIAbs IThingAll IThingWithAssoc AssocNone AssocLeft AssocRightDeclPatSynTypeSig PatSynSig InlineSigSpecSigFunBindPatBind RoleAnnotDecl DefaultDecl DerivDeclInstDeclDataDecl ClassDecl SpliceDeclTypeDecl TypeFamDeclClosedTypeFamDecl GDataDecl DataFamDecl TypeInsDecl DataInsDecl GDataInsDecl InfixDeclForImpForExpRulePragmaDeclDeprPragmaDeclWarnPragmaDeclInlineConlikeSig SpecInlineSigInstSig AnnPragma MinimalPragmaCompletePragmaPatternSynDirectionUnidirectionalImplicitBidirectionalExplicitBidirectionalTypeEqn AnnotationAnnTypeAnn ModuleAnnBooleanFormula VarFormula AndFormula OrFormula ParenFormulaRoleNominalRepresentationalPhantom RoleWildcard DataOrNewDataTypeNewTypeInjectivityInfo ResultSigKindSigTyVarSigDeclHeadDHeadDHInfixDHParenDHAppInstRuleIRuleIParenInstHeadIHConIHInfixIHParenIHAppDeriving DerivStrategy DerivStock DerivAnyclass DerivNewtypeDerivViaBindsIPBindsBDeclsIPBindMatch InfixMatch QualConDeclConDecl InfixConDeclRecDecl FieldDeclGadtDeclClsDecl ClsDataFamClsTyFamClsTyDef ClsDefSigInsDeclInsTypeInsDataInsGDataBangTypeBangedTyLazyTy NoStrictAnnot UnpackednessUnpackNoUnpackNoUnpackPragmaRhs UnGuardedRhs GuardedRhss GuardedRhsTypeTyConTyVarTyForallTyStarTyFunTyTuple TyUnboxedSumTyList TyParArrayTyAppTyParenTyInfixTyKind TyPromotedTyEqualsTySpliceTyBang TyWildCard TyQuasiQuoteMaybePromotedName PromotedNameUnpromotedNamePromotedPromotedIntegerPromotedString PromotedCon PromotedList PromotedTuple PromotedUnitBoxedUnboxed TyVarBind KindedVar UnkindedVarKindFunDepContextCxSingleCxTupleCxEmptyAsstClassAAppAInfixAIParamEqualPParenA WildCardALiteralStringCharIntFracPrimIntPrimWord PrimFloat PrimDoublePrimChar PrimStringSignSignlessNegativeExpVarConIfAppLitLetCaseListCompNegAppTupleOverloadedLabelIPVarInfixAppLambdaMultiIfDoMDo UnboxedSum TupleSectionListParArrayParen LeftSection RightSection RecConstr RecUpdateEnumFrom EnumFromTo EnumFromThenEnumFromThenToParArrayFromToParArrayFromThenToParComp ParArrayComp ExpTypeSigVarQuoteTypQuote BracketExp SpliceExp QuasiQuoteTypeAppXTagXETagXPcdataXExpTag XChildTag CorePragma SCCPragma GenPragmaProc LeftArrApp RightArrAppLeftArrHighAppRightArrHighAppLCaseXNameXDomNameXAttrBracket ExpBracket PatBracket TypeBracket DeclBracketSpliceIdSplice ParenSpliceSafetyPlaySafePlayInterruptible PlayRiskyCallConvCCallStdCallCApi JavaScript CPlusPlusDotNetJvmJs ModulePragmaLanguagePragma OptionsPragmaAnnModulePragmaToolGHCHUGSNHC98YHCHADDOCK UnknownToolOverlap Overlappable OverlappingOverlaps Incoherent NoOverlap Activation ActiveFrom ActiveUntilRuleRuleVar TypedRuleVar WarningTextDeprTextWarnTextPatPVarPLitPNPlusK PInfixAppPAppPTuple PUnboxedSumPListPParenPRecPAsPat PWildCardPIrrPat PatTypeSigPViewPatPRPatPXTagPXETagPXPcdataPXPatTagPXRPatsPSplice PQuasiQuotePBangPatPXAttrRPatOpRPStarRPStarGRPPlusRPPlusGRPOptRPOptGRPatRPOpRPEitherRPSeqRPGuardRPCAsRPAsRPParenRPPatPatField PFieldPat PFieldPunPFieldWildcardStmtLetStmtRecStmt Generator QualifierQualStmt ThenTransThenByGroupBy GroupUsing GroupByUsing FieldUpdateFieldPun FieldWildcardAlt AnnotatedamapannLanguage.Haskell.Exts.SrcLoc<^^><**<+?><++> combSpanMaybe combSpanInfoinfoSpan noSrcSpan noInfoSpanspanSize isNullSpan mergeSrcSpan mkSrcSpan srcSpanEnd srcSpanStartnoLoc srcFilenamesrcLine srcColumnSrcSpansrcSpanStartLinesrcSpanEndLinesrcSpanFilenamesrcSpanStartColumnsrcSpanEndColumnLocunLoc SrcSpanInfo srcInfoSpan srcInfoPointsSrcInfo toSrcInfo fromSrcInfo getPointLocfileName startLine startColumnLanguage.Haskell.Exts.ExtensiontoExtensionListprettyExtensionparseExtensionclassifyExtensiondeprecatedExtensionsknownExtensions ghcDefault glasgowExts impliesExtsprettyLanguageclassifyLanguageknownLanguagesLanguage Haskell98 Haskell2010HaskellAllDisabledUnknownLanguage ExtensionEnableExtensionDisableExtensionUnknownExtensionKnownExtensionStrictOverlappingInstancesUndecidableInstancesIncoherentInstancesMonomorphismRestriction MonoPatBindsMonoLocalBindsRelaxedPolyRecExtendedDefaultRulesForeignFunctionInterfaceUnliftedFFITypesInterruptibleFFICApiFFIGHCForeignImportPrim JavaScriptFFIParallelArraysArrowsTemplateHaskell QuasiQuotesImplicitParamsImplicitPreludeScopedTypeVariables UnboxedTuples UnboxedSums BangPatterns TypeFamiliesTypeFamilyDependencies TypeInTypeOverloadedStringsDisambiguateRecordFieldsRecordWildCards RecordPuns ViewPatternsGADTsNPlusKPatternsDoAndIfThenElseRebindableSyntaxConstraintKinds PolyKinds DataKinds InstanceSigsStandaloneDerivingDeriveDataTypeable DeriveFunctorDeriveTraversableDeriveFoldable DeriveGenericDefaultSignaturesDeriveAnyClassDerivingStrategies DerivingViaTypeSynonymInstancesFlexibleContextsFlexibleInstancesConstrainedClassMethodsMultiParamTypeClassesFunctionalDependencies UnicodeSyntaxExistentialQuantification MagicHashEmptyDataDeclsKindSignaturesRoleAnnotationsParallelListCompTransformListCompGeneralizedNewtypeDeriving RecursiveDoPostfixOperators TupleSections PatternGuardsLiberalTypeSynonyms RankNTypesImpredicativeTypes TypeOperatorsExplicitNamespacesPackageImportsExplicitForAllDatatypeContextsNondecreasingIndentation LambdaCase MultiWayIfBinaryLiteralsOverloadedLabels EmptyCasePatternSynonymsPartialTypeSignaturesNamedWildCardsTypeApplications StrictDataSafeDoRec Rank2TypesPolymorphicComponentsPatternSignaturesCPPGenericsNamedFieldPunsExtensibleRecordsRestrictedTypeSynonyms HereDocumentsNewQualifiedOperators XmlSyntaxRegularPatterns SafeImports Trustworthypretty-1.1.3.6#Text.PrettyPrint.Annotated.HughesPJModePageMode ZigZagModeLeftMode OneLineModeStylemode lineLengthribbonsPerLinestyle&uniplate-1.6.12-I4v1VEqVnmFIG9gMPOrosd!Data.Generics.Uniplate.OperationsholesBi contextsBi rewriteBiM rewriteBi transformBiM transformBi childrenBi universeBiparaholescontextsrewriteMrewrite transformM transformchildrenuniverseUniplateuniplatedescenddescendMBiplatebiplate descendBi descendBiM$Data.Generics.Uniplate.Internal.Data transformBis transformer TransformerType_Pat_Exp_Decl_Module_SneedBracketOlddescendBracketOldextensionImpliesextensionImpliedByextensionImplications1data-default-class-0.1.2.0-FeIQ5tLoVZBHMSgrT9zptQData.Default.ClassdefellipsesopExpexpOp moduleDecls moduleName moduleImports modulePragmasmoduleExtensionsfromModuleNamefromChar fromPChar fromString fromPString fromParen1 fromParen fromPParen fromTyParen fromTyBangisVarisCon isInfixAppisParenisIfisLambdaisMDoisBoxed isDerivDecl isPBangPat isPFieldPun isFieldPun isPWildCardisPFieldWildcardisFieldWildcard isPViewPat isParComp isTypeApp isPatTypeSig isQuasiQuoteisTyQuasiQuote isSpliceDecl isNewType isRecStmt isClsDefSigisTyBangisLCaseisTupleSectionisString isRecUpdate isRecConstr isPrimLiteralallowRightSectionallowLeftSectionunqualfromQual isSpecialisDoldotAppdotAppsisReturnisLexeme isAssocLeft isAssocNoneisWHNFtransformBracketOld descendIndex getEquations toFunBindreplaceBranchesappsfromAppsfromAppsWithLoc childrenApps descendApps descendAppsM universeApps transformAppstransformAppsM universeS childrenSuniverseParentExp showSrcLocandropAnn/=~=elem_notElem_nub_delete_ intersect_neqListeqList getFixity toInfixDeclScope scopeCreate scopeMatch scopeMovemempty scopeImportsNamed fromNamedtoNamedVar_PVar_PApp_ LamConst1App2Viewview~=isSymreducehsColourConsole hsColourHTMLparallelversion getBinDir getLibDir getDynLibDir getDataDir getLibexecDir getSysconfDirgetDataFileNametimedtimedIO startTimings printTimings forceList exitMessageexitMessageImpuregetContentsUTF8gzipuniverseParentBidefaultExtensionsghcSrcLocToHSE ghcSpanToHSE ghcCommentsmkModehseFailOpParseModuleExfailOpParseModuleExghcFailOpParseModuleExghcExtensionsFromParseFlagscontext2haskell-src-exts-util-0.2.5-AdzmxjhWPND5CE5jVGI4dILanguage.Haskell.Exts.Bracket appsBracket rebracket1transformBracketBracketsremParen needBracketLanguage.Haskell.Exts.FreeVarsAllVarsallVarsFreeVars ghcModule hseModule hseCommentsghcAnnotationsvarsvarsspvarsfreeVarsparseFlagsSetLanguage toSrcSpan'toRefactSrcSpantoSStoSS' niceLambdaR simplifyExp niceLambdaSettingArgumentHintRulehintRuleSeverity hintRuleName hintRuleScope hintRuleLHS hintRuleRHS hintRuleSide hintRuleNotesSettingInfixSettingClassifySettingMatchExpSettingRestrict SettingSmellBuiltin SmellTypeSmellLongFunctionsSmellLongTypeListsSmellManyArgFunctionsSmellManyImportsRestrict restrictTyperestrictDefault restrictName restrictAsrestrictWithin RestrictTypeRestrictModuleRestrictExtension RestrictFlagRestrictFunction getSeveritygetRestrictTypedefaultHintName isUnifyVar showNotes getSmellTypeclassifyMissingproof GHC.MaybeNothing showIdeasJsonshowANSIrawIdearawIdeaNideaidea'suggestsuggest'warnwarn'ignoreNoSuggestion'ignoreignore'suggestN suggestN'ignoreN withTestsTestaddIdeasgetIdeasprogresspassedfailedtested testTypeChecktestQuickCheck matchStartestInputOutput writeReport printIssueIssuefromIdeaMonoid hintModules hintModule hintDecl'hintDecl CrossHintModuHint DeclHint'DeclHint unsafeHint pragmaHint patternHintsingleSimpleField simpleCons dropConsBangDataCon HsSrcBang newtypeHint namingHintmonadLetfromRet monadHint listRecHintlistHint lambdaHint importHintnoDeriveNewtype deriveStockderivesextensionsHint exportHintDupe duplicateHint commentHint bracketHintsmellModuleHint smellHint restrictHintSubst fromSubst substituteunify validSubstunifyExp readMatch HintBuiltin builtinHints hintRulesreadFileConfigYaml parseFail ConfigYamlsettingsFromConfigYaml readSettings readPragmareadFileConfigHaskell readSetting readCommentreadFilesConfigcomputeSettings applyHintFileapplyHintFiles executeHintsparseModuleApplyallHintsclassifytestAnnotationsrunGrepcmdFiles cmdReports cmdGivenHints cmdWithHints cmdWithGroupscmdGitcmdColor cmdThreads cmdIgnore cmdShowAll cmdExtension cmdLanguagecmdCross cmdFindHints cmdDataDir cmdDefaultcmdJsoncmdCC cmdNoSummarycmdOnly cmdSerialise cmdRefactorcmdRefactorOptionscmdWithRefactorcmdProof cmdTempDir ColorModeNeverAlwaysAuto cmdHintFiles cmdUseColour resolveFileCmdCmdMainCmdGrepCmdTestCmdHSEcmdPath cmdCppDefine cmdCppInclude cmdCppFile cmdCppSimple cmdCppAnsi cmdNoExitCode cmdTiming cmdPattern cmdQuickCheck cmdTypeCheckgetCmd exitWithHelp cmdExtensionscmdCpptestreadAllSettings splitSettings_docs