Kit Langton, автор макроса для автовайринга ZLayer, отметился в любопытном пропозале на форуме разработчиков компилятора Scala. В пропозале обсуждается синтаксический сахар для аппликативной композиции по аналогии с for-comprehension
для монадок. Если сильно упрощать смысл аппликативных вычислений до наиболее частого практического применения — это вычисление нескольких эффектов параллельно и сбор результатов в одном месте (академики, не ругайтесь).
Сейчас в популярных библиотеках параллельные вычисления описываются вспомогательными функциями, и это не особо удобно в реальности, когда собрать надо с десяток значений:
ZIO.mapParN(fetchName, fetchAge)((name, age) => User(name, age))А программисты хотят синтаксического сахарка, как если бы вычисления были последовательными:
afor {В предложенном варианте меньше бросается в глаза, что вычисления побегут в параллель, но читается он гораздо лучше. В Haskell такое расширение компилятора уже реализовано и выглядит довольно симпатично.
name <- fetchName
age <- fetchAge
} yield User(name, age)
Так вот, Kit написал работающий PoC макроса, который даёт такой синтаксис без доработок компилятора. Пока только для ZIO.
par {Макрос строит граф вычислений из обёрнутого
for {
name <- fetchName
age <- fetchAge
} yield User(name, age)
}
for-comprehension
, топологически его сортирует и параллелит всё, что можно. Утилита уже сейчас выглядит привлекательно, и может быть её втащат в ZIO, как это уже было с zio-magic.https://github.com/kitlangton/parallel-for
>>Click here to continue<<