!du`      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_5None"`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRNone%>PShlintnLike 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 bsiXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~STUVWNone%M& hlintMData 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%=?@A'hlintQfromNamed will return "" when it cannot be represented toNamed may crash on ""None%(xSafe( None( Safe)= None"#+"hlintXReturns the number of failing tests. Warning: Not multithread safe, but is reenterant None"#%X,chlint,First string may have stars in it (the want) None,NoneESX,None%>=#hlintA parse error from .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.hlintDefault value for  .hlint:Given some fixities, add them to the existing fixities in  .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 :), the filename, and optionally the contents of that file.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 NoneONone%ThlintGenerate 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.Nonen hlintExtra 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.3      !"#)$%&'(*.+-,Noneq<hlint:Given a set of hints, do all the HintRule hints type checkhlintBGiven a set of hints, do all the HintRule hints satisfy QuickCheckNone"#>r)hlintGuess why a theorem is missingNone"#{ /hlintAn idea suggest by a Hint.1hlint1The modules the idea is for, usually a singleton.2hlintkThe declarations the idea is for, usually a singleton, typically the function name, but may be a type name.3hlintThe severity of the idea, e.g. -.4hlint3The name of the hint that generated the idea, e.g.  "Use reverse".5hlint$The source code the idea relates to.6hlint4The contents of the source code the idea relates to.7hlintThe suggested replacement, or + for no replacement (e.g. on parse errors).8hlint3Notes about the effect of applying the replacement.9hlintHow to perform this idea!#)$%&'(*.+-,/0412356789 !"#$%&'(None"#|)None"#*hlint Print an +* with trailing null-terminator and newlineHThe trailing newline will be ignored, but makes the output more readable,hlintConvert 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   values.?hlintGiven a comment generate some /s.X`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~STUVW #)$%&'(*.+-,/0412356789 !"#$%&'(:;<=>?./0None`1None%>2None%3None)4None>l5None%>56hlint do ...; x  -return y; ... == do ...; let x = y; ...7hlintMatch return x to Just x.8None%x9 None%>:!None%;"None"#Xa<#NoneX=hlint+Classes that can't require newtype deriving>hlint>Classes that can appear as stock, and can't appear as anyclass?hlint0What is derived on newtype, and on data type  'deriving'J declarations may be on either, so we approximate as both newtype and data@$NoneA%NoneXBhlintThe 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 findC&NoneD'None%XJE(None"#F)None%>MX5GhlintCA list of substitutions. A key may be duplicated, you need to call check( to ensure the substitution is valid.HhlintUnpack the substitutionIhlintPerform a substitutionJhlint(Unification, obeys the property that if  unify a b = s, then substitute s a = b.GHKIL*None"#%>XM+None:@hlintWA list of the builtin hints wired into HLint. This list is likely to grow over time.Nhlint=A list of builtin hints, currently including entries such as "List" and  "Bracket".QhlintTransform a list of @ or  into a :.OhlintTransform a list of  into a :.:;<=>?/0@ABCDEFGHIJKLMNOPNQO,None"#%MPPhlintRead 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 YAMLQhlintBFailed when parsing some value, give an informative error message.RPS-None%PXThlint@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.Uhlint 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.VWUX.NoneY/None"#ZhlintGiven 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.Z0None[hlintDApply hints to a single file, you may have the contents of the file.\hlintAApply hints to multiple files, allowing cross-file hints to fire.Rhlint*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.6Given a set of modules, it may be faster pass each to R 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.[\R1None"#%#a2None^b3None2J chlint.which files to run it on, nothing = none givendhlintwhere to generate reportsehlint)which settignsfiles were explicitly givenfhlint(hints that are given on the command lineghlint)groups that are given on the command linehhlintuse git ls-files to find filesihlintcolor the resultjhlint/Numbmer of threads to use, 0 = whatever GHC haskhlintthe hints to ignorelhlintdisplay all skipped itemsmhlint extensionsnhlint#the extensions (may be prefixed by No)ohlintRwork between source files, applies to hints such as duplicate code between modulesphlint!source files to look for hints inqhlintthe data directoryrhlintPrint a default file to stdoutshlintdisplay hint data as JSONthlint(display hint data as Code Climate Issuesuhlintdo not show the summary infovhlintspecify which hints explicitlywhlint%Display hints in serialisation formatxhlintRun the refactor* executable to automatically perform hintsyhlintOptions to pass to the refactor executable.zhlintPath 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 stdin5 mqhcdefgijklnoprstuvwxyz{|4None"#e5None"#PShlintvThis 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 a your server with untrusted input.SNone"# Thlint1Get the Cabal configured data directory of HLint.Uhlint'The function produces a tuple containg   (for  ), and  and : for RC. It approximates the normal HLint configuration steps, roughly: Use X with W+ to find and load the HLint settings files.Use  and Q to transform the outputs of X.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.Vhlint A version of U 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.WhlintGiven a directory (or  to imply T), 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.Xhlint-Given a function to load a module (typically W.), and a module to start from (defaults to  hlint.yaml/) find the information from all settings files.hlintSplit a list of 0 for separate use in parsing and hint resolutionhlintISnippet from the documentation, if this changes, update the documentationY  !"#)$%&'(*.+-,/0412356789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYSR/0412356789*.+-,#)$%&'( !"TUVXW@ABCDEFGHIJKLMNOP:;<=>?Q None)YhlintA suggestion - the Show instance is of particular use.Zhlint|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. *.+-,YZ[\ ZY[\*.+-,6789::;<=>>?@ABCDEFGHHIJKLMNOPPQRSTUVWXYZU[\]^_`abcdefghiijklm+n+o+p+q+r+s+t+u+v+w+x+y+z+{+|+}+~+05]      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'(()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYYZ[\]^_`abcdefghijkklmnopqrstuvwxyz{||}~54      !"#$%&'()*+,-./0123456789:;<=>?@A=BCDEFFGGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdeefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./012345645745845945:45;45;45<45=45>45?@AB@AC@AD@AE@AF@AG@AH@AI@AJ@AK@AL@AM@AN@AO@AP@AQ@AR@AS@AT@AU@AV@AW@AX@AY@AZ@[\@[]@[^_`abcdefghijklmnopqrstuvwxyz{|}~                            !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLM 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/n0o0p0q0r0s0t1u2v3w3x3y3z3{3|3}3~33333333333333333333333333333333333333333333345#hlint-2.1.13-JraqHU4w3X3Ip3LhIxQbGpLanguage.Haskell.HLint3Language.Haskell.HLintHSE.TypeHSE.Util HSE.Scope HSE.Match HSE.ReduceHsColourParallel Paths_hlint Test.UtilTest.InputOutputTimingUtilHSE.AllRefact Hint.Util Config.TypeTest.Translate Test.ProofIdeaReportCC 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.Restrict HSE.Unify Hint.MatchHint.All Config.YamlConfig.Haskell Config.ReadConfig.ComputeApplyTest.AnnotationsGrepCmdLineTest.AllHLintScope scopeCreate scopeMatch scopeMove ParseErrorparseErrorLocationparseErrorMessageparseErrorContents ParseFlagscppFlagshseFlagsCppFlagsNoCpp CppSimpleCpphsdefaultParseFlagsparseFlagsAddFixities parseModuleExHintRulehintRuleSeverity hintRuleName hintRuleScope hintRuleLHS hintRuleRHS hintRuleSide hintRuleNotesClassifyclassifySeverity classifyHintclassifyModule classifyDeclNoteIncreasesLazinessDecreasesLaziness RemovesError ValidInstanceRequiresExtensionSeverityIgnore SuggestionWarningError ideaModuleideaDecl ideaSeverityideaHintideaSpanideaFromideaToideaNoteideaRefactoringHint hintModules hintModulehintDecl hintComment HintBuiltinHintList HintListRec HintMonad HintLambda HintBracket HintNaming HintPattern HintImport HintExport HintPragmaHintExtensions HintUnsafe HintDuplicate HintRestrict HintComment HintNewType resolveHints applyHintshlintgetHLintDataDir autoSettings argsSettingsreadSettingsFile findSettingssuggestionLocationsuggestionSeverity$fShowSuggestion$fEqSuggestion$fOrdSuggestion.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 parseWithModeparseWithComments ParseResultParseOk ParseFailed ParseMode parseFilename baseLanguage extensionsignoreLanguagePragmasignoreLinePragmasfixitiesignoreFunctionArityLanguage.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 SpecialConConsUnitConListConFunConTupleConUnboxedSingleConExprHoleQNameQualUnQualSpecialNameSymbolIdentIPNameIPDupIPLinQOpQVarOpQConOpOpVarOpConOpCNameVarNameConNameModuleXmlPage XmlHybrid ModuleHeadExportSpecList ExportSpecEVarEAbs EThingWithEModuleContents EWildcard NoWildcard Namespace NoNamespace TypeNamespacePatternNamespace ImportDecl importAnn importModuleimportQualified importSrc importSafe importPkgimportAs importSpecsImportSpecList ImportSpecIVarIAbs IThingAll IThingWithAssoc AssocNone AssocLeft AssocRightDeclPatSynInstDecl ClassDeclTypeDecl TypeFamDeclClosedTypeFamDeclDataDecl GDataDecl DataFamDecl TypeInsDecl DataInsDecl GDataInsDecl DerivDecl InfixDecl DefaultDecl SpliceDeclTypeSig PatSynSigFunBindPatBindForImpForExpRulePragmaDeclDeprPragmaDeclWarnPragmaDecl InlineSigInlineConlikeSigSpecSig SpecInlineSigInstSig AnnPragma MinimalPragma RoleAnnotDeclCompletePragmaPatternSynDirectionUnidirectionalImplicitBidirectionalExplicitBidirectionalTypeEqn AnnotationAnnTypeAnn ModuleAnnBooleanFormula VarFormula AndFormula OrFormula ParenFormulaRoleNominalRepresentationalPhantom RoleWildcard DataOrNewDataTypeNewTypeInjectivityInfo ResultSigKindSigTyVarSigDeclHeadDHeadDHInfixDHParenDHAppInstRuleIRuleIParenInstHeadIHConIHInfixIHParenIHAppDeriving DerivStrategy DerivStock DerivAnyclass DerivNewtypeDerivViaBindsBDeclsIPBindsIPBindMatch InfixMatch QualConDeclConDecl InfixConDeclRecDecl FieldDeclGadtDeclClsDecl ClsDataFamClsTyFamClsTyDef ClsDefSigInsDeclInsTypeInsDataInsGDataBangTypeBangedTyLazyTy NoStrictAnnot UnpackednessUnpackNoUnpackNoUnpackPragmaRhs UnGuardedRhs GuardedRhss GuardedRhsTypeTyConTyForallTyStarTyFunTyTuple TyUnboxedSumTyList TyParArrayTyAppTyVarTyParenTyInfixTyKind TyPromotedTyEqualsTySpliceTyBang TyWildCard TyQuasiQuoteMaybePromotedName PromotedNameUnpromotedNamePromotedPromotedIntegerPromotedString PromotedCon PromotedList PromotedTuple PromotedUnitBoxedUnboxed TyVarBind KindedVar UnkindedVarKindFunDepContextCxSingleCxTupleCxEmptyAsstClassAAppAInfixAIParamEqualPParenA WildCardALiteralStringCharIntFracPrimIntPrimWord PrimFloat PrimDoublePrimChar PrimStringSignSignlessNegativeExpVarConIfAppOverloadedLabelIPVarLitInfixAppNegAppLambdaLetMultiIfCaseDoMDoTuple UnboxedSum TupleSectionListParArrayParen LeftSection RightSection RecConstr RecUpdateEnumFrom EnumFromTo EnumFromThenEnumFromThenToParArrayFromToParArrayFromThenToListCompParComp ParArrayComp ExpTypeSigVarQuoteTypQuote BracketExp SpliceExp QuasiQuoteTypeAppXTagXETagXPcdataXExpTag XChildTag CorePragma SCCPragma GenPragmaProc LeftArrApp RightArrAppLeftArrHighAppRightArrHighAppLCaseXNameXDomNameXAttrBracket ExpBracket PatBracket TypeBracket DeclBracketSpliceIdSplice ParenSpliceSafety PlayRiskyPlaySafePlayInterruptibleCallConvStdCallCCall CPlusPlusDotNetJvmJs JavaScriptCApi ModulePragmaLanguagePragma OptionsPragmaAnnModulePragmaToolGHCHUGSNHC98YHCHADDOCK UnknownToolOverlap Overlappable OverlappingOverlaps Incoherent NoOverlap Activation ActiveFrom ActiveUntilRuleRuleVar TypedRuleVar WarningTextDeprTextWarnTextPatPVarPLitPNPlusK PInfixAppPAppPTuple PUnboxedSumPListPParenPRecPAsPat PWildCardPIrrPat PatTypeSigPViewPatPRPatPXTagPXETagPXPcdataPXPatTagPXRPatsPSplice PQuasiQuotePBangPatPXAttrRPatOpRPStarRPStarGRPPlusRPPlusGRPOptRPOptGRPatRPOpRPEitherRPSeqRPGuardRPCAsRPAsRPParenRPPatPatField PFieldPat PFieldPunPFieldWildcardStmt Generator QualifierLetStmtRecStmtQualStmt ThenTransThenByGroupBy GroupUsing GroupByUsing FieldUpdateFieldPun FieldWildcardAlt AnnotatedamapannLanguage.Haskell.Exts.SrcLoc<^^><**<+?><++> combSpanMaybe combSpanInfoinfoSpan noSrcSpan noInfoSpanspanSize isNullSpan mergeSrcSpan mkSrcSpan srcSpanEnd srcSpanStartnoLocSrcLoc srcFilenamesrcLine srcColumnSrcSpansrcSpanFilenamesrcSpanStartLinesrcSpanStartColumnsrcSpanEndLinesrcSpanEndColumnLocunLoc 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 StrictDataDoRec Rank2TypesPolymorphicComponentsPatternSignaturesCPPGenericsNamedFieldPunsExtensibleRecordsRestrictedTypeSynonyms HereDocumentsNewQualifiedOperators XmlSyntaxRegularPatterns SafeImportsSafe Trustworthypretty-1.1.3.6#Text.PrettyPrint.Annotated.HughesPJMode OneLineModeLeftMode ZigZagModePageModeStylemoderibbonsPerLine lineLengthstyle&uniplate-1.6.12-IuLxrY5QRgrBmW7Kpvt9Ut!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 fromParen fromPParen fromTyParen fromTyBangisVarisConisApp isInfixAppisAnyAppisParenisIfisLambdaisMDoisBoxed isDerivDecl isPBangPat isPFieldPun isFieldPun isPWildCardisPFieldWildcardisFieldWildcard isPViewPat isParComp isTypeApp isPatTypeSig isQuasiQuoteisTyQuasiQuote isSpliceDecl isNewType isRecStmt isClsDefSigisTyBangisLCaseisTupleSectionisString isRecUpdate isRecConstr isSection isPrimLiteralallowRightSectionallowLeftSectionunqualfromQual isSpecialisDolisDotisDotAppdotAppdotAppsisReturnisLexeme isAssocLeft isAssocNoneisWHNFtransformBracketOld descendIndex isKindHash getEquations toFunBindreplaceBranchesappsfromAppsfromAppsWithLoc childrenApps descendApps descendAppsM universeApps transformAppstransformAppsM universeS childrenSuniverseParentExp showSrcLocandropAnn/=~=elem_notElem_nub_delete_ intersect_neqListeqListeqMaybe getFixity toInfixDeclbaseGHC.Basemempty scopeImportsNamed fromNamedtoNamedVar_PVar_PApp_ LamConst1App2Viewview~=isSymreducehsColourConsole hsColourHTMLparallelversion getBinDir getLibDir getDynLibDir getDataDir getLibexecDir getSysconfDirgetDataFileName withTestsprogresspassedfailedtested matchStartestInputOutputtimedtimedIO startTimings printTimings forceList exitMessageexitMessageImpuregzipuniverseParentBidefaultExtensionscontext1haskell-src-exts-util-0.2.4-QTyayj2WGq3Ak6hZtz02ULanguage.Haskell.Exts.Bracket appsBracket rebracket1transformBracketparenBracketsremParenaddParenisAtom needBracketLanguage.Haskell.Exts.FreeVarsAllVarsallVarsFreeVarsvarsvarsspvarsfreeVarsparseFlagsSetLanguagetoRefactSrcSpantoSS niceLambdaR simplifyExp niceLambdaSettingArgumentSettingInfixSettingClassifySettingMatchExpSettingRestrictBuiltinRestrict restrictTyperestrictDefault restrictName restrictAsrestrictWithin RestrictTypeRestrictModuleRestrictExtension RestrictFlagRestrictFunction getSeveritygetRestrictTypedefaultHintName isUnifyVar showNotes testTypeChecktestQuickCheckclassifyMissingproof GHC.MaybeNothing showIdeasJsonshowANSIrawIdearawIdeaNideasuggestwarnignoresuggestN writeReport printIssueIssuefromIdeaMonoid CrossHintModuHintDeclHint unsafeHint pragmaHint patternHint newtypeHint namingHintmonadLetfromRet monadHint listRecHintlistHint lambdaHint importHintnoDeriveNewtype deriveStockderivesextensionsHint exportHintDupe duplicateHint commentHint bracketHint restrictHintSubst fromSubst substituteunify validSubstunifyExp readMatch 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