W      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~ SafeAOTNone9;I &Types that support conversion to HTML.A chunk of HTML source. !Extract HTML source code from an Html value. ,Convert a chunk of HTML source code into an Html value as-is. Note that this bypasses any and all HTML encoding; the caller is responsible for taking appropriate measures against XSS and other potential vulnerabilities. In other words, the input to this function is considered pre-sanitized. "Safely convert plain text to HTML.$HTML-encode an individual character. !Html itself is a trivial instance 6String is automatically HTML-encoded and converted to "Text is automatically HTML-encoded      None=Expressions, building blocks for the expression minilanguage.#String literal expression: "foobar"!Numeric literal expression: 123.4 Boolean literal expression: true Literal nullVariable reference: foobar$List construct: [ expr, expr, expr ]1Object construct: { expr: expr, expr: expr, ... }foo[bar] (also dot access)foo(bar=baz, quux)(foo, bar) -> exprexpr ? expr : exprGinger statements. !A sequence of multiple statements!&Run wrapped statement in a local scope",Literal output (anything outside of any tag)#{{ expression }}$:{% if expression %}statement{% else %}statement{% endif %}%;{% for index, varname in expression %}statement{% endfor %}&{% set varname = expr %}'+{% macro varname %}statements{% endmacro %}){% include "template" %}*The do-nothing statement (NOP)+A block definition (  {% block %} ).A macro definition (  {% macro %} )2?Top-level data structure, representing a fully parsed template.7A context variable name.% !"#$%&'()*+,-./01234567% !"#$%&'()*+,-./01234567%723456./01+,- !"#$%&'()*  !"#$%&'()*+,-./01234567None9;<=T.=QA key/value pair, used for constructing dictionary GVals using a compact syntax.>#Types that implement conversion to A.@GA function that can be called from within a template execution context.AA variant type designed as the unitype for the template language. Any value referenced in a template, returned from within a template, or used in a template context, will be a A. m, in most cases, should be a .#Some laws apply here, most notably:when L is , then all of J, G, I, F, C, D, and K should produce when L is , then H should produce when I is not , then H should only return  for exactly zero -ness of K should match one or both of C / DC"Convert value to list, if possibleD=Convert value to association list ("dictionary"), if possibleE"Convert value to a lookup functionFRender value as HTMLGRender value as plain-textHGet value's truthinessI&Convert value to a number, if possibleJ1Access value as a callable function, if it is oneK6Get length of value, if it is a collection (list/dict)LCheck if the value is nullM1Provide a custom JSON representation of the valueNConvenience wrapper around D to represent a A as a .O]Match arguments passed to a function at runtime against a list of declared argument names. !matchFuncArgs argNames argsPassed returns ((matchedArgs, positionalArgs, namedArgs) , where  matchedArgsR is a list of arguments matched against declared names (by name or by position), positionalArgs5 are the unused positional (unnamed) arguments, and  namedArgs are the unused named arguments.P{Construct a dictionary GVal from a list of pairs. Internally, this uses a hashmap, so element order will not be preserved.QConstruct an ordered dictionary GVal from a list of pairs. Internally, this conversion uses both a hashmap (for O(1) lookup) and the original list, so element order is preserved, but there is a bit of a memory overhead.R(Construct a pair from a key and a value.S4Silly helper function, needed to bypass the default  instance of  in order to make integral s look like integers.UTurn a @ into a AV-Check if the given GVal is a list-like objectW3Check if the given GVal is a dictionary-like objectXTreat a A as a flat list and look up a value by integer index. If the value is not a List, or if the index exceeds the list length, return .YHelper function; look up a value by an integer index when the index may or may not be available. If no index is given, return .ZeStrictly-typed lookup: treat value as a dictionary-like object and look up the value at a given key.[Loosely-typed lookup: try dictionary-style lookup first (treat index as a string, and container as a dictionary), if that doesn't yield anything (either because the index is not string-ish, or because the container doesn't provide dictionary-style access), try index-based lookup.\Treat a AE as a dictionary and list all the keys, with no particular ordering.] Convert a A to a number.^ Convert a A to an e. The conversion will fail when the value is not numeric, and also if it is too large to fit in an ._Loose cast to boolean.9Numeric zero, empty strings, empty lists, empty objects, Null, and boolean S are considered falsy, anything else (including functions) is considered true-ish.`-Dynamically cast to a function. This yields  a @ if the value is a function,  if it's not.aConvert Aeson Values to Aps over an arbitrary host monad. Because JSON cannot represent functions, this conversion will never produce a @. Further, the ToJSON instance for such a A will always produce the exact Value" that was use to construct the it.b%This instance is slightly wrong; the H, I, and Ge methods all treat the HTML source as plain text. We do this to avoid parsing the HTML back into a  (and dealing with possible parser errors); the reason this instance exists at all is that we still want to be able to pass pre-rendered HTML around sometimes, and as long as we don't call any numeric or string functions on it, everything is fine. When such HTML values accidentally do get used as strings, the HTML source will bleed into the visible text, but at least this will not introduce an XSS vulnerability.-It is therefore recommended to avoid passing K values into templates, and also to avoid calling any string functions on f values inside templates (e.g. capturing macro output and then passing it through a textual filter).e*Single characters are treated as length-1 s.fString -> A conversion uses the  class; because String, is an alias for '[Char]', there is also a > instance for StringA, but it marshals strings as lists of characters, i.e., calling ?3 on a string produces a list of characters on the A side.gGBooleans render as 1 or empty string, and otherwise behave as expected.n of  becomes a dictionary-like AoHaskell lists become list-like Asp becomes NULL,  unwraps.qTrivial instance for A itself.s6Converting to HTML hooks into the ToHtml instance for W for most tags. Tags that have no obvious textual representation render as empty HTML.tFor convenience, A is implemented in a way that looks similar to JavaScript / JSONuGConversion to JSON values attempts the following conversions, in order: check the L property; if it is , always return Null!, even if the GVal implements MMCD (through N)IGDNote that the default conversions will never return booleans unless M explicitly does this, because G will always return *something*.v The default A is equivalent to NULL.:=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuv$=>?@ABKLCDEFGHIJMNOPQRSTUVWXYZ[\]^_`:ABCDEFGHIJKLMNvutsr@O>?qponmlkjih=PQRSgfedcbaTUVWXYZ[\]^_`-=>?@A BCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvR8Nonewxyz{|}wxwxwxyz{|}None 9:;<=LT~8Internal type alias for our template-runner monad stack.sExecution context. Determines how to look up variables from the environment, and how to write out template output.Create an execution context for runGingerT. Takes a lookup function, which returns ginger values into the carrier monad based on a lookup key, and a writer function (outputting HTML by whatever means the carrier monad provides, e.g. putStr for IO, or tell for Writers).Create an execution context for runGinger. The argument is a lookup function that maps top-level context keys to ginger values.  is a specialized version of , targeting the  H monad (which is what is used for the non-monadic template interpreter  runGinger).The type of the lookup function may look intimidating, but in most cases, marshalling values from Haskell to Ginger is a matter of calling ?S on them, so the 'GVal (Run (Writer Html))' part can usually be ignored. See the    module for details.!Lift a value from the host monad m into the ~ monad.$Lift a function from the host monad m into the ~ monad.~~~ None 9:;<=LTYMatch args according to a given arg spec, Python style. The return value is a triple of '(matched, args, kwargs, unmatchedNames) , where matches is a hash map of named captured arguments, args is a list of remaining unmatched positional arguments, kwargs is a list of remaining unmatched named arguments, and unmatchedNames8 contains the argument names that haven't been matched.6Parse argument list into type-safe argument structure.8Parse argument list into flat list of matched arguments.  None 9:;<=LT!!!None 9:;<=LT APurely expand a Ginger template. The underlying carrier monad is  h;, which is used to collect the output and render it into a h value.'Monadically run a Ginger template. The m parameter is the carrier monad.8Find the effective base template of an inheritance chainRun a template.2Run an action within a different template context.$Run an action within a block contextRun one statement.(Deeply magical function that converts a . into a Function.xHelper function to run a State action with a temporary state, reverting to the old state after the action has finished.xHelper function to run a Scope action with a temporary scope, reverting to the old scope after the action has finished.DRun (evaluate) an expression and return its value into the Run monad[Helper function to output a HTML value using whatever print function the context provides.~~NoneLT +Error information for Ginger parser errors.Human-readable error messageSource name, if anyLine number, if availableColumn number, if availableUsed to resolve includes. Ginger will call this function whenever it encounters an {% include %}, {% import %}, or {% extends %} directive. If the required source code is not available, the resolver should return Nothing, else Just the source.+A source identifier (typically a filename).(Input type for the parser (source code).DHelper function to create a Ginger parser error from a Parsec error. Parse Ginger source from a file. Parse Ginger source from memory.j      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ `      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ Noneh !"#$%&'()*+,-./01234567=>?@ABKLCDEFGHIJMNOPQRSTUVWXYZ[\]^_`wx~[  !"#$%&'()*+,-./01234567889::;<==>?@ABCDEFGHIJ  KLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~        !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijk%ginger-0.2.8.0-7G8ZtN2IecX1LLZhI1jmlD Text.PrintfAText.Ginger.HtmlText.Ginger.ASTText.Ginger.GValText.Ginger.OptimizerText.Ginger.RunText.Ginger.ParseText.Ginger.Run.Type Text.GingerGValText.Ginger.Run.FuncUtilsText.Ginger.Run.Builtins PrintfTypeTTunT PrintfArgTPprintfaToHtmltoHtmlHtml htmlSource unsafeRawHtmlhtml $fToHtmlHtml $fToHtml[] $fToHtmlText $fMonoidHtml $fShowHtml$fEqHtml $fOrdHtml ExpressionStringLiteralENumberLiteralE BoolLiteralE NullLiteralEVarEListEObjectE MemberLookupECallELambdaETernaryE StatementMultiSScopedSLiteralSInterpolationSIfSForSSetVarS DefMacroS BlockRefSPreprocessedIncludeSNullSBlock blockBodyMacro macroArgs macroBodyTemplate templateBodytemplateBlockstemplateParentVarName$fShowExpression$fShowStatement $fShowMacro$fShowTemplate $fShowBlockPairToGValtoGValFunctionasList asDictItemsasLookupasHtmlasText asBooleanasNumber asFunctionlengthisNullasJSON asHashMap matchFuncArgsdict orderedDict~>scientificToText rawJSONToGVal fromFunctionisListisDict lookupIndexlookupIndexMay lookupKey lookupLoosekeystoNumbertoInt toBoolean toFunction$fToGValmValue $fToGValmHtml $fToGValmText$fToGValmText0 $fToGValmChar$fIsStringGVal $fToGValmBool$fToGValm(,,,) $fToGValm(,,) $fToGValm(,)$fToGValmScientific$fToGValmInteger $fToGValmInt$fToGValmHashMap $fToGValm[]$fToGValmMaybe $fToGValmGVal$fPrintfArgGVal $fToHtmlGVal $fShowGVal $fToJSONGVal $fDefaultGVal Optimizableoptimize$fOptimizableExpression$fOptimizableMacro$fOptimizableBlock$fOptimizableStatement$fOptimizableTemplateRun GingerContext makeContextM' makeContext' makeContext makeContextMmakeContextHtmlmakeContextHtmlMmakeContextTextmakeContextTextMliftRunliftRun2 extractArgs extractArgsT extractArgsLextractArgsDefL runGinger runGingerT ParserErrorpeErrorMessage peSourceName peSourceLinepeSourceColumnIncludeResolver SourceNameSourceparseGingerFile parseGinger$fShowParserErrorhtmlEncodeChar#text-1.2.2.1-9Yh8rJoh8fO2JMLWffT3QsData.Text.InternalTextunHtmlbaseGHC.BaseMonadghc-prim GHC.TypesTrueNothingFalse2unordered-containers-0.2.7.1-5INwdG7O5Jdakf1CqKoOBData.HashMap.BaseHashMapGHC.ShowShow)scientific-0.3.4.9-JxsEP2U97KeHjUTI8Fv24jData.Scientific ScientificIntJust Data.StringIsStringoptimizeTemplateoptimizeStatement optimizeBlock optimizeMacrooptimizeStatementList cullNulls mergeLiteralsoptimizeExpressionexpandConstExpressionsoptimizeSubexpressionsisConstExpressioncompileTimeEvaltransformers-0.5.2.0Control.Monad.Trans.Writer.LazyWriterRunStatersScope rsCapturersCurrentTemplatersCurrentBlockName contextLookup contextWrite contextEncodecontextWriteEncoded liftLookup unaryFuncignoreArgNamesvariadicNumericFuncunaryNumericFuncvariadicStringFuncinjectDefaults gfnRawHtml gfnUrlEncode gfnDefault gfnEscapegfnAnygfnAll gfnEquals gfnNEquals gfnContains looseEqualsgfnLess gfnGreater gfnLessEqualsgfnGreaterEqualslessgreaterlessEq greaterEq differenceratiointRatiomodulo capitalize gfnCentergfnSlice gfnReplacegfnSortcentergfnFileSizeFormatformatFileSize gfnPrintf gfnFilterprintfG baseTemplate runTemplate withTemplate withBlockName runStatement macroToGValwithLocalStatewithLocalScope runExpressionecho defaultScope lookupBlocksetVargetVar clearCapture appendCapture fetchCapture defRunStatefromParsecErrorParser ParseStatepsBlocks ParseContext pcResolvepcCurrentSource defParseStateignore getResolverincludeincludeTemplatereduceStatements templatePderivedTemplateP baseTemplateP statementsP statementPinterpolationStmtP literalStmtP endOfLiteralP commentStmtPifStmtP elseBranchP elifBranchPsetStmtP setStmtInnerP defineBlock blockStmtPblockP macroStmtP macroHeadP callStmtP callHeadP scopeStmtPforStmtPincludePforHeadP forIteratorPforIndexedIteratorPforSimpleIteratorP forHeadInP forHeadAsP fancyTagP simpleTagPopenInterpolationPcloseInterpolationP openCommentP closeCommentPopenTagP closeTagPopenPopenWPopenNWPclosePcloseWPcloseNWP expressionP lambdaExprPoperativeExprP ternaryExprP cTernaryTailPpyTernaryTailP booleanExprPcomparativeExprP additiveExprPmultiplicativeExprP postfixExprPpostfixP dotPostfixP arrayAccessP funcCallPfuncArgP namedFuncArgPpositionalFuncArgPfilterP atomicExprPparenthesizedExprP listExprP objectExprPexpressionPairPgroupPbracedPvarExprP identifierP identCharPstringLiteralExprPstringLiteralP stringCharPnumberLiteralExprPnumberLiteralP followedBybefore