!XM?      !"#$%&'()*+,-./0123456789:;<=>GNone?@ANoneBhlintA comment as a string.Chlint+The comment string with delimiters removed.BCDEFGHINone=>?@AJhlintLIs this item lexically requiring no bracketing ever i.e. is totally atomic.KhlintlIs the child safe free from brackets in the parent position. Err on the side of caution, True = don't know.LMNOPQJKNoneRNone %=>?HVX ShlintAReturn the variables, erring on the side of more free variables.ThlintAReturn the variables, erring on the side of more free variables. USVTWXYZ[\]^None$_hlint declName xQ returns the "new name" that is created (for example a function declaration) by x. If xV isn't a declaration that creates a new name (for example an instance declaration), ` is returned instead. This is useful because we don't want to tell users to rename binders that they aren't creating right now and therefore usually cannot change.abc_de None<OPQJKfgh SafeihlintParse a GHC extensioni None@jk Nonel None=>?@AOPQJKmnopqrstuvNoneUwxyzNone%M{|}~NoneMNone%=?@AjNone %=>?@AHPVhlint'dotApp a b' makes 'a . b'.hlint'paren e' wraps e in parens if e is non-atomic.OPQJKNone>      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~None>P0hlintnLike needBracket, but with a special case for a . b . b, which was removed from haskell-src-exts-util-0.2.2hlintHDescend, and if something changes then add/remove brackets appropriatelyhlint/This extension implies the following extensionshlint5This extension is implied by the following extensionshlint;(a, bs) means extension a implies all of bs. Taken from  Xhttps://downloads.haskell.org/~ghc/master/users-guide/glasgow_exts.html#language-options/ In the GHC source at DynFlags.impliedXFlagsiNoneM7O hlintMData type representing the modules in scope within a module. Created with   and queried with  scopeMatch and  scopeMove. 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.   None%=?@A9 hlintQfromNamed will return "" when it cannot be represented toNamed may crash on ""  Safe9None9Safe: !"#$None:h%&'(NoneESX>)hlintTExtensions we turn on by default when parsing. Aim to parse as many files as we can.*hlintExtensions we turn on when reading config files, don't have to deal with the whole world of variations - in particular, we might require spaces in some places.+,-./0)*None%>MX@1hlint(Unification, obeys the property that if  unify a b = s, then substitute s a = b.23456NoneAh7BCDEFGHIOPQJKRUSVTWXYZ[\]^abc_defghijklmnopqrstuvwxyz{|}~2345689:None%>P[Mhlint 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!Ahlint6The error handler invoked when GHC parsing has failed.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.BhlintUGiven a line number, and some source code, put bird ticks around the appropriate bit.      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~CDEFGHIJKLMN    OPQRS ;<TUVWX=YZNoneo[hlintHDon't crash in case ghc gives us a "fake" span, opting instead to show 0 0 0 0 coordinates.\][^ None%r _hlintGenerate a lambda, but prettier (if possible). Generally no lambda is good, but removing just some arguments isn't so useful._!None`hlintExtra command-line argumentahlintA  LHS ==> RHS style hint rule.bhlintDefault severity for the hint.chlintName for the hint.dhlint(Module scope in which the hint operates.ehlintLHSfhlintRHSghlint)Side condition, typically specified with  where _ = ....hhlintDNotes about application of the hint. We wrap these GHC elements in i in order that we may derive j.khlint9Module scope in which the hint operates (GHC parse tree).lhlintLHS (GHC parse tree).mhlintRHS (GHC parse tree).nhlint Side condition (GHC parse tree).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.@opqrs`tuvwxyz{|}~abcdefghklmn"! "None"#>ehlintGuess why a theorem is missing#None"# #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+"! #$,+(%&')*-$None"#Mhlint$Returns the number of failing tests.%None4hlint:Given a set of hints, do all the HintRule hints type checkhlintBGiven a set of hints, do all the HintRule hints satisfy QuickCheck&None"#%Xihlint,First string may have stars in it (the want)'None"#(None"#;hlint Print an * with trailing null-terminator and newlineHThe trailing newline will be ignored, but makes the output more readablehlintConvert an hlint #, to a datatype more easily serialized for CC)None.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 V values.      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~CDEFGHIJKLMN    OPQRS ;<TUVWX=YZ\][^"! #$,+(%&')*-.*None:+None%>,None%-None$hlintwGiven 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.hlintGChecks 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.hlintThe "Bang" here refers to , which notably also includes UNPACK pragmas!.None%>/None%>ΊhlintARewrite 'do ...; x <- return y; ...' as 'do ...; let x = y; ...'.0None"#%1None%>(2None%k3None"#X4NoneXhlint+Classes that can't require newtype derivinghlint>Classes that can appear as stock, and can't appear as anyclass5NoneHVL6None>XhlintThe 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 find7NoneP8None%>HVX9None:None"#HV_`օ;None"#$%>PXhlint7A list of root expressions, with their associated names<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 a into a ..hlintTransform a list of a into a .. .=None"#%MPhlintRead 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%PXhlint@Given a module containing HLint settings information return the  rules and the a| 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.?None@None"#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.ANonehlintDApply 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.BNone"#%5CNonepDNone2Pd 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 hints hlintOptions to pass to the refactor executable. hlintPath to refactor tool hlinta proof script to check against hlint'temporary directory to put the files in hlintWhen 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 stdin6    !"  #$%&'(ENone"#)FNone"#/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"#A 0hlint1Get the Cabal configured data directory of HLint.1hlint'The function produces a tuple containg  (for  ), and  and . for 6C. It approximates the normal HLint configuration steps, roughly: Use 5 with 4+ to find and load the HLint settings files.Use  and 2 to transform the outputs of 5.If you want to do anything custom (e.g. using a different data directory, storing intermediate outputs, loading hints from a database) you are expected to copy and paste this function, then change it to your needs.2hlint]The identity function. In previous versions of HLint this function was useful. Now, it isn't.3hlint A version of 1 which respects some of the arguments supported by HLint. If arguments unrecognised by HLint are used it will result in an error. Arguments which have no representation in the return type are silently ignored.4hlintGiven a directory (or ` to imply 0), and a module name (e.g.  HLint.Defaulto), find the settings file associated with it, returning the name of the file, and (optionally) the contents.9This function looks for all settings files starting with HLint.U in the directory argument, and all other files relative to the current directory.5hlint-Given a function to load a module (typically 4.), and a module to start from (defaults to  hlint.yaml/) find the information from all settings files.+hlintSplit a list of o0 for separate use in parsing and hint resolution6hlint*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 6 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).,hlintISnippet from the documentation, if this changes, update the documentation7hlint Create a N from GHC annotations and module tree. Note that any hints that work on the haskell-src-extsn won't work. It is assumed the incoming parse module has not been adjusted to account for operator fixities.8 "! #$,+(%&')*-./012345678/6#$,+(%&')*-"! 01354.27 GNoneC8 "! #$,+(%&')*-./01234567NoneM8hlintA 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:;"! -HIIJKLMMNOPQRSTUV!W!W!X!Y!Z![!\!]!^!_!`!a!\!b!c!d!e!f#####g#h#i#j#k#l#m#n#o)pFqrstuvwxydqz{|}~       !"#$%&'()*+,-./0123456778899::;<<=>=?@A@B@C@D@E@F@G@H@I@J@K@L@M@N@O@P@Q@R@S@T@U@V@W@X@Y@Z@[@\@]@^@_@`@a@b@c@d@e@f@g@h@i@j@k@l@m@n@o@p@q@r@s@t@u@v@w@x@y@z@{@|@}@~@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOOPQRSTUVWXYZ[\]^_`abcdefghijkklmnnoopqrstuuvwxyz{{|}~      !"#$$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrsttuvvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123445566789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefgefhefiefjefkeflefmefnefoepqeprepsHtuvwxyz{|}~ !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!""###################$$$$$$$$%%&&'(((.))))p)))))*+,----.//01234445667899:;;<<<t<====>>> > > ? @ AAAxAAAABCDDDDDDDDDDD D!D"D#D$D%D&D'D(D)D*D+D,D-D.D/D0D1D2D3D4D5D6D7D8D9D:D;D<D=D>D?D@DADBDCDDDEDFDGDHDIDJDKELFMNOP#hlint-2.2.11-IVhWwRnySKEIeDZxJSOugzLanguage.Haskell.HLint4Language.Haskell.HLint EmbedDataGHC.Util.ApiAnnotationGHC.Util.BracketsGHC.Util.DynFlagsGHC.Util.FreeVarsGHC.Util.HsDeclGHC.Util.HsType GHC.Util.LanguageExtensions.TypeGHC.Util.ModuleGHC.Util.Outputable GHC.Util.PatGHC.Util.RdrNameGHC.Util.ScopeGHC.Util.SrcLoc GHC.Util.ViewGHC.Util.HsExprHSE.TypeHSE.Util HSE.Scope HSE.MatchHsColourParallel Paths_hlintTimingUtilGHC.Util.UnifyGHC.UtilHSE.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 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$fOrdSuggestion hlintYaml defaultYamlreportTemplatecomment commentTextisCommentMultilinepragmasflagslangExtsmkFlags mkLangExtsisAtom' needBracket'0ghc-lib-parser-ex-8.8.5.1-DYvDSj7KexX3UHZFQ29281+Language.Haskell.GhclibParserEx.GHC.Hs.ExprisAnyAppisOpAppisApp Brackets' remParen' addParen' baseDynFlags freeVars'allVars' FreeVars'AllVars'Vars'bound'free'vars'varss'pvars' freeVarSet'declNamebase GHC.MaybeNothing isNewType'isForD' isDerivD'bindName isClsDefSig' fromTyParen'isTyQuasiQuote'isUnboxedTuple' readExtensionmodNamefromModuleName'unsafePrettyPrint patToStr' strToPat' fromPChar'hasPFieldsDotDot'isPFieldWildcard' isPWildCard' isPFieldPun' isPatTypeSig' isPBangPat' isPViewPat' rdrNameStr' isSpecial'unqual' fromQual'Scope' scopeCreate' scopeImports' scopeMatch' scopeMove'SrcSpanD stripLocs' LamConst1'App2'PApp_'PVar_'Var_'View'view' fromParen' fromPParen'dotApp'paren'dotApps'universeParentExp'apps' fromApps' universeApps'transformAppsM' rebracket1' appsBracket' simplifyExp' niceDotApp' niceLambda'replaceBranches'needBracketOld'transformBracketOld'descendBracketOld'reduce'reduce1' fromParen1'.haskell-src-exts-1.23.0-IvjfjJasXCo89gWhp1TrsKLanguage.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 LeftArrowTailRightArrowTailLeftDblArrowTailRightDblArrowTailOpenArrowBracketCloseArrowBracket THExpQuote THTExpQuote THPatQuote THDecQuote THTypQuote THCloseQuote THTCloseQuote THIdEscape THParenEscape THTIdEscapeTHTParenEscape 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 parseWithModeparseWithComments ParseResultParseOk 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 InfixDecl TSpliceDeclForImpForExpRulePragmaDeclDeprPragmaDeclWarnPragmaDeclInlineConlikeSig 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 UnkindedVarKindFunDepContextCxSingleCxTupleCxEmptyAsstTypeAIParamParenALiteralStringCharIntFracPrimIntPrimWord PrimFloat PrimDoublePrimChar PrimStringSignSignlessNegativeExpVarConIfAppLitLetCaseListCompNegAppTupleOverloadedLabelIPVarInfixAppLambdaMultiIfDoMDo UnboxedSum TupleSectionListParArrayParen LeftSection RightSection RecConstr RecUpdateEnumFrom EnumFromTo EnumFromThenEnumFromThenToParArrayFromToParArrayFromThenToParComp ParArrayComp ExpTypeSigVarQuoteTypQuote BracketExp SpliceExp QuasiQuoteTypeAppXTagXETagXPcdataXExpTag XChildTag CorePragma SCCPragma GenPragmaProc LeftArrApp RightArrAppLeftArrHighAppRightArrHighAppArrOpLCaseXNameXDomNameXAttrBracket ExpBracket TExpBracket PatBracket TypeBracket DeclBracketSpliceIdSplice TIdSplice ParenSplice TParenSpliceSafetyPlaySafePlayInterruptible 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 srcSpanStartnoLocSrcLoc 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 ViewPatternsGADTsNPlusKPatternsDoAndIfThenElseBlockArgumentsRebindableSyntaxConstraintKinds PolyKinds DataKinds InstanceSigsStandaloneDerivingDeriveDataTypeable DeriveFunctorDeriveTraversableDeriveFoldable DeriveGenericDefaultSignaturesDeriveAnyClassDerivingStrategies DerivingViaTypeSynonymInstancesFlexibleContextsFlexibleInstancesConstrainedClassMethodsMultiParamTypeClassesFunctionalDependencies UnicodeSyntaxExistentialQuantification MagicHashEmptyDataDeclsKindSignaturesRoleAnnotationsParallelListCompTransformListCompGeneralizedNewtypeDeriving RecursiveDoPostfixOperators TupleSections PatternGuardsLiberalTypeSynonyms RankNTypesImpredicativeTypes TypeOperatorsExplicitNamespacesPackageImportsExplicitForAllDatatypeContextsNondecreasingIndentation LambdaCase MultiWayIfBinaryLiteralsOverloadedLabels EmptyCasePatternSynonymsPartialTypeSignaturesNamedWildCardsTypeApplications StrictDataQuantifiedConstraintsSafeDoRec 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 TransformerPat_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 isSection isPrimLiteralallowRightSectionallowLeftSectionunqualfromQual isSpecialisDolisDotisDotAppdotAppdotAppsisReturnisLexeme isAssocLeft isAssocNoneisWHNFtransformBracketOld descendIndex getEquations toFunBindreplaceBranchesappsfromAppsfromAppsWithLoc childrenApps descendApps descendAppsM universeApps transformAppstransformAppsM universeS childrenSuniverseParentExp showSrcLocandropAnn/=~=elem_notElem_nub_delete_ intersect_neqListeqListeqMaybe getFixity toInfixDeclScope scopeCreateGHC.Basemempty scopeImportsNamed fromNamedtoNamedVar_PVar_App2Viewview~=isSymhsColourConsole hsColourHTMLparallelversion getBinDir getLibDir getDynLibDir getDataDir getLibexecDir getSysconfDirgetDataFileNametimedtimedIO startTimings printTimingsparseExtensionsconfigExtensions forceList exitMessageexitMessageImpuregetContentsUTF8gzipuniverseParentBiunify'Subst' fromSubst' validSubst' substitute' unifyExp'(Language.Haskell.GhclibParserEx.DynFlagsparsePragmasIntoDynFlagsparseExpGhcLibparseImportGhcLibparseFileGhcLibghcSrcLocToHSE ghcSpanToHSE ghcCommentsmkModehseFailOpParseModuleExfailOpParseModuleExghcFailOpParseModuleExcontext2haskell-src-exts-util-0.2.5-2GiKnKemKZCBvsKirqywzYLanguage.Haskell.Exts.Bracket appsBracket rebracket1transformBracketparenBracketsremParenaddParenisAtom needBracketLanguage.Haskell.Exts.FreeVarsAllVarsallVarsFreeVarsghcAnnotations ghcModule hseModule hseCommentsvarsvarsspvarsfreeVarsparseFlagsSetLanguageparseExpGhcWithModeparseImportDeclGhcWithMode toSrcSpan'toRefactSrcSpantoSStoSS' niceLambdaRSettingArgumentHintRulehintRuleSeverity hintRuleName hintRuleScope hintRuleLHS hintRuleRHS hintRuleSide hintRuleNotes6Language.Haskell.GhclibParserEx.GHC.Hs.ExtendInstancesHsExtendInstancesGHC.ShowShowhintRuleGhcScopehintRuleGhcLHShintRuleGhcRHShintRuleGhcSideSettingInfixSettingClassifySettingMatchExpSettingRestrict SettingSmellBuiltin SmellTypeSmellLongFunctionsSmellLongTypeListsSmellManyArgFunctionsSmellManyImportsRestrict restrictTyperestrictDefault restrictName restrictAsrestrictWithinrestrictBadIdentsrestrictMessage RestrictTypeRestrictModuleRestrictExtension RestrictFlagRestrictFunction getSeveritygetRestrictTypedefaultHintName isUnifyVar showNotes getSmellTypeclassifyMissingproof showIdeasJsonshowANSIrawIdearawIdea'rawIdeaN rawIdeaN'ideaidea'suggestsuggest'warnwarn'ignoreNoSuggestion'ignoreignore'suggestN suggestN'ignoreNignoreN' withTestsTestaddIdeasgetIdeasprogresspassedfailedtested testTypeChecktestQuickCheck matchStartestInputOutput writeReport printIssueIssuefromIdeaMonoid hintModules hintModule hintDecl'hintDecl CrossHintModuHint DeclHint'DeclHint unsafeHint pragmaHint patternHintsingleSimpleField simpleCons dropConsBang4ghc-lib-parser-8.8.2.20200205-FYvk4aUArajAwkHF90NG4NDataCon HsSrcBang newtypeHint namingHintmonadLet monadHint listRecHintlistHint lambdaHint importHintnoDeriveNewtype deriveStockextensionsHint exportHintDupe duplicateHint commentHint bracketHintsmellModuleHint smellHint restrictHint findDecls' 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 cmdIgnoreGlob cmdPattern cmdQuickCheck cmdTypeCheckgetCmd exitWithHelp cmdExtensionscmdCpptestreadAllSettings splitSettings_docs