УМННБJ, ЯХВ. Войти !bnw Сегодня Клубы

Удобное приведение типов, теперь и в х-ле!

import Data.Maybe (fromJust)
import Data.Aeson (decode, encode)

jsonCast :: (ToJSON a, FromJSON b) => a -> b
jsonCast = head . fromJust . decode . encode . (:[])

Теперь можно кастовать список интов в вектор даблов. Или различные числовые типы между собой.

♥ jsonCast ([1,2,3] :: [Int]) :: Data.Vector.Vector Double
    fromList [1.0, 2.0, 3.0]
♥ let q = jsonCast; a=3::Int; b=1.3::Float; c=Just 10
♥ q a + q b + q c :: Double
    14.3
Рекомендовали: @ulidtko
#6TVM85 / @fix / 3846 дней назад

На самом деле можно [более типобезопасно]( http://pastebin.com/raw.php?i=Avm3rdaS ), только надо что-нибудь придумать, чтобы не писать 2N² инстансов.
#6TVM85/C8V / @fix / 3846 дней назад
эмм, а `fmap fromIntegral` не покатит?
#6TVM85/LBW / @ulidtko / 3846 дней назад
@ulidtko Это только частный случай.
#6TVM85/1B2 / @fix --> #6TVM85/LBW / 3846 дней назад
@fix лан
#6TVM85/X47 / @ulidtko --> #6TVM85/1B2 / 3846 дней назад
@ulidtko не то
#6TVM85/GAM / @fix --> #6TVM85/3L8 / 3846 дней назад
@fix всё то // нешаришь
#6TVM85/3TP / @ulidtko --> #6TVM85/GAM / 3846 дней назад
@ulidtko лан
#6TVM85/CG4 / @238328 --> #6TVM85/3TP / 3846 дней назад
ipv6 ready BnW для ведрофона BnW на Реформале Викивач Котятки

Цоперайт © 2010-2016 @stiletto.