10000 Mendler-style paramorphism. · github/semantic@d22bd1e · GitHub
[go: up one dir, main page]

Skip to content
This repository was archived by the owner on Apr 1, 2025. It is now read-only.

Commit d22bd1e

Browse files
committed
Mendler-style paramorphism.
1 parent 809ab74 commit d22bd1e

File tree

1 file changed

+7
-0
lines changed

1 file changed

+7
-0
lines changed

semantic-analysis/src/Analysis/Syntax.hs

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -7,6 +7,7 @@ module Analysis.Syntax
77
, foldTerm
88
, paraTerm
99
, mendlerTerm
10+
, mendlerParaTerm
1011
) where
1112

1213
import qualified Data.Set as Set
@@ -47,3 +48,9 @@ mendlerTerm var sig = go
4748
where
4849
go (Var v) = var v
4950
go (Term s) = sig go s
51+
52+
mendlerParaTerm :: (v -> r) -> (forall r' . (r' -> (Term sig v, r)) -> sig r'-> r) -> (Term sig v -> r)
53+
mendlerParaTerm var sig = go
54+
where
55+
go (Var v) = var v
56+
go (Term s) = sig ((,) <*> go) s

0 commit comments

Comments
 (0)
0