adamc@7: type c1 = t :: Type -> t adamc@1: con c2 :: Type = t :: Type -> t adamc@1: con c3 = fn t :: Type => c1 adamc@1: con c4 = c3 c1 adamc@1: con c5 = (fn t :: Type => c1) c1 adamc@1: adamc@1: con name = #MyName adamc@1: adamc@1: con c6 = {A : c1, name : c2} adamc@1: con c7 = [A = c1, name = c2] adamc@5: adamc@5: con c8 = fn t :: Type => t adamc@6: adamc@6: con c9 = {} adamc@6: con c10 = ([]) :: {Type} adamc@8: adamc@8: val v1 = fn t :: Type => fn x : t => x adamc@11: val v2 = v1 [t :: Type -> t -> t] v1 adamc@12: adamc@12: val r = {X = v1, Y = v2} adamc@12: val v1_again = r.X adamc@12: val v2_again = r.Y adamc@12: adamc@12: val r2 = {X = {}, Y = v2, Z = {}} adamc@12: val r2_X = r2.X adamc@12: val r2_Y = r2.Y adamc@12: val r2_Z = r2.Z adamc@12: adamc@12: val f = fn fs :: {Type} => fn x : $([X = {}] ++ fs) => x.X adamc@12: val f2 = fn fs :: {Type} => fn x : $(fs ++ [X = {}]) => x.X adamc@12: val f3 = fn fs :: {Type} => fn x : $([X = {}, Y = {Z : {}}] ++ fs) => x.X adamc@12: val f4 = fn fs :: {Type} => fn x : $([X = {}, Y = {Z : {}}] ++ fs) => x.Y adamc@12: val f5 = fn fs1 :: {Type} => fn fs2 :: {Type} => fn x : $(fs1 ++ [X = {}] ++ fs2) => x.X adamc@12: val f6 = fn fs1 :: {Type} => fn fs2 :: {Type} => fn x : $(fs1 ++ [X = {}] ++ fs2 ++ [Y = {Z : {}}]) => x.X adamc@12: val f7 = fn fs1 :: {Type} => fn fs2 :: {Type} => fn x : $(fs1 ++ [X = {}] ++ fs2 ++ [Y = {Z : {}}]) => x.Y adamc@12: adamc@12: val test = f [[Y = t :: Type -> t -> t, Z = {}]] r2 adamc@12: val test = f7 [[Y = t :: Type -> t -> t]] [[Z = {}]] r2