169 похожих чатов

А можно как-то констрейнты затащить на каинд левел? infixr 5 :&&: data

LoT k where
LoT0 :: LoT Type
(:&&:) :: k -> LoT ks -> LoT (k -> ks)

type TypeNatExpr :: forall k. k -> k -> Type
type TypeNatExpr k1 k2 = Proxy k1 -> Proxy k2 -> Type

type k1 ~> k2 = TypeNatExpr k1 k2

infixr 4 ~>

type HeadLoT :: forall k k'. LoT (k -> k') -> k -> Constraint
class HeadLoT l h | l -> h

instance HeadLoT (a :&&: as) a

type TailLoT :: forall k k'. LoT (k -> k') -> LoT k' -> Constraint
class TailLoT l t | l -> t

instance TailLoT (a :&&: as) as

type Apply :: forall k. k -> LoT k -> Type -> Constraint
class Apply x l t | l x -> t

instance Apply f LoT0 f
instance (HeadLoT as h, TailLoT as t, Apply (f h) t r) => Apply f as r

type Apply1 :: forall k. k -> LoT k -> Type
type Apply1 f as = forall r. Apply f as r => r

type TEvalN :: forall f g as. (f ~> g) -> Apply1 f as -> Apply1 g as -> Constraint
class TEvalN nat f g | nat f -> g

6 ответов

9 просмотров

Можно, это называется "Idris"

TOV_MULTIMASSO
(с) me

Раньше шутить надо было🌚

Похожие вопросы

Обсуждают сегодня

Скажите, можно ли как-то "переместить" динамический массив из одной переменной в другую? Скажем, переместить из TList<> в TArray<>. Именно переместить, а не скопировать. Если ...
Eugene Krasnikov (ᴊɪɴ x)
37
комрады, че-та лыжы не едут var tmpFont: TFont; begin tmpFont:= TFont.Create; try case rgFontColor.ItemIndex of 0: tmpFont.Color:= clWindowText; 1: tmpFo...
Ed Doc
34
.model small .stack 100h .data a db 'Hello, World!', '$' ; исходная строка b db 20 dup(?) ; строка b с запасом на максимальную длину .code main: ...
Алексей -man
3
М-да. Почему бы просто со stringlist не работать?
Michael Longneck
23
Редактор листа Excel, по сути двумерный массив ячеек. Ячейка - это экземпляр класса, у нее всякие свойства, методы. Проблема в том, что количество используемых строк и колоно...
Sergey Bodrov
2
Интересно, нет ли какого-то способа получить из dll не адрес самой метки, а адрес со смещением?
The Bird of Hermes
54
Is there a digital way to cut the electricity from a usb in linux? It sounds weird, but it's exactly what I need to do. I tried to simulate the unplug/replug but is not the ...
Eduard Rivas
15
Добавляю 100 тыс слов в TListBox. Перемешаю скролл (от ListBox). После примерно 65536 скролл резко прыгает вверх. Это что за глюк? Как фиксить, кто-нибудь знает?
Eugene Krasnikov (ᴊɪɴ x)
8
generic procedure function test<T>(param: T); type case T of longint: NewT = word; longword: NewT = byte; end; var v1: NewT; Как это можно сделать? Чтобы у меня...
notme
21
Делал задачу вот такую https://stepik.org/lesson/4985/step/9?unit=1083 получилось такое https://play.haskell.org/saved/ipKrepqe оно работает, тестов много не писал, но работае...
Fedor
22
Карта сайта