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

FoldThese1 :: Monoid m => [These m b] -> These

m [b]
foldThese1 [] = This mempty
foldThese1 (x:xs) = fmap ($[])
$ foldl'
(\a b -> case a of
This xa -> case b of
This ya -> This (xa <> ya)
That _ -> This xa
These ya _ -> This (xa<>ya)
That xb -> case b of
This ya -> This ya
That yb -> That (xb .(yb:))
These ya yb -> These ya (xb .(yb:))
These xa xb -> case b of
This ya -> This (xa <> ya)
That yb -> These xa (xb .(yb:))
These ya yb -> These (xa<>ya) (xb .(yb:))) (fmap (\t -> (t:)) x) xs

А вот такое адищще как-то проще же выражается?
Смысл мы проходимся по всем веткам, собираем все ошибки (Here (This a, These a), если среди данных не было таких, где только ошибка (This) то собираем все There (That b, These _ b), ну и за 1 проход это

2 ответов

16 просмотров

https://hackage.haskell.org/package/these-1.1/docs/Data-These.html - эти These?

foldMap1 pure ? (Ну заменить просты списки на дифф-листы)

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

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

Добрый вечер. Есть вопрос, а может и предложение. Был у меня диалог в другой группе о делфи и я задался вопросом: "А нельзя ли в делфи цвет //коментария и {комментария} сде...
Kraszx
24
Всем привет! Подскажи, пожалуйста, как передать в TComboBox сразу значение и id записи. На Delphi я делал так: ComboBox1.Items.AddObject('Какое-то значение', Pointer(id запис...
Евгений
13
Мдя, прикол, боевая сборка запускается (именно под отладчиком) после F9 примерно полторы минуты (97 секунд если быть точным). Начал копать - проблема детектится сразу - зависа...
Александр (Rouse_) Багель
38
Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
50
Товарищи, кто работа с iphelper? Или может я в самой логике ошибки фигачу, не пойму.... var ifTable : PMIB_IFTABLE; size, corSize: DWORD; Buffer ...
Warfarellen
4
я так понимаю, я так подозреваю, что создание такого плагина для человека, кто умеет писать плагины для делфи потребует минут 5-10 времени. но это мое подозрение. хотелось бы ...
Kraszx
7
Коллеги, добрый вечер. Создаю коллекцию от TFPGMap, ключ - перечисление, значение - целое. Нужно отсортировать коллекцию по значению. Как это можно сделать?
Kirill Filippenok
11
Скажи а ты когда этот канал создавал ты уже дельфи не любил, или это со временем пришло?
Роман Лях (rgreat)
18
Привет, такой вопросик появился кажется ли вам что Rust слишком сложный/строгий для высокоуровневого программирования и слишком "безопасный"/строгий для низкоуровневого?
Крокант
10
Всем привет! Использую кастомное модальное диалоговое окошко, все по классике - mrOK, mrCancel как ModalResult. Однако есть нюанс - в главной форме есть универсальный обработч...
Олег Гранишевский
20
Карта сайта