!$      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~NoneM reform&a wrapper which lifts a value with an ' instance so that it can be used as an  or  kd :: WrappedApplicative Maybe y Char d = WrappedApplicative (Just succ) <<*>> WrappedApplicative (Just 'c')reforma class for a 'type-indexed' or  paramaterized applicative functorsrnote: not sure what the most correct name is for this class, or if it exists in a well supported library already.reform similar to reform similar to reform similar to reform similar to  reforma class for a 'type-indexed' or  paramaterized functorrnote: not sure what the most correct name is for this class, or if it exists in a well supported library already. reformimap is similar to fmap reform similar to  . An alias for imap id reform A variant of  with the arguments reversed. reformFLift a function to actions. This function may be used as a value for   in a  instance. reform"Lift a binary function to actions.reform"Lift a binary function to actions. reform$function to apply to first parameterreform%function to apply to second parameterreformindexed functor   444 4Safe'reform+A range of ID's to specify a group of formsreformAn ID used to identify formsreformGlobal prefix for the formreform:Stack indicating field. Head is most specific to this itemreformType for failing computationsreform convert a  to ! discarding the error message on  reform-The zero ID, i.e. the first ID that is usable!reformmap a function over the  [Integer] inside a reform get the head  from a "reformIncrement a form ID#reform create a  from a $reform Check if a  is contained in a %reform Check if a  is contained in another &reform%Select the errors for a certain range'reformVSelect the errors originating from this form or from any of the children of this form$reformId to check forreformRangereformIf the range contains the id%reform Sub-rangereform Larger rangereform1If the sub-range is contained in the larger range !"#$%&' !"#$%&'None=?M^Q2reforma 2 contains a 5e combined with a validation function which will attempt to extract a value from submitted form data.It is highly parameterized, allowing it work in a wide variety of different configurations. You will likely want to make a type alias that is specific to your application to make type signatures more manageable. m*A monad which can be used by the validatorinputUA framework specific type for representing the raw key/value pairs from the form dataerror.A application specific type for error messagesviewKThe type of data being generated for the view (HSP, Blaze Html, Heist, etc)proof@A type which names what has been proved about the return value. () means nothing has been proved.aEValue return by form when it is successfully decoded, validated, etc.!This type is very similar to the 2 type from digestive-functors <= 0.2. If proof is (), then 2A is an applicative functor and can be used almost exactly like digestive-functors <= 0.2.5reformA view represents a visual representation of a form. It is composed of a function which takes a list of all errors and then produces a new view8reform;The environment is where you get the actual input per form.The : constructor is typically used when generating a view for a GET request, where no data has yet been submitted. This will cause the input elements to use their supplied default values. Note that  NoEnviroment2 is different than supplying an empty environment.;reformused to represent whether a value was found in the form submission data, missing from the form submission data, or expected that the default value should be used?reforminner state used by 2.@reformiProved records a value, the location that value came from, and something that was proved about the value.Ereform2Utility Function: trivially prove nothing about ()Freform'Utility function: Get the current inputGreform1Utility function: Gets the input of an arbitrary .Hreform'Utility function: Get the current rangeIreform&Utility function: returns the current 8. This will only make sense if the form is not composedJreform(Utility function: increment the current .Lreform Run a formMreform Run a formNreformUJust evaluate the form to a view. This usually maps to a GET request in the browser.OreformEvaluate a formReturns:  Left viewon failure. The view. will have already been applied to the errors.Right a on success.Preform create a 2 from some view.+This is typically used to turn markup like <br> into a 2.QreformRAppend a unit form to the left. This is useful for adding labels or error fields.The Forms6 on the left and right hand side will share the same #. This is useful for elements like <label for="someid">4, which need to refer to the id of another element.Rreform%Append a unit form to the right. See Q.Sreform1Change the view of a form using a simple functionRThis is useful for wrapping a form inside of a <fieldset> or other markup element.TreformAUtility Function: turn a view and return value into a successful ?VreformxNot quite sure when this is useful and so hard to say if the rules for combining things with Missing/Default are correctNreform form prefixreform form to viewOreformInput environmentreformIdentifier for the formreform Form to runreformResultPreformView to insertreformResulting formSreform Manipulatorreform Initial formreformResulting form#2345678:9;>=<?@ADCBEFGHIJKLMNOPQRST#@ADCBE?;>=<FGH8:9IJ567234KLMNOPQRSTQ6R5Nonep`reform2proof that a number is also (allowed to be) signedbreform proof that a  is a Real/Fractional numberdreform proof that a  is a decimal numberfreformproof that a list is not emptyhreformA h+ attempts to prove something about a value.pIf successful, it can also transform the value to a new value. The proof should hold for the new value as well.Generally, each hK has a unique data-type associated with it which names the proof, such as: data NotNull = NotNulljreformname of the thing to provekreform!function which provides the prooflreformapply a h to a 2mreform transform a 2 using a h!, and the replace the proof with ().LThis is useful when you want just want classic digestive-functors behaviour.nreformtransform the 2 result using a monadic  function.oreformtransform the 2 result using an  function.preformprove that a list is not emptyqreform+read an unsigned number in decimal notationrreformread signed decimal numbersreformread  numbertreformread a signed  numberqreformcreate an error message (! is the value that did not parse)`abcdefghikjlmnopqrsthikjlmnofgpdebc`aqrstSafe@AHV ureform*Class which all backends should implement.vreforminput[ is here the type that is used to represent a value uploaded by the client in the request.wreformVParse the input into a string. This is used for simple text fields among other thingsxreformShould be implementedyreformParse the input value into zreform(Can be overriden for efficiency concerns{reform*Get a file descriptor for an uploaded file|reformA Class to lift a ( into an application-specific error typereformFan error type used to represent errors that are common to all backendskThese errors should only occur if there is a bug in the reform-* packages. Perhaps we should make them an  Exception so that we can get rid of the | class.reform some default error messages for reformshow input( in a format suitable for error messagesreforma u{zyxwv|~}|~}u{zyxwvNone%HVX reform$used for constructing elements like <input type="text">$, which return a single input value.reformused for elements like <input type="submit">: which are not always present in the form submission data.reformused for elements like <input type="reset">@ which take a value, but are never present in the form data set.reform used for <input type="file">reformused for groups of checkboxes, <select multiple="multiple"> boxesreformradio buttons, single <select> boxesreformradio buttons, single <select> boxesreformused to create <label> elementsreform*used to add a list of error messages to a 2This function automatically takes care of extracting only the errors that are relevent to the form element it is attached to via R or Q.reform similar to ? but includes error messages from children of the form as well.reformvalue, label, initially checkedreform!function which generates the viewreformisChecked/isSelected initiallyreform is defaultreform value, labelreform!function which generates the viewreform value, labelreform!function which generates the viewreform2function to convert the error messages into a view None,} !"#$%&'23456789:;<=>?@ABCDEFGHIJKLMNOPQRST`abcdefghijklmnopqrstuvwxyz{|}~   !"#$$%&'()*+,-./0123456789:;<==>??@AABCDEFGHHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefgghhiijjkklmnopqrstuvwxyz{|}~%reform-0.2.7.3-2muzkX9i6JyDOn6oSmAUOKControl.Applicative.IndexedText.Reform.ResultText.Reform.CoreText.Reform.ProofText.Reform.BackendText.Reform.GeneralizedControl.Applicative*><* Data.Functor<$> Text.ReformWrappedApplicativeunwrapApplicativeIndexedApplicativeipure<<*>>*>><<*IndexedFunctorimap<<$>><<**>>liftIAliftIA2liftIA3&$fIndexedApplicativeWrappedApplicative"$fIndexedFunctorWrappedApplicative$fFunctorWrappedApplicative$fApplicativeWrappedApplicative$fMonadWrappedApplicative$fEqWrappedApplicative$fOrdWrappedApplicative$fReadWrappedApplicative$fShowWrappedApplicative FormRangeFormId formIdListResultErrorOk getResultzeroIdmapIdincrementFormId unitRange isInRange isSubRange retainErrorsretainChildErrors $fShowFormId$fApplicativeResult $fMonadResult$fFunctorResult $fEqFormId $fOrdFormId $fEqFormRange$fShowFormRange $fShowResult $fEqResultFormunFormViewunView Environment NoEnvironmentValueDefaultMissingFound FormStateProvedproofsposunProved unitProved getFormInput getFormInput' getFormRange getFormId incFormId bracketStaterunFormrunForm'viewForm eitherFormview++><++mapViewmkOk$fFunctorProved$fMonoidEnvironment$fSemigroupEnvironment $fFunctorView$fApplicativeForm $fFunctorForm$fIndexedApplicativeForm$fIndexedFunctorForm $fShowProved$fSemigroupView $fMonoidViewSignedRealFractionalDecimalNotNullProof proofName proofFunctionprove transformtransformEitherMtransformEither notNullProofdecimal signedDecimalrealFracrealFracSigned FormInputFileTypegetInputStringgetInputStrings getInputText getInputTexts getInputFile FormErrorErrorInputTypecommonFormErrorCommonFormError InputMissing NoStringFound NoFileFoundMultiFilesFoundMultiStringsFoundMissingDefaultValuecommonFormErrorStr$fEqCommonFormError$fOrdCommonFormError$fShowCommonFormErrorinput inputMaybe inputNoData inputFile inputMulti inputChoiceinputChoiceFormslabelerrors childErrorsbaseGHC.Base Applicativepure<*> formPrefix GHC.MaybeMaybeformId integer-gmpGHC.Integer.TypeIntegerString Data.EitherEitherGHC.RealRealFrac text-1.2.3.1Data.Text.InternalText<>Monoidmemptymappendmconcat Data.MonoidFirstgetFirstLastgetLastApgetApData.Semigroup.InternalDualgetDualEndoappEndoAllgetAllAnygetAnySumgetSumProduct getProductAltgetAlt