mirror of
https://github.com/GrammaticalFramework/gf-core.git
synced 2026-05-24 02:12:50 -06:00
Split widesnake example. Changed examples to use rec and sig keywords.
This commit is contained in:
@@ -1,15 +1,15 @@
|
|||||||
Additive : Type -> Type
|
Additive : Type -> Type
|
||||||
Additive A = { zero : A; plus : A -> A -> A }
|
Additive A = sig { zero : A; plus : A -> A -> A }
|
||||||
|
|
||||||
additive_Integer : Additive Integer
|
additive_Integer : Additive Integer
|
||||||
additive_Integer = { zero = 0; plus = prim_add_Int }
|
additive_Integer = rec { zero = 0; plus = prim_add_Int }
|
||||||
|
|
||||||
sum : (A:Type) -> Additive A -> List A -> A
|
sum : (A:Type) -> Additive A -> List A -> A
|
||||||
sum _ d (Nil _) = d.zero
|
sum _ d (Nil _) = d.zero
|
||||||
sum A d (Cons _ x xs) = d.plus x (sum A d xs)
|
sum A d (Cons _ x xs) = d.plus x (sum A d xs)
|
||||||
|
|
||||||
Showable : Type -> Type
|
Showable : Type -> Type
|
||||||
Showable A = { show : A -> String }
|
Showable A = sig { show : A -> String }
|
||||||
|
|
||||||
|
|
||||||
--Compositional : Type -> Type
|
--Compositional : Type -> Type
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
Pair : Type -> Type -> Type
|
Pair : Type -> Type -> Type
|
||||||
Pair A B = { p1 : A; p2 : B }
|
Pair A B = sig { p1 : A; p2 : B }
|
||||||
|
|
||||||
pair : (A:Type) -> (B:Type) -> A -> B -> Pair A B
|
pair : (A:Type) -> (B:Type) -> A -> B -> Pair A B
|
||||||
pair _ _ x y = { p1 = x; p2 = y }
|
pair _ _ x y = rec { p1 = x; p2 = y }
|
||||||
|
|
||||||
fst : (A:Type) -> (B:Type) -> Pair A B -> A
|
fst : (A:Type) -> (B:Type) -> Pair A B -> A
|
||||||
fst _ _ p = case p of Pair _ _ x _ -> x
|
fst _ _ p = case p of Pair _ _ x _ -> x
|
||||||
|
|||||||
@@ -1,5 +1,3 @@
|
|||||||
import bool
|
|
||||||
|
|
||||||
data Cat : Type where {
|
data Cat : Type where {
|
||||||
CN : Cat ;
|
CN : Cat ;
|
||||||
NP : Cat ;
|
NP : Cat ;
|
||||||
@@ -207,17 +205,3 @@ data Tree : (_ : Cat)-> Type where {
|
|||||||
|
|
||||||
derive composOp Tree
|
derive composOp Tree
|
||||||
derive composFold Tree
|
derive composFold Tree
|
||||||
|
|
||||||
monoid_Bool = { zero = False; plus = \x -> \y -> x && y }
|
|
||||||
|
|
||||||
isSnake : (A : Tree) -> Tree A -> Bool
|
|
||||||
isSnake _ x = case x of
|
|
||||||
Snake -> True
|
|
||||||
_ -> composFold_Tree Bool monoid_Bool ? isSnake x
|
|
||||||
|
|
||||||
wideSnake : (A : Cat) -> Tree A -> Tree A
|
|
||||||
wideSnake _ x = case x of
|
|
||||||
Wide y -> let y' : CN = wideSnake ? y
|
|
||||||
in if isSnake CN y' then Thick y' else Wide y'
|
|
||||||
_ -> composOp_Tree ? wideSnake x
|
|
||||||
|
|
||||||
|
|||||||
19
transfer/examples/widesnake.tr
Normal file
19
transfer/examples/widesnake.tr
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
import bool
|
||||||
|
import stoneage
|
||||||
|
|
||||||
|
monoid_Bool : sig { zero : Bool; plus : Bool -> Bool -> Bool }
|
||||||
|
monoid_Bool = rec
|
||||||
|
zero = False
|
||||||
|
plus = \x -> \y -> x && y
|
||||||
|
|
||||||
|
isSnake : (A : Tree) -> Tree A -> Bool
|
||||||
|
isSnake _ x = case x of
|
||||||
|
Snake -> True
|
||||||
|
_ -> composFold_Tree Bool monoid_Bool ? isSnake x
|
||||||
|
|
||||||
|
wideSnake : (A : Cat) -> Tree A -> Tree A
|
||||||
|
wideSnake _ x = case x of
|
||||||
|
Wide y -> let y' : CN = wideSnake ? y
|
||||||
|
in if isSnake CN y' then Thick y' else Wide y'
|
||||||
|
_ -> composOp_Tree ? wideSnake x
|
||||||
|
|
||||||
Reference in New Issue
Block a user