(      !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~                             !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~(c) Fumiaki Kinoshita 2017BSD3'Fumiaki Kinoshita <fumiexcel@gmail.com> Trustworthy%&*+,059:;DIOQRT  :: Getter s a -> s -> a & :: Getter s a -> (a -> r) -> (s -> r)  * :: Setter s t a b -> (a -> b) -> (s -> t)      (c) Fumiaki Kinoshita 2017BSD3'Fumiaki Kinoshita <fumiexcel@gmail.com>None%&*+,/023459:;DIOQRT Poly-kinded productPoly-kinded ConstPoly-kinded composition&The extensible data types should take k -> *T as a parameter. This class allows us to take a shortcut for direct representation. h v! is the actual representation of h v.This is an isomorphism between h v and  h v. !_Wrapper :: Iso' (h v) (Repr h v)Restricted version of .. It is useful for eliminating ambiguousness.Wrap a result of   !"#     !"#(c) Fumiaki Kinoshita 2017BSD3'Fumiaki Kinoshita <fumiexcel@gmail.com> Trustworthy%&*+,/059:;<=?DIOQRT[Ideally, it will be 'Map Succ'=The successor of the number>Converts type naturals into .@Type level binary numberEFindType typesGUnicode flipped alias for SJA readable type search resultNN k v xs is essentially identical to  (k :> v) " xs , but the type v is inferred from k and xs.PA synonym for (R)QThe kind of key-value pairsSx is a member of xsUThe position of x in the type level set xs.W Generates a U2 that corresponds to the given ordinal (0-origin).XRemember that  Member xs x from U.Z/Embodies a type equivalence to ensure that the U points the first element.[ Compare two Us.\ There is no U of an empty list.]The U points the first element^The next membership0=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefg4=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^#UVVWYZ[\]^STXGEQRPNOHIJKLM@ABC>?=FD#=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefgR0(c) Fumiaki Kinoshita 2017BSD3'Fumiaki Kinoshita <fumiexcel@gmail.com> Trustworthy%&*+,059:;DIOQRTijklmnoijklmnoijklmnoijklmnok5(c) Fumiaki Kinoshita 2017BSD3'Fumiaki Kinoshita <fumiexcel@gmail.com>None%&*+,059:;<=DIOQRT qEvery element in xs satisfies crEnumerate all possible Us of xs with an additional context.t(Every type-level list is an instance of t.uEnumerate all possible Us of xs.v Count the number of memberships.w Enumerate Us and construct an i.xThis class allows us to use y for both sums and products.zAccessor for an element.{Like z%, but reckon membership from its key.|-Access a specified element through a wrapper.}$Access an element through a wrapper.~>Access an element specified by the key type through a wrapper.pqrstuvwxyz{|}~#EGHIJKLMNOPQRSTUWXZ[pqrstuvwxyz{|}~#xyz{|}~UW[ZSTXGEtuvwqrspQRPNOHIJKLMpqrstuvwxyz{|}~(c) Fumiaki Kinoshita 2017BSD3'Fumiaki Kinoshita <fumiexcel@gmail.com>None$%&*+,059:;<=BDIOQRT The type of extensible products. (:*) :: (k -> *) -> [k] -> *A pointer to an element in a .Mutable type-indexed struct.Write a value in a .Read a value from a .Get a  from a name. Create a new  using the supplied initializer. Create a  full of the specified value. Create a new / using the supplied initializer with a context. Create a new  from an HList.Turn ) into an immutable product. The original  may not be used. Create a new  from a product.The size of a product.$Right-associative fold of a product.Convert a product into an HList. Create a new ! using the contents of a product.Get an element in a product.Create a product from an  action which returns a .!(c) Fumiaki Kinoshita 2017BSD3'Fumiaki Kinoshita <fumiexcel@gmail.com>None%&*+,/059:;<=DIOQRTbThe extensible sum type (:|) :: (k -> *) -> [k] -> *Change the wrapper.O(1) lift a value."Try to extract something you want."Try to extract something you want.O(1) Naive pattern matchThere is no empty union.&Embed a value, but focuses on its key. 1 (c) Fumiaki Kinoshita 2017BSD3'Fumiaki Kinoshita <fumiexcel@gmail.com> Trustworthy$%&*+,/059:;<=DIOQRT:O(n) Prepend an element onto a product. Expressions like a <: b <: c <: nil are transformed to a single .Strict version of ().An empty product.Convert  into a product.Flipped -Map a function to every element of a product.;Transform every element in a product, preserving the order.   "a   (f . g) "a  f .  g  for heterogeneous product for heterogeneous product1Map elements to a monoid and combine the results.  f .  g "a  (f . g)! with the membership of elements.$ with a constraint for each element.$ with a constraint for each element.<Traverse all elements and combine the result sequentially.  htraverse (fmap f . g) "a fmap (hmap f) . htraverse g htraverse pure "a pure htraverse (Comp . fmap g . f) "a Comp . fmap (htraverse g) . htraverse f  analog for extensible products The dual of  The dual of  with Us.*A product filled with the specified value.3Construct a product using a function which takes a U.  f ( g) "a  (f . g)  ( m) "a m  ( k) "a k  version of .Pure version of .*A product filled with the specified value. version of .Accumulate sums on a product.  haccum =  Group sums by type.$Evaluate every element in a product.)qrstuvw)tuvwqrs00 None%&*+,059:;<=DIOQRT%Composition for a class and a wrapperForall upon a wrapper0Reify a collection of dictionaries, as you wish. (c) Fumiaki Kinoshita 2017BSD3'Fumiaki Kinoshita <fumiexcel@gmail.com>None%&*+,059:;<=DIOQRT  Similar to , but this focuses on keys. xs (k ':> v) is equivalent to N k v xsys contains xsUnicode alias for 'Reify the inclusion of type level sets.O(n) Select some elements.O(1) Embed to a larger union.'Reify the inclusion of type level sets.O(n) Select some elements.O(1) Embed to a larger union.   (c) Fumiaki Kinoshita 2017BSD3'Fumiaki Kinoshita <fumiexcel@gmail.com>None%&*+,059:;DIOQRT)Turn a wrapper type into a clause for it.ORetrieve the contents so that they matches and pass both to the given function.$Applies a function to the result of .O(1) Perform pattern matching.Flipped 0 (c) Fumiaki Kinoshita 2017BSD3'Fumiaki Kinoshita <fumiexcel@gmail.com>None%&*+,/059:;<=DIOQRT*A ghostly type which spells the field name!Signifies a field name internally4When you see this type as an argument, it expects a  FieldLensA. This type is used to resolve the name of the field internally."The trivial inextensible data type FieldOptic s; is a type of optics that points a field/constructor named s.The yielding fields can be  Jhttp://hackage.haskell.org/package/lens/docs/Control-Lens-Lens.html#t:LensLenses for s and  Khttp://hackage.haskell.org/package/lens/docs/Control-Lens-Lens.html#t:PrismPrisms for s. ( "foo" = Associate "foo" a xs => Lens' ( xs) a ) "foo" = Associate "foo" a xs => Prism' ( xs) a s can be generated using mkField defined in the Data.Extensible.TH module.Simple variant Simple record The dual of  )VariantOf :: (v -> *) -> [Assoc k v] -> *1The type of records which contain several fields. (RecordOf :: (v -> *) -> [Assoc k v] -> *A  h (k ':> v) is h v annotated with the field name k.  :: (v -> *) -> Assoc k v -> *Combined constraint for QTake the type of the valueTake the type of the key Proxy-level . This is useful when using . Lift a function for the content. Lift a function for the content. An empty .*Select a corresponding field of a variant.Pattern matching on a #Annotate a value by the field name. foo :: - '["num" >: Int, "str" >: String] foo = #num = 42 <: #str = "foo" <: nil Lifted ()  foo :: IO (? '["num" >: Int, "str" >: String]) foo = hsequence $ #num < => readLn  :#str <@= getLine <: nil @+Annotate a value by the field name without .'Kind-monomorphic, unwrapped version of ('=')@ Shows in field @= value" style instead of the derived one.    1111(c) Fumiaki Kinoshita 2017BSD3'Fumiaki Kinoshita <fumiexcel@gmail.com>None%&*+,059:;DIOQRT5Throwing an exceptionAn effect with no result(,) already is a writer monad.fThe reader monad is characterised by a type equality between the result type and the enviroment type. [a, b, c] r is a -> b -> c -> r )Anonymous representation of instructions.#Transformation between effects&A function to bind an ( in ..' The extensible operational monad(.A unit of named effects. This is a variant of (:|)! specialised for 'Type -> Type'.*Lift an instruction onto an ' action.+Lift an instruction onto an '+ action and apply a function to the result.,/Censor a specific type of effects in an action.-Upcast an action..7Build a relay-style handler from a triple of functions. `runStateEff = peelEff1 (a s -> return (a, s)) (m k s -> let (a, s') = runState m s in k a s') /./ specialised for continuations with no argument0.( specialised for 1-argument continuation1*A common value for the second argument of .!. Binds an instruction directly.2/A pre-defined value for the second argument of ... Preserves the argument of the continuation.3/A pre-defined value for the second argument of ./. Preserves two arguments of the continuation.4Reveal the final result of '.5Tear down an action using the  instance of the instruction.6 Process an ' action using a record of #s.7Pass the arguments of   to the supplied function.8 Create a  of a # for an  .9Specialised version of . for  s. You can pass a function a -> b -> ... -> (q -> r) -> r as a handler for   '[a, b, ...] q.:$Non continuation-passing variant of 9.;Fetch the environment.<#Pass the environment to a function.=Modify the enviroment locally.>Run the frontal reader effect.?Get the current state.@%Pass the current state to a function.A#Replace the state with a new value.BModify the state.C#Lift a state modification function.DRun the frontal state effect.E8Run the frontal state effect and return the final state.F9Run the frontal state effect and return the final result.G6Write the second element and return the first element.HWrite a value.I/Squash the outputs into one step and return it.J3Modify the output using the function in the result.KRun the frontal writer effect.LRun the frontal state effect.M,Run an effect which may fail in the name of k.NThrow an exception e,, throwing the rest of the computation away.O"Attach a handler for an exception.PRun an action and abort on N.Q!Put a milestone on a computation.R*Run a computation until the first call of Q.S$Place a continuation-passing action.TUnwrap a continuation.< !"#$%&'()*+,-.Re-bind an unrelated actionreturn the result%Handle the foremost type of an action/return the result%Handle the foremost type of an action0return the result%Handle the foremost type of an action123456789Re-bind an unrelated actionreturn the resultHandle the foremost action:Handle the foremost action;<=>?@ABCDEFGHIJKLMNOPQRST= !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRST=()'*+,-#$%6.&1/20345 !"789:;<=>?@ABCDEFGHIJKLMNOPQRST7 !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRST81(c) Fumiaki Kinoshita 2017BSD3'Fumiaki Kinoshita <fumiexcel@gmail.com>None%&*+,059:;<=DIOQRT Wmtl-compatible writerXmtl-compatible stateYmtl-compatible readerZSpecialised version of > compatible with the  instance.[D specialised for the  instance.\F specialised for the  instance.]E specialised for the  instance.^^ specialised for the  instance.__ specialised for the  instance.` Similar to  runMaybeT , but on 'a Similar to  , but on 'c A bit dubiousUVWXYZ[\]^_`abcdefgh UVWXYZ[\]^_`a YZX[\]W^_V`UaUVWXYZ[\]^_`abcdefgh(c) Fumiaki Kinoshita 2017BSD3'Fumiaki Kinoshita <fumiexcel@gmail.com>None%&*+,059:;<=DIOQRTiSpecialised version of ~.ijkikijijk(c) Fumiaki Kinoshita 2017BSD3'Fumiaki Kinoshita <fumiexcel@gmail.com>None%&*+,059:;DIOQRT[l Wrapped Maybeo Apply a function to its content.pThe inverse of .qA product filled with l r,Extend a product and fill missing fields by Null.s)Narrow the range of the sum, if possible. lmnopqrstulmnopqrsqprslmnolmnopqrstu(c) Fumiaki Kinoshita 2017BSD3'Fumiaki Kinoshita <fumiexcel@gmail.com> Trustworthy%&*+,059:;DIOQRT[{Alias for plain sums|Alias for plain products}O(log n) Add a plain value to a product.~Extract a plain value.Embed a plain value.)Naive pattern matching for a plain value.%An accessor for newtype constructors.{|}~{|}~|{}~{|}~}51(c) Fumiaki Kinoshita 2017BSD3'Fumiaki Kinoshita <fumiexcel@gmail.com>None%&*+,059:;DIOQRT[3The class of types that can be converted to/from a .Convert a value into a . Convert a  to a value. 5record :: IsRecord a => Iso' a (Record (RecFields a)) Create an * instance for a normal record declaration.  (c) Fumiaki Kinoshita 2017BSD3'Fumiaki Kinoshita <fumiexcel@gmail.com> Trustworthy$%&*+,059:;DIOQRT[Generate fields using ~.  "foo Bar" defines: Rfoo :: FieldOptic "foo" foo = itemAssoc (Proxy :: Proxy "foo") _Bar :: FieldOptic Bar" _Bar = itemAssoc (Proxy :: Proxy Bar) /Generate named effects from a GADT declaration. LdecEffects [d| data Blah a b x where Blah :: Int -> a -> Blah a b b |]  generates type Blah a b = "Blah" >: Action '[Int, a] b blah :: forall xs a b . Associate "Blah" (Action '[Int, a] b) xs => Int -> a -> Eff xs b blah a0 a1 = liftEff (Data.Proxy.Proxy :: Data.Proxy.Proxy "Blah") (AArgument a0 (AArgument a1 AResult)) WInstead of making a type synonym for individual actions, it defines a list of actions.KGenerates type synonyms for the set of actions and also individual actions.(generate a synonym of the set of actions(generate synonyms for individual actions(c) Fumiaki Kinoshita 2017BSD3'Fumiaki Kinoshita <fumiexcel@gmail.com>None%&*+,059:;DIOQRT h xs mA is the monad of computations that may depend on the elements in xs.#Hitch an element associated to the  through a wrapper.6Take a value from the tangles. The result is memoized.Run a 8 action and return the result and the calculated values.Run a  action.-Run tangles and collect all the results as a .  tangle matrixpre-calculated values tangle matrixpre-calculated values tangle matrixpre-calculated values  (c) Fumiaki Kinoshita 2017BSD3'Fumiaki Kinoshita <fumiexcel@gmail.com>None%&*+,059:;DIOQRT EGHIJKLMNOPQRSTUWXZ[pqrstuvwxyz{|}~ !"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTilmnopqrs{|}~  !"#$%&'())**+,,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{|}~                                            ! " # $ % & ' ( ) * +,-./012344567889:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\]^_`abcdefghijklmnopqrstuvwxyz{{|}~n  'extensible-0.4.4-CixIO0KcyNmJDpejwnuKSEData.Extensible.EffectData.Extensible.Internal.RigData.Extensible.WrapperData.Extensible.InternalData.Extensible.HListData.Extensible.ClassData.Extensible.StructData.Extensible.SumData.Extensible.ProductData.Extensible.DictionaryData.Extensible.InclusionData.Extensible.MatchData.Extensible.FieldData.Extensible.Effect.DefaultData.Extensible.LabelData.Extensible.NullableData.Extensible.PlainData.Extensible.RecordData.Extensible.THData.Extensible.TangleLHListData.ExtensiblebaseData.Functor.IdentityIdentitytransformers-0.5.2.0Control.Monad.Trans.ContContT Control.Monad.Trans.State.StrictStateExchangeOptic'OpticviewviewsoverwithIsoreview$fProfunctorExchangeProdConst' getConst'CompgetCompWrapperRepr_Wrapper _WrapperAscomp $fMonoidProd$fSemigroupProd$fWrapperkProd $fNFDataProd$fWrapperkProxy$fWrapperkConst'$fWrapperkComp$fWrapperTYPE[]$fWrapperTYPEMaybe$fWrapperTYPEIdentity $fShowComp$fEqComp $fOrdComp $fNFDataComp $fGenericComp$fSemigroupComp $fMonoidComp $fShowConst' $fEqConst' $fOrdConst'$fGenericConst'$fNFDataConst'$fFunctorConst'$fFoldableConst'$fTraversableConst' $fShowProd$fEqProd $fOrdProd $fGenericProd $fFunctorProd$fFoldableProd$fTraversableProd$fTraversableComp$fFoldableComp $fFunctorCompSucc KnownPositiontheIntNatZeroDNatSDNatLastFindTypeHead∈ FindAssoc Elaborate Elaborated ExpectingMissing Duplicate Associate association>:Assoc:>Member membership Membership getMemberId mkMembershiprememberreifyMembership leadershipcompareMembershipimpossibleMembershipherenavNext$fKnownPositionNatSDNat$fKnownPositionNatDNat$fKnownPositionNatZero$fSemigroupMembership$fOrdMembership$fEqMembership$fShowMembership$fAssociatevkkvxs $fMemberkxsx$fNFDataMembershipHNilHCons htraversehtraverseWithIndexhfoldrWithIndexhlengthForallFForall henumerateForhgenerateListForGenerate henumeratehcount hgenerateList ExtensiblepieceAtpiece pieceAssocitemAtitem itemAssoc $fForallac: $fForallkc[] $fGeneratek: $fGeneratek[]:*WrappedPointerStructsetget atomicModify atomicModify' atomicModify_atomicModify'_-$>new newRepeatnewFor newFromHList unsafeFreezethawtoHListnewFromhlookuphfrozenhmodify$fExtensiblekfp:*$fHasUpdateWrappedPointeraa$fHasSetterWrappedPointera$fHasGetterWrappedPointera:|EmbedAthoistembedstrikestrikeAt<:|exhaust embedAssoc$fExtensiblekfp:| $fBounded:|$fEnum:|<:@:>@==$fProfunctorLabelPhantom$fExtensiblekfpInextensible $fShowField$fWrapperAssocField$fKeyValuevkpkpv:>$fGenericField $fNFDataField$fBoundedField $fEnumField $fMonoidField$fStorableField$fSemigroupField$fRealFracField$fRealFloatField $fRealField$fFloatingField$fFractionalField$fIntegralField $fNumField $fOrdField $fEqField EitherEffMaybeEff WriterEff ReaderEffFunctionActionAResult AArgument InterpreterrunInterpreterRebinderEff InstructionliftEffliftsEffhoistEffcastEffpeelEffpeelEff0peelEff1 rebindEff0 rebindEff1 rebindEff2leaveEff retractEff handleEff runAction@!? peelAction peelAction0askEffasksEfflocalEff runReaderEffgetEffgetsEffputEff modifyEffstateEff runStateEff execStateEff evalStateEff writerEfftellEff listenEffpassEff runWriterEff execWriterEff runMaybeEffthrowEffcatchEff runEitherEfftickEff runIterEffcontEff runContEff EitherDefMaybeDef WriterDefStateDef ReaderDef runReaderDef runStateDef evalStateDef execStateDef runWriterDef execWriterDef runMaybeDef runEitherDef$fMonadPlusSkeleton$fAlternativeSkeleton$fMonadErroreSkeleton$fMonadWriterwSkeleton$fMonadStatesSkeleton$fMonadReaderrSkeleton$fMonadIOSkeleton訊$fIsLabelk(->)$fIsLabelkProxyNullable getNullable mapNullable coinclusionvacancywrenchretrench$fMonoidNullable$fWrapperkNullable$fShowNullable $fEqNullable $fOrdNullable$fGenericNullable$fNFDataNullableOneOfAllOf<%pluckbury<%| accessingIsRecord RecFieldsrecordFromList recordToListtoRecord fromRecordrecordderiveIsRecord $fIsRecord()mkField mkFieldAs decEffects decEffectSetdecEffectSuitecustomDecEffectsTangleT unTangleTlassohitchAt runTangleT evalTangleT runTangles$fMonoidTangleT$fSemigroupTangleT$fMonadTransTangleT$fFunctorTangleT$fApplicativeTangleT$fMonadTangleTGHC.BasefmapMapSuccghc-prim GHC.TypesWord MapSuccKey Remembrance~~Data.Type.Equalityouterinnerapply gcastWithcastWithtranssym:~:Refl TestEquality testEquality== Data.Proxy asProxyTypeOfProxyKProxyproxyKeyGHC.STSTHProductnewDict newForDictunsafeMembershipidGHC.ListzipWithzipWith3Data.Traversablesequence ApplicativegetAssociation Associated' GHC.TypeLits symbolValMonad contState contWriter mtl-2.2.1-BLKBelFsPB3BoFeSWSOYj6Control.Monad.Reader.Class MonadReaderControl.Monad.State.Class MonadStateControl.Monad.Writer.Class MonadWriterControl.Monad.Trans.Except runExceptTpReaderpStatepWriterpEitherNothingtvName shape2Pat shape2Expcon2EfffromMangledGADTvarsT effectFunD effectFunT uniqueNames typeListT associateT effClause