Releases: fizruk/free-foil
v0.2.0
- Generate
COMPLETE
pragma inmkPatternSynonyms
(see #26) - Polykind
ZipMatchK
class with default generic implementation viakind-generics
(see #27) - New experimental TH generation for Free Foil with support for rich syntax in
Control.Monad.Free.Foil.TH.MkFreeFoil
(see #28)
v0.1.0
-
Generalize functions for binders, support general patterns (see #16)
-
Add
withPattern
method toCoSinkable
. It can be seen as a CPS-style traversal over binders in a pattern.
Our Template Haskell support covers generation ofwithPattern
,
so normally the user does not have to think about it. -
Generalize many functions to work with arbitrary patterns, not just
NameBinder
:withFreshPattern
— towithRefreshedPattern
andwithRefreshedPattern'
extendScopePattern
— extend a given scope with all binders in a given patternnamesOfPattern
— collect all names from a patternunsinkNamePattern
— try to unsink names from a scope extended with binders from a given patternassertDistinctPattern
— establish that extended scope is distinct (if outer scope is)assertDistinctExt
— establish that extended scope is distinct and indeed an extension
-
Implement unification for patterns in
unifyPatterns
.
This turns out to be one of the most difficult places, especially for compound patterns.
Implementing patterns properly on the user side not comfortable at all!
Luckily, we provide useful helpers likeandThenUnifyPatterns
andandThenUnifyNameBinders
,
as well as Template Haskell support to deriveUnifiablePattern
. -
Generalize Free Foil to support arbitrary patterns.
-
The
Foil
andFreeFoilTH
implementations now make use of the generalized pattern support.
-
v0.0.3
-
Add α-equivalence checks and α-normalization (see #12):
Control.Monad.Foil
now offers more helpers to work with binder renaming and binder unification.
These helpers can be used to implement (efficient) α-equivalence.- In
Control.Monad.Free.Foil
general implementation of α-equivalence and α-normalization is provided.
-
Add general conversion functions for free foil (see #14):
Control.Monad.Free.Foil
now offersconvertToAST
andconvertFromAST
functions
enabling easier implementation of conversions raw and scope-safe representations.
-
Add Template Haskell functions for free foil (see #14):
Control.Monad.Free.Foil.TH
contains many useful functions to generate free foil from
a raw representation (e.g. generated via BNFC), including generation of the signature,
convenient pattern synonyms,ZipMatch
instance, and conversion helpers.