LB      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~       !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~                      !!"##$$$$%&&&& & & & & &&&&&&&&&&&&&&&&&&& &!&"&#'$'%(&)'*(+)+*++,,,-,.,/,0,1,2-3-4-5.6/708191:1;1<1=1>1?1@1A15 Safe-InferredState for the parser monad*The most recently marked indentation level Safe-Inferred Safe-Inferred+7/Data type for simplified Javascript expressions VRaw Javascript (generated when parsing fails for an inline foreign import declaration) Continue statement Break statement Labelled statement InstanceOf testType-Of operatorThrow statementReturn statementIf-then-else statement ForIn loopFor loop While loopA variable assignment3A variable introduction and optional initialization A block of expressions in bracesConditional expressionVariableFunction application8A function introduction (optional name, arguments, body)&An object property accessor expressionAn object literalAn array indexer expressionAn array literal A binary operator application!A unary operator application"A boolean literal#A string literal$A numeric literal%Built-in binary operators&"Bitwise right shift with zero-fill'Bitwise right shift(Bitwise left shift) Bitwise xor* Bitwise or+ Bitwise and, Boolean or- Boolean and.Numeric greater-than-or-equal/Numeric greater-than0Numeric less-than-or-equal1Numeric less-than2Generic inequality test3Generic equality test4 Remainder5Numeric division6Numeric multiplication7Numeric subtraction8Numeric addition9Built-in unary operators: Constructor;Numeric unary 'plus'<Bitwise negation=Boolean negation>Numeric negation:  !"#$%&'()*+,-./0123456789:;<=>?@A:  !"#$%&'()*+,-./0123456789:;<=>?@A:9>=<;:%876543210/.-,+*)('&$#"!  ?@A$#"!  %876543210/.-,+*)('&9>=<;:?@A Safe-Inferred BCDEFGHIJ BCDEFGHIJ BCDEFGHIJ BCDEFGHIJ Safe-InferredK@Collapse blocks which appear nested directly below another blockKLKLKLKL2 Safe-Inferred BCDEFGHIJKLMNCIJKLMN BCDEFGHIJKLMN Safe-InferredBMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~BMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~BMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~BMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~ Safe-InferredNone246B   Safe-Inferred!"(* !The data type of compiler options)Disable inclusion of the built in PreludeDisable tail-call eliminationPerform type checks at runtime>Disable inlining of calls to return and bind for the Eff monad#When specified, checks the type of mainN in the module, and generate a call to run main after the module definitions.Skip all optimizationsVerbose error message_Specify the namespace that PureScript modules will be exported to when running in the browser.Per-mode optionsVIndicates the mode of the compiler. Lifted using DataKinds to refine the Options type.Default compiler optionsDefault make options   Safe-InferredEliminate tail callsOO  Safe-Inferred+:A qualified name, i.e. a name with an optional module name Module namesTProper names, i.e. capitalized names for e.g. module names, type//data constructors.Names for value identifiers%A symbolic name for an infix operatorAn alphanumeric identifier7Provide a default module name, if a name is unqualified   Safe-Inferred30)A list of purescript reserved identifiers+The characters allowed for use in operators(A list of reserved identifiers for typesA list of reserved operators(Valid first characters for an identifierValid identifier characters&Valid first characters for an operatorValid operators characters"The PureScript language definition/A token parser based on the language definition Parse a tokenParse an identifierParse a reserved wordParse a reserved operatorParse an operatorParse a string literalParse whitespace SemicolonColonPeriodCommaBacktickPipe characterNatural numberParse a proper nameParse a module name0Parse a qualified name, i.e. M.name or just name(Parse an integer or floating point value-Parse an identifier or parenthesized operator$Parse a token inside square brackets Parse a token inside parenthesesParse a token inside braces#Parse a token inside angle brackets8Parse zero or more values separated by a separator token7Parse one or more values separated by a separator token1Parse zero or more values separated by semicolons0Parse one or more values separated by semicolons-Parse zero or more values separated by commas,Parse one or more values separated by commasnRun the first parser, then match the second if possible, applying the specified function on a successful matchnRun the first parser, then match the second zero or more times, applying the specified function for each matchPBuild a parser from a smaller parser and a list of parsers for postfix operators/Parse an identifier in backticks or an operator"Mark the current indentation level;Check that the current identation level matches a predicateACheck that the current indentation level is past the current markWCheck that the current indentation level is at the same indentation as the current mark'Run a parser which supports indentation0000  Safe-InferredWrap a string in parentheses)Number of characters per identation level)Pretty print with a new indentation level!Get the current indentation levelPrint many lines.Prints an object key, escaping reserved names. None+The data type of kindsFunction kinds5Kinds for labelled, unordered rows without duplicatesThe kind of effectsThe kind of types!Unification variable of type KindNone Parse a kindPQRPQRNone4Generate a pretty-printed string representing a KindSTUSTUNone+The type of types %A placeholder used in pretty printing %A placeholder used in pretty printing %A placeholder used in pretty printing %A placeholder used in pretty printing A non-empty row An empty rowA skolem constant+A type with a set of type class constraintsForall quantifier7A type synonym which is "saturated", i.e. fully appliedA type applicationA type constructorA named type variable#A unification variable of type Type0An identifier for the scope of a skolem variable4Convert a row to a list of pairs of labels and types+Convert a list of labels and types to a row"Check whether a type is a monotypeUniversally quantify a type?Replace a type variable, taking into account variable shadowing'Replace named type variables with types .Collect all type variables appearing in a type!3Collect all free type variables appearing in a type"EUniversally quantify over all type variables appearing free in a type#5Move all universal quantifiers to the front of a type!      !"#$%&'(!      !"#$%&'(!      !"#$%&'(      !"#$%&'(None+ )#The type of a type class dictionary*XA type class dictionary which is an alias for an imported dictionary from another module+A regular type class dictionary,;Data representing a type class dictionary which is in scope.CThe identifier with which the dictionary can be accessed at runtime/DThe name of the type class to which this type class instance applies03The types to which this type class instance applies1LType class dependencies which must be satisfied to construct this dictionary2The type of this dictionary3(Is this instance exported by its module? )*+,-./0123 )*+,-./0123 ,-./0123)+*)+*,-./0123None+'4 The type ('data' or  'newtype') of a data type declaration5A newtype constructor6A standard data constructor7The kinds of a type8A local type variable9 Foreign data: Type synonym; Data type<The kind of a name=OA type class dictionary, generated during desugaring of type class declarations>A data constructor?SA local name introduced using a lambda abstraction, variable introduction or binder@A foreign importAfA type class dictionary member accessor import, generated during desugaring of type class declarationsB+A value introduced as a binding in a moduleC!The visibility of a name in scopeD_The name is defined in the another binding group, or has been made visible by a function binderEDThe name is defined in the current binding group, but is not visibleFThe type of a foreign importGEA foreign import which contains inline Javascript as a string literalHA regular foreign importIThe  Environment; defines all values and types which are currently in scope:KValue names currently in scopeLType names currently in scopeMXData constructors currently in scope, along with their associated data type constructorsN Type synonyms currently in scopeO!Available type class dictionariesP Type classesQTThe initial environment with no values and only the default javascript types definedR)Construct a ProperName in the Prim moduleS#Construct a type in the Prim moduleTType constructor for functionsUType constructor for stringsVType constructor for numbersWType constructor for booleansXType constructor for arraysYType constructor for objectsZ$Smart constructor for function types[WThe primitive types in the external javascript environment with their associated kinds.)456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\(456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[)IJKLMNOPQFHGCED<BA@?>=7;:98465\RSTUVWXYZ[4657;:98<BA@?>=CEDFHGIJKLMNOPQRSTUVWXYZ[\None+MY]Data type for binders^)A binder with source position information_/A binder which binds its input to an identifier`;A binder which matches an array and binds its head and taila6A binder which matches an array and binds its elementsb8A binder which matches a record and binds its propertiesc)A binder which matches a data constructord"A binder which binds an identifiere(A binder which matches a numeric literalf'A binder which matches a string literalg(A binder which matches a boolean literalhWildcard binderi"A statement in a do-notation blockj6A do notation element with source position informationk0A let statement, i.e. a pure value with a binderlA monadic value with a binderm A monadic value without a bindern"An alternative in a case statementp6A collection of binders with which to match the inputsqAn optional guardrThe result expressions#Data type for expressions and termst(A value with source position informationueA placeholder for a superclass dictionary to be turned into a TypeClassDictionary during typecheckingvA placeholder for a type class dictionary to be inserted later. At the end of type checking, these placeholders will be replaced with actual expressions representing type classes dictionaries which can be evaluated at runtime. The constructor arguments represent (in order): whether or not to look at superclass implementations when searching for a dictionary, the type class name and instance type, and the type class dictionaries in scope.w\An application of a typeclass dictionary constructor. The value should be an ObjectLiteral.xA do-notation blocky A let bindingzA value with a type annotation{A case expression. During the case expansion phase of desugaring, top-level binders will get desugared into case expressions, hence the need for guards and multiple binders per branch here.|A data constructor}%Conditional (if-then-else expression)~VariableFunction applicationFunction introductionPartial record update&An record property accessor expressionAn object literalAn array literaljExplicit parentheses. During the rebracketing phase of desugaring, this data constructor will be removed.qBinary operator application. During the rebracketing phase of desugaring, this data constructor will be removed.A prefix -, will be desugaredA boolean literalA string literalA numeric literalSA guard is just a boolean-valued expression that appears alongside a set of bindersThe data type of declarations.A declaration with source position informationbA type instance declaration (name, dependencies, class name, instance types, member declarations)GA type class declaration (name, argument, implies, member declarations)A module import (module name, optional set of identifiers to import, optional set of identifiers to hide, optional "qualified as" name)1A fixity declaration (fixity data, operator name)$A type class instance foreign import'A data type foreign import (name, kind)KA foreign import declaration (type, name, optional inline Javascript, type)6A minimal mutually recursive set of value declarationsDA value declaration (name, top-level binders, optional guard, value))A type declaration for a value (name, ty)2A type synonym declaration (name, arguments, type):A minimal mutually recursive set of data type declarationsMA data type declaration (data or newtype, name, arguments, data constructors)8The data type which specifies type of import declaration;Import with hiding clause with a list of references to hide4Qualified import with a list of references to importUnqualified import0An item in a list of explicit imports or exports8A declaration reference with source position information]A type class instance, created during typeclass desugaring (name, class name, instance types) A type classA value)A type constructor with data constructorsA module declaration, consisting of a module name, a list of declarations, and a list of the declarations that are explicitly exported. If the export list is Nothing, everything is exported.Fixity data for infix operatorsSource position information Source name Line number Column number!Associativity for infix operators(A precedence level for an infix operator,Test if a declaration is a value declaration@Test if a declaration is a data type or type synonym declaration(Test if a declaration is a module import3Test if a declaration is a data type foreign import=Test if a declaration is a type class instance foreign import-Test if a declaration is a fixity declaration)Test if a declaration is a foreign import=Test if a declaration is a type class or instance declarationMFind the original dictionary which a type class dictionary in scope refers to8Collect all names introduced in binders in an expressionj]^_`abcdefghijklmnopqrstuvwxyz{|}~g]^_`abcdefghijklmnopqrstuvwxyz{|}~js~}|{zyxwvutnopqrimlkj]hgfedcba`_^!] hgfedcba`_^imlkjnopqrs~}|{zyxwvutNone)A list of modules with their dependencies:Sort a collection of modules based on module dependencies.6Reports an error if the module graph contains a cycle.VNCalculate a list of used modules based on explicit imports and qualified namesWFConvert a strongly connected component of the module graph to a moduleVXWVXWNoneZEliminate all declarations which are not a transitive dependency of the entry point moduleYZ[\YZ[\None 4Convert an Ident into a valid Javascript identifier:,Alphanumeric characters are kept unmodified.2Reserved javascript identifiers are prefixed with $$.Symbols are prefixed with ]2 followed by a symbol name or their ordinal value.;Test if a string is a valid JS identifier without escaping.kAttempts to find a human-readable name for a symbol, if none has been specified returns the ordinal value.<Checks whether an identifier name is reserved in Javascript.Finds the value stored for a data constructor in the current environment. This is a partial function, but if an invalid type has reached this far then something has gone wrong in typechecking.Checks whether a data constructor is the only constructor for that type, used to simplify the check when generating code for binders.3Checks whether a data constructor is for a newtype.:Checks the number of arguments a data constructor accepts.AChecks whether a data constructor has no arguments, for example, ^.    None_CInline type class dictionaries for >>= and return for the Eff monadE.g.;Prelude[">>="](dict)(m1)(function(x) { return ...; })becomes-function __do { var x = m1(); ... }`!Inline functions in the ST module_`_`NoneaaNone@Apply a series of optimizer passes to simplified Javascript codebbNone c$The state object used in this moduledDA map from names bound (in the input) to their names (in the output)eDThe set of names which have been used and are in scope in the outputfCRuns renaming starting with a list of idents for the initial scope.gbCreates a new renaming scope using the current as a basis. Used to backtrack when leaving an Abs.hqAdds a new scope entry for an ident. If the ident is already present, a new unique name is generated and stored.i'Finds the new name to use for an ident.j(Finds idents introduced by declarations.,Renames within each declaration in a module.kPRenames within a declaration. isTopLevel is used to determine whether the declaration is a module member or appearing within a Let. At the top level declarations are not renamed or added to the scope (they should already have been added), whereas in a Let declarations are renamed if their name shadows another in the current scope.lRenames within a value.m!Renames within case alternatives.nRenames within binders.ocpdeqfghijklmn ocpdeqfghijklmnNone!"$ iGenerate code in the simplified Javascript intermediate representation for all declarations in a module.XGenerate code in the simplified Javascript intermediate representation for a declarationrOGenerate key//value pairs for an object literal exporting values from a module.sxGenerate code in the simplified Javascript intermediate representation for a variable based on a PureScript identifier.tGenerate code in the simplified Javascript intermediate representation for an accessor based on a PureScript identifier. If the name is not valid in Javascript (symbol based, reserved name) an indexer is returned.uaGenerate code in the simplified Javascript intermediate representation for a value or expression.vShallow copy an object.w_Generate code in the simplified Javascript intermediate representation for runtime type checks.xfGenerate code in the simplified Javascript intermediate representation for a reference to a variable.yGenerate code in the simplified Javascript intermediate representation for a reference to a variable that may have a qualified name.zmGenerate code in the simplified Javascript intermediate representation for pattern match binders and guards.{cGenerate code in the simplified Javascript intermediate representation for a pattern match binder.|}rst~uvwxyz{=  !"#$%&'()*+,-./0123456789:;<=>?@A|}rst~uvwxyz{NoneEGenerate a pretty-printed string representing a Javascript expressionrGenerate a pretty-printed string representing a collection of Javascript expressions at the same indentation levelPGenerate an indented, pretty-printed string representing a Javascript expressionNone3Generate a pretty-printed string representing a Row\Generate a pretty-printed string representing a Type, as it should appear inside parentheses4Generate a pretty-printed string representing a Type  None;Generate a pretty-printed string representing an expression6Generate a pretty-printed string representing a Binder3None None3B A stack trace for an errorCompilation errors Error message"The value where the error occurred$Optional source position information(Type for sources of type checking errors#An error which originated at a Type#An error which originated at a ExprJRethrow an error with a more detailed error message in the case of failure1Rethrow an error with source position information !None3HMDRemove explicit parentheses and reorder binary operator applications"None Replace all DoNotationBind and DoNotationValueH constructors with applications of the Prelude.(>>=) function, and all  DoNotationLet# constructors with let expressions.#NoneIReplace all top level type declarations in a module with type annotations=Replace all top level type declarations with type annotations$NoneSReplace all sets of mutually-recursive declarations in a module with binding groupsBCollapse all binding groups in a module to individual declarationsGReplace all sets of mutually-recursive declarations with binding groups6Collapse all binding groups to individual declarations%None]An imported environment for a particular module. This also contains the module's own members.HLocal names for types within a module mapped to to their qualified namesTLocal names for data constructors within a module mapped to to their qualified namesJLocal names for classes within a module mapped to to their qualified namesILocal names for values within a module mapped to to their qualified names(The exported declarations from a module.#The types exported from each module%The classes exported from each module$The values exported from each moduleMThe global export environment - every declaration exported from every module.Updates the exports for a module from the global environment. If the module was not previously present in the global environment, it is created.-Adds an empty module to an ExportEnvironment.<Adds a type belonging to a module to the export environment.'Adds a class to the export environment.'Adds a class to the export environment.eAdds an entry to a list of exports unless it is already present, in which case an error is returned.FReplaces all local names with qualified names within a set of modules.Make all exports for a module explicit. This may still effect modules that have an exports list, as it will also make all data constructor exports explicit.vReplaces all local names with qualified names within a module and checks that all existing qualified names are valid.4Finds all exported declarations in a set of modules.mFilters the exports for a module to ensure only explicit exports are kept in the global exports environment.|Finds the imports within a module, mapping the imported module name to an optional set of explicitly imported declarations.,Constructs a local environment for a module.TExtends the local environment for a module by resolving an import of another module.&None2346BHMgThe type checking monad, which provides the state of the type checker, and error reporting capabilities!State required for type checking:  The current  Environment (The next fresh unification variable name #The next type class dictionary name The current module0Temporarily bind a collection of names to values/Temporarily bind a collection of names to typesBTemporarily make a collection of type class dictionaries available;Get the currently available list of type class dictionaries9Temporarily bind a collection of names to local variables>Temporarily bind a collection of names to local type variables-Update the visibility of all names to Defined*Lookup the type of a value by name in the  Environment0Lookup the visibility of a value by name in the  EnvironmentAssert that a name is visible)Lookup the kind of a type by name in the  EnvironmentGet the current  Environment Update the  Environment Modify the  Environment=Run a computation in the Check monad, starting with an empty  EnvironmentmRun a computation in the Check monad, failing with an error, or succeeding with a return value and the final  Environment.0Make an assertion, failing with an error message'Generate new type class dictionary name Lift a computation in the Check# monad into the substitution monad.!bRun a computation in the substitution monad, generating a return value and the final substitution."Typecheck in parallel      !"      !"      !"      !"'None#@Replace all top-level binders in a module with case expressions.$4Replace all top-level binders with case expressions.#$#$$##$(None%Add type synonym declarations for type class dictionary types, and value declarations for type class instance dictionary expressions. %%% %)None&,The desugaring pipeline proceeds as follows:3Introduce type synonyms for type class dictionaries'Rebracket user-defined binary operatorsDesugar do-notation using the  Prelude.Monad type classBDesugar top-level case declarations into explicit case expressionsPDesugar type declarations into value declarations with explicit type annotationsIGroup mutually recursive value and data declarations into binding groups.'Qualify any unqualified names and types&#$%&&&*None'9Generate foreign imports for all declarations in a module''''4None>  !"#$%&'()*+,-./0123456789:;<=>?@A'+None(5Parse a type as it appears in e.g. a data constructor)Parse a monotype*Parse a polytype()*()*)*(()*,None Read source position information+Parse a single declaration,6Parse a module header and a collection of declarations-Parse a collection of modules. Parse a value/Parse a binder0<Parse a binder as it would appear in a top level declaration1 Parse a guard6+,-     ./01+,-./01+,-.1/06+,-     ./015None>()*+,-./01-None2462Infer the kind of a single type3tInfer the kind of a type constructor with a collection of arguments and a collection of associated data constructors4NSimultaneously infer the kinds of several mutually recursive type constructors^Solve the set of kind constraints associated with the data constructors for a type constructor 3Default all unknown kinds to the Star kind of types!Infer a kind for a type 234 !"#$234234 234 !"#$.None%,Build a type substitution for a type synonym&:Replace all instances of a specific type synonym with the SaturatedTypeSynonym data constructor5#Replace all type synonyms with the SaturatedTypeSynonym data constructor%&555%&5/None2346+'A simplified representation of expressions which are used to represent type class dictionaries at runtime, which can be compared for equality(A subclass dictionary)0A dictionary which depends on other dictionaries*CA dictionary which is brought into scope by an instance declaration+>A dictionary which is brought into scope by a local constraint,2Unify two types, updating the current substitution-1Unify two rows, updating the current substitutionCommon labels are first identified, and unified. Remaining labels and types are unified with a trailing row unification variable, if appropriate, otherwise leftover labels result in a unification error.6Infer the types of multiple mutually-recursive values, and return elaborated values including type class dictionaries and type annotations..+Check if a value contains a type annotation/=Map a function over type annotations appearing inside a value0PReplace type class dictionary placeholders with inferred type class dictionaries1Check that the current set of type class dictionaries entail the specified type class goal, and, if so, return a type class dictionary reference.25Check all values in a list pairwise match a predicate3Check that two types unify4Check whether the type heads of two types are equal (for the purposes of type class dictionary lookup), and return a substitution from type variables to types which makes the type heads unify.51Ensure skolem variables do not escape their scope6)Ensure a row contains no duplicate labels7)"Setify" all rows occuring inside a value8JReplace outermost unsolved unification variables with named type variables9yRemove any ForAlls and ConstrainedType constructors in a type by introducing new unknowns or TypeClassDictionary values.iThis is necessary during type checking to avoid unifying a polymorphic type with a unification variable.:>Replace a single type variable with a new unification variable;-Replace fully applied type synonyms with the SaturatedTypeSynonymR data constructor, which helps generate better error messages during unification.< "Desaturate" SaturatedTypeSynonyms=>Replace a type synonym and its arguments with the aliased type>JEnsure a set of property names and value does not contain duplicate labels?UInfer a type for a value, rethrowing any error to provide a more useful error message@Infer a type for a valueA>Infer the type of a property inside a record with a given typeB;Infer the types of variables brought into scope by a binderCLCheck the types of the return values in a set of binders in a case statementDGenerate a new skolem constantEGenerate a new skolem scopeFPSkolemize a type variable by replacing its instances with fresh skolem constantsGThis function has one purpose - to skolemize type variables appearing in a SuperClassDictionary placeholder. These type variables are somewhat unique since they are the only example of scoped type variables.H5Introduce skolem scope at every occurence of a ForAllINCheck the type of a value, rethrowing errors to provide a better error messageJCheck the type of a valueK5Check the type of a collection of named record fieldsThe laxt parameter controls whether or not every record member has to be provided. For object updates, this is not the case.L]Check the type of a function application, rethrowing errors to provide a better error messageM(Check the type of a function applicationN\Check whether one type subsumes another, rethrowing errors to provide a better error messageO'Check whether one type subsumes anotherPsCompute the meet of two types, i.e. the most general type which both types subsume. TODO: handle constrained types7'()*+QR,-6STU./0123456789:;V<=WX>?@YABCDEFGHIJZKLMNOP[\663'+*)(QR,-6STU./0123456789:;V<=WX>?@YABCDEFGHIJZKLMNOP[\0None247'Type check all declarations in a moduleWAt this point, many declarations will have been desugared, but it is still necessary to)Kind-check all types and add them to the  Environment*Type-check all values and add them to the  Environment%Bring type class instances into scopeProcess module imports ]^_`abcde7$      !"2345677 ]^_`abcde71None( 8SA type class which collects the IO actions we need to be able to run in "make" mode9Get a file timestamp:Read a file as a string;Write a text file<Report an error=Respond to a progress update>Compile a collection of modules-The compilation pipeline proceeds as follows:PSort the modules based on module dependencies, checking for cyclic dependencies.#Perform a set of desugaring passes.YType check, and elaborate values to include type annotations and type class dictionaries.URegroup values to take into account new value dependencies introduced by elaboration.Eliminate dead code.5Generate Javascript, and perform optimization passes.%Pretty-print the generated Javascript@[Compiles in "make" mode, compiling each module separately to a js files and an externs fileIf timestamps have not changed, the externs file can be used to provide the module's types without having to typecheck the module again.fSAdd an import declaration for a module if it does not already explicitly import it.89:;<=>?gh@ifjkA  !"#$%&'()*+,-./0123456789:;<=>?@A      !"#$%&'(456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[]^_`abcdefghijklmnopqrstuvwxyz{|}~      !"#$%&'()*+,-./0123456789:;<=>?@A >?89:;<=@A 89:;<=>?gh@ifjkAl66789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~                                                   ! " # $ $ %  & ' ( ) *+,-./0123456789:;<=>?@ABCDDEFGHIJKLMNOPQRSTUVWXXYZ[\]^_`abcdefghijklmnopqrsttuvwxyz{|}~                       !! "!#"##$$$%$&$'%(&)&)&*&+&+&,&-&.&/&0&1&2&3&4&5&6&7&8&9&:&;&<&=&>&?&@&A&B&C&D'E'F(G)H*I+J+K+L,M,N,O,P,Q,R,S-T-U-V.W/X0Y1Z1[1\1]1^1_1`1a1b1c2d2e2f2g2h2i2j2k2l2m2n2o2p qrsJtuvwxyz{||}~}t!!!!!!!!!!P!!!"$$$$$$$$$$%%%%%%%%%%%%%%%%%%%%%%%%%''''''((((((((((++++++++++++,, , , , , ,,,,,,,,,,,,,,,,,,, ,!,",#,$,%,&,',(,),*,+,,,-,.,/,0,1,2,3,4,5,6-7-8-9-:-;-<.=.>/?/@/A/B/C/D/E/F/G/H/I/J/K/L/M/N/O/P/Q/R/S/T/U/V/9/:/W/X/Y/Z/[/\/]/^/_/`/a/b/c/d/e/f/g/h/i/j/k/l/m/n/o/p/q/r0s0t0u0v000w0x0y1z1{1|1}1~1purescript-0.5.6.3 Language.PureScript.Parser.StateLanguage.PureScript.Traversals"Language.PureScript.CodeGen.JS.AST$Language.PureScript.Optimizer.Common$Language.PureScript.Optimizer.BlocksLanguage.PureScript.Constants$Language.PureScript.Optimizer.UnusedLanguage.PureScript.SupplyLanguage.PureScript.Options!Language.PureScript.Optimizer.TCOLanguage.PureScript.Names!Language.PureScript.Parser.Common!Language.PureScript.Pretty.CommonLanguage.PureScript.Kinds Language.PureScript.Parser.Kinds Language.PureScript.Pretty.KindsLanguage.PureScript.Types)Language.PureScript.TypeClassDictionariesLanguage.PureScript.Environment Language.PureScript.Declarations&Language.PureScript.ModuleDependencies'Language.PureScript.DeadCodeElimination"Language.PureScript.CodeGen.Common%Language.PureScript.Optimizer.MagicDo%Language.PureScript.Optimizer.InlinerLanguage.PureScript.OptimizerLanguage.PureScript.RenamerLanguage.PureScript.CodeGen.JSLanguage.PureScript.Pretty.JS Language.PureScript.Pretty.Types!Language.PureScript.Pretty.ValuesLanguage.PureScript.Errors#Language.PureScript.Sugar.Operators$Language.PureScript.Sugar.DoNotation*Language.PureScript.Sugar.TypeDeclarations'Language.PureScript.Sugar.BindingGroupsLanguage.PureScript.Sugar.Names%Language.PureScript.TypeChecker.Monad*Language.PureScript.Sugar.CaseDeclarations%Language.PureScript.Sugar.TypeClassesLanguage.PureScript.Sugar#Language.PureScript.CodeGen.Externs Language.PureScript.Parser.Types'Language.PureScript.Parser.Declarations%Language.PureScript.TypeChecker.Kinds(Language.PureScript.TypeChecker.Synonyms%Language.PureScript.TypeChecker.TypesLanguage.PureScript.TypeCheckerLanguage.PureScriptPaths_purescriptLanguage.PureScript.PrettyLanguage.PureScript.CodeGenLanguage.PureScript.Parser ParseStateindentationLevelfstMsndMthirdMmaybeMdefSJSJSRaw JSContinueJSBreakJSLabel JSInstanceOfJSTypeOfJSThrowJSReturnJSIfElseJSForInJSForJSWhile JSAssignmentJSVariableIntroductionJSBlock JSConditionalJSVarJSApp JSFunction JSAccessorJSObjectLiteral JSIndexerJSArrayLiteralJSBinaryJSUnaryJSBooleanLiteralJSStringLiteralJSNumericLiteralBinaryOperatorZeroFillShiftRight ShiftRight ShiftLeft BitwiseXor BitwiseOr BitwiseAndOrAndGreaterThanOrEqualTo GreaterThanLessThanOrEqualToLessThan NotEqualToEqualToModulusDivideMultiplySubtractAdd UnaryOperatorJSNewPositive BitwiseNotNotNegateeverywhereOnJSeverywhereOnJSTopDowneverythingOnJSapplyAll replaceIdent replaceIdents isReassigned isReboundisUsedtargetVariable isUpdatedremoveFromBlockcollapseNestedBlockscollapseNestedIfs$#<>++>>=+-*/%<><=>===/=&bar^&&|| unsafeIndexnegateshlshrzshr complementnotreturnpure' returnEscapeduntilEwhileErunST runSTArray stRefValuenewSTRef readSTRef writeSTRef modifySTRef peekSTArray pokeSTArraymkFnrunFn undefinedmonadEffDictionaryapplicativeEffDictionarybindEffDictionary numNumber ordNumbereqNumbereqString eqBoolean bitsNumberboolLikeBooleansemigroupStringsemigroupoidArrmain __superclass___unusedprimprelude preludeUnsafeeffst dataFunctionremoveCodeAfterReturnStatementsremoveUnusedArgremoveUndefinedAppSupplySupplyT unSupplyT runSupplyT evalSupplyT runSupply evalSupplyfresh freshName$fMonadErroreSupplyTOptionsoptionsNoPrelude optionsNoTcooptionsPerformRuntimeTypeChecksoptionsNoMagicDo optionsMainoptionsNoOptimizationsoptionsVerboseErrorsoptionsAdditional ModeOptions MakeOptionsCompileOptionsModeMakeCompilebrowserNamespaceentryPointModulescodeGenModulesdefaultCompileOptionsdefaultMakeOptionstco Qualified ModuleName ProperName runProperNameIdentOprunIdent runModuleNamemoduleNameFromStringqualify$fShowQualified$fShowModuleName$fShowProperName $fShowIdentreservedPsNamesopCharsreservedTypeNamesreservedOpNames identStart identLetteropStartopLetterlangDef tokenParserlexeme identifierreserved reservedOpoperator stringLiteral whiteSpacesemicolondotcommatickpipenatural properName moduleNameparseQualifiedintegerOrFloat parseIdentsquaresparensbracesanglessepBysepBy1semiSepsemiSep1commaSep commaSep1augmentfoldbuildPostfixParserparseIdentInfixmarkcheckIndentationindentedsamerunIndentParser PrinterStateindent blockIndent withIndent currentIndentprettyPrintManyprettyPrintObjectKeyKindFunKindRowBangStarKUnknowneverywhereOnKindseverythingOnKinds parseKindprettyPrintKindTypePrettyPrintForAllPrettyPrintObjectPrettyPrintArrayPrettyPrintFunctionRConsREmptySkolemConstrainedTypeForAllSaturatedTypeSynonymTypeAppTypeConstructorTypeVarTUnknown SkolemScoperunSkolemScope rowToList rowFromList isMonoTypemkForAllreplaceTypeVarsreplaceAllTypeVarsusedTypeVariablesfreeTypeVariablesquantifymoveQuantifiersToFronteverywhereOnTypeseverywhereOnTypesTopDowneverywhereOnTypesMeverywhereOnTypesTopDownMeverythingOnTypesTypeClassDictionaryTypeTCDAlias TCDRegularTypeClassDictionaryInScopetcdName tcdClassNametcdInstanceTypestcdDependenciestcdType tcdExported DataDeclTypeNewtypeDataTypeKindLocalTypeVariable ExternData TypeSynonymDataTypeNameKindTypeInstanceDictionaryValueDataConstructor LocalVariableExternTypeClassAccessorImportValueNameVisibilityDefined UndefinedForeignImportTypeInlineJavascript ForeignImport EnvironmentnamestypesdataConstructors typeSynonymstypeClassDictionaries typeClassesinitEnvironmentprimNameprimTy tyFunctiontyStringtyNumber tyBooleantyArraytyObjectfunction primTypes$fShowDataDeclTypeBinderPositionedBinder NamedBinder ConsBinder ArrayBinder ObjectBinderConstructorBinder VarBinder NumberBinder StringBinder BooleanBinder NullBinderDoNotationElementPositionedDoNotationElement DoNotationLetDoNotationBindDoNotationValueCaseAlternativecaseAlternativeBinderscaseAlternativeGuardcaseAlternativeResultExprPositionedValueSuperClassDictionaryTypeClassDictionary!TypeClassDictionaryConstructorAppDoLet TypedValueCase Constructor IfThenElseVarAppAbs ObjectUpdateAccessor ObjectLiteral ArrayLiteralParensBinaryNoParens UnaryMinusBooleanLiteral StringLiteralNumericLiteralGuard DeclarationPositionedDeclarationTypeInstanceDeclarationTypeClassDeclarationImportDeclarationFixityDeclarationExternInstanceDeclarationExternDataDeclarationExternDeclarationBindingGroupDeclarationValueDeclarationTypeDeclarationTypeSynonymDeclarationDataBindingGroupDeclarationDataDeclarationImportDeclarationTypeHiding Qualifying UnqualifiedDeclarationRefPositionedDeclarationRefTypeInstanceRef TypeClassRefValueRefTypeRefModuleFixity SourcePos sourceName sourcePosLinesourcePosColumn AssociativityInfixInfixrInfixl Precedence isValueDecl isDataDecl isImportDeclisExternDataDeclisExternInstanceDecl isFixityDecl isExternDeclisTypeClassDeclarationcanonicalizeDictionary binderNameseverywhereOnValueseverywhereOnValuesTopDownMeverywhereOnValuesMeverythingOnValueseverythingWithContextOnValueseverywhereWithContextOnValuesM accumTypes$fEqDeclarationRef$fShowSourcePos$fShowAssociativity ModuleGraph sortModuleseliminateDeadCode identToJsidentNeedsEscapingidentCharToStringnameIsJsReservedmoduleNameToJslookupConstructorisOnlyConstructorisNewtypeConstructorgetConstructorArityisNullaryConstructormagicDo etaConvertunThunk evaluateIifesinlineVariablesinlineOperatorinlineCommonOperatorsoptimizerenameInModules moduleToJsdeclToJs prettyPrintJSprettyPrintRowprettyPrintTypeAtomprettyPrintTypeprettyPrintValueprettyPrintBinder ErrorStackMultipleErrors runErrorStack CompileErrorcompileErrorMessagecompileErrorValuecompileErrorPosition ErrorSource TypeError ExprErrorprettyPrintErrorStackstringifyErrorStackisErrorNonEmpty showError mkErrorStack positionErrorrethrowrethrowWithPosition$fErrorErrorStack$fMonoidErrorStack rebracketremoveSignedLiteralsdesugarDoModuledesugarTypeDeclarationsModuledesugarTypeDeclarationscreateBindingGroupsModulecollapseBindingGroupsModulecreateBindingGroupscollapseBindingGroupsdesugarImportsCheckunCheck CheckStatecheckEnv checkNextVarcheckNextDictNamecheckCurrentModule bindNames bindTypeswithTypeClassDictionariesgetTypeClassDictionariesbindLocalVariablesbindLocalTypeVariablesmakeBindingGroupVisiblelookupVariable getVisibilitycheckVisibilitylookupTypeVariablegetEnvputEnv modifyEnvrunCheck runCheck' guardWithfreshDictionaryName liftCheck liftUnifyparUdesugarCasesModule desugarCasesdesugarTypeClassesdesugar moduleToPs parseTypeAtom parseType parsePolyTypeparseDeclaration parseModule parseModules parseValue parseBinderparseBinderNoParens parseGuardkindOfkindsOf kindsOfAllsaturateAllTypeSynonymstypesOf typeCheckAll MonadMake getTimestamp readTextFile writeTextFile liftErrorprogresscompilecompile'makepreludeFilenamecatchIOversionbindirlibdirdatadir libexecdir sysconfdir getBinDir getLibDir getDataDir getLibexecDir getSysconfDirgetDataFileNametco' parseStar parseBang typeLiteralsmatchRowfunKind usedModulestoModule getModuleNameKeydeclarationsByModule dependenciesbaseGHC.Base Data.MaybeNothingmagicDo'inlineST shouldInlineuntilFixedPoint RenameState rsBoundNames rsUsedNames runRenamenewScope updateScope lookupIdentfindDeclIdents renameInDecl renameInValuerenameInCaseAlternativerenameInBinderRename initState exportToJsvaraccessor valueToJs extendObjruntimeTypeChecksvarToJs qualifiedToJS bindersToJs binderToJs importToJsimportsaccessorStringprettyPrintJS1prettyPrintJS'literalsstring conditionalindexerlamapptypeOf instanceOfunarybinaryprettyStatementstypeAppappliedFunctioninsertPlaceholders matchTypeAtom matchTypeforall_prettyPrintDeclarationprettyPrintCaseAlternativeprettyPrintDoNotationElement ifThenElse objectUpdateprettyPrintValue'prettyPrintBinderAtomprettyPrintBinder'matchConsBinderprettyPrintObjectPropertyBinderprettyPrintObjectPropertyChainrebracketModule removeParenscollectFixitiesensureNoDuplicatescustomOperatorTablematchOperatorstoAssoctokenparseOp parseTicksmatchOp desugarDocreateBindingGroupsForValuecollapseBindingGroupsForValue usedIdentsusedProperNamesgetIdent getProperNametoBindingGrouptoDataBindingGroup isTypeSynonym fromValueDeclImportEnvironment importedTypesimportedDataConstructorsimportedTypeClassesimportedValuesExports exportedTypesexportedTypeClassesexportedValuesExportEnvironmentupdateExportedModuleaddEmptyModuleaddType addTypeClassaddValue addExportelaborateExportsrenameInModule findExports filterExports findImportsresolveImports resolveImport desugarAbs inSameGrouptoDecls isVarBindertoTuplemakeCaseDeclarationDesugar MemberMap desugarModule desugarDeclmemberToNameAndTypetypeClassDictionaryDeclaration#typeClassMemberToDictionaryAccessormkSuperclassDictionaryNameunit!typeInstanceDictionaryDeclaration parseArray parseArrayOf parseFunction parseObjectparseTypeVariableparseTypeConstructor parseForAllparseConstrainedType parseAnyTypeparseNameAndTypeparseRowEndingparseRow sourcePosparseDataDeclarationparseTypeDeclarationparseTypeSynonymDeclarationparseValueDeclarationparseExternDeclarationparseAssociativity parseFixityparseFixityDeclarationparseImportDeclarationparseDeclarationRefparseTypeClassDeclarationparseTypeInstanceDeclaration positionedparseLocalDeclarationbooleanLiteralparseNumericLiteralparseStringLiteralparseBooleanLiteralparseArrayLiteralparseObjectLiteralparseIdentifierAndValueparseAbsparseVarparseConstructor parseCaseparseCaseAlternativeparseIfThenElseparseLetparseValueAtomparsePropertyUpdate parseAccessorparseDoparseDoNotationLetparseDoNotationBindparseDoNotationElementparseStringBinderparseBooleanBinderparseNumberBinderparseVarBinderparseNullaryConstructorBinderparseConstructorBinderparseObjectBinderparseArrayBinderparseNamedBinderparseNullBinderparseIdentifierAndBinder solveTypes starIfUnknowninferinfer'$fUnifiableCheckKind $fPartialKindbuildTypeSubstitutionsaturateTypeSynonymDictionaryValueSubclassDictionaryValueDependentDictionaryValueGlobalDictionaryValueLocalDictionaryValue unifyTypes unifyRowsisTyped overTypesreplaceTypeClassDictionariesentailspairwise unifiesWithtypeHeadsAreEqualskolemEscapeChecksetify setifyAll varIfUnknowninstantiatePolyTypeWithUnknownsreplaceVarWithUnknownreplaceAllTypeSynonyms'desaturateAllTypeSynonymsexpandTypeSynonym'ensureNoDuplicateProperties inferProperty inferBinder checkBindersnewSkolemConstantnewSkolemScope skolemizeskolemizeTypesInValueintroduceSkolemScopecheckcheck'checkPropertiescheckFunctionApplicationcheckFunctionApplication'subsumes subsumes'meet UntypedDataTypeDatatypeDictionaryForBindingGroupcheckTypedBindingGroupElementtypeForBindingGroupElementreplaceAllTypeSynonymsexpandTypeSynonymexpandAllTypeSynonymsinferLetBindingcontainsTypeSynonyms$fUnifiableCheckType $fPartialType addDataTypeaddDataConstructoraddTypeSynonymvalueIsNotDefinedaddTypeClassDictionariescheckDuplicateTypeArgumentscheckTypeClassInstanceaddDefaultImporttypeCheckModule generateMainreverseDependencies importPrim importPrelude