Знаете ли вы, что
Scala - это Haskell в жабьей шкуре?
Если кложура сразу видна как лисп и не совсем мейнстримный язык, то скала замаскирована жабьей шкуркой от зоркого ока менеджеров, чтобы к тому времени, как до них дойдет, во что они вляпались - было уже поздно.
Язык знатно безумный, я почти Programming in Scala дочитал. И кое-какие вещи там сильно похожи на решение некоторых проблем с наследованием и зависимостями типов друг от друга, которых мне не хватало в дельфи и дотнетах :)
Если кложура сразу видна как лисп и не совсем мейнстримный язык, то скала замаскирована жабьей шкуркой от зоркого ока менеджеров, чтобы к тому времени, как до них дойдет, во что они вляпались - было уже поздно.
Язык знатно безумный, я почти Programming in Scala дочитал. И кое-какие вещи там сильно похожи на решение некоторых проблем с наследованием и зависимостями типов друг от друга, которых мне не хватало в дельфи и дотнетах :)
![[personal profile]](https://www.dreamwidth.org/img/silk/identity/user.png)




no subject
Моё решение, когда я обнаружил ошибку:
{-# LANGUAGE GADTs, KindSignatures, TypeOperators, UnicodeSyntax #-} --import Prelude.Unicode import Control.Monad.State type (a :-> b) = Term (a -> b) data Term :: * -> * where Num :: Double -> Term Double Sum :: Term Double -> Term Double -> Term Double Var :: String -> Term a Abs :: Term a -> Term b -> a :-> b App :: (a :-> b) -> a -> Term b add = Sum type MkTerm a = State Int a class MkT a where mkTerm :: MkTerm (Term a) inventVar :: MkTerm (Term a) inventVar = do modify (+1) x <- get return $ Var $ "x"++show x instance MkT b => MkT (a -> b) where mkTerm = do a <- inventVar b <- mkTerm return $ Abs a b tyoe family ToTerm a type instance ToTerm test ∷ (a -> b) -> IO () test = undefined -- main = test $ \x -> add x 0.5 -- Abs (Var "x") (Sum (Var "x") (Num 0.5))Интересно, найдёте ли вы ошибку в своём коде?no subject
А подразумевал
, конечно.
@ class MkT a
@ b <- mkTerm
@ ...
Пока не представляю, что Вы хотели этим показать. С inventVar всё понятно - это такой gensym в state-монаде,
а вот mkTerm - это какой-то конструктор канонических термов для заданных типов.
Непонятно, как он поможет погружать хаскельные лямбда-абстракции в лямбда-абстракции подъязыка.
Даже пофантазировать на эту тему особо не получается, потому что ясно, что, например, для типа Double,
mkTerm будет возвращать какой-то один и тот же терм. Как, например, это соотносится с
?
Похоже, что этот вот "MkT b => MkT (a -> b)" в "b <- mkTerm" вообще опирается исключительно на тип тела лямбда-абстракции. Как он будет погружать тело хаскельной лямбда-абстракции в подъязык, если он даже ничего о нём кроме типа не осознаёт? Для одного только типа тела Double у нас бесконечно разных термов, которые мы хотели бы погрузить в разные термы подъязыка.
no subject
no subject
no subject