elm/compiler/Model/Libraries.hs

59 lines
No EOL
2.1 KiB
Haskell

module Libraries (libraries, addPrelude) where
import Ast
import Control.Applicative ((<$>),(<*>))
import qualified Data.Map as Map
import Data.List (inits)
import Text.JSON
import LoadLibraries as Libs
addPrelude :: Module -> Module
addPrelude (Module name exs ims stmts) = Module name exs (customIms ++ ims) stmts
where customIms = concatMap addModule prelude
addModule (n, method) = case lookup n ims of
Nothing -> [(n, method)]
Just (As m) -> [(n, method)]
Just _ -> []
prelude = text : map (\n -> (n, Hiding [])) modules
where
text = ("Text", Hiding ["link", "color", "height"])
modules = [ "Prelude", "Signal", "List", "Maybe", "Time"
, "Graphics.Element", "Color", "Graphics.Collage" ]
libraries :: Map.Map String (Map.Map String String)
libraries =
case getLibs of
Error err -> error err
Ok libs -> Map.unionWith Map.union libs nilAndTuples
where nilAndTuples = Map.singleton "Prelude" (Map.fromList pairs)
pairs =
[ ("Cons", "a -> [a] -> [a]")
, ("Nil", "[a]")
] ++ map makeTuple (inits ['a'..'i'])
makeTuple cs =
let name = "Tuple" ++ show (length cs)
in (name, concatMap (\c -> c : " -> ") cs ++
name ++ concatMap (\c -> [' ',c]) cs)
getLibs :: Result (Map.Map String (Map.Map String String))
getLibs = do
obj <- decodeStrict Libs.docs :: Result (JSObject JSValue)
modules <- valFromObj "modules" obj :: Result [JSObject JSValue]
Map.fromList `fmap` mapM getValues modules
get :: String -> JSObject JSValue -> Result String
get = valFromObj
getValue :: JSObject JSValue -> Result (String,String)
getValue obj = (,) <$> get "name" obj <*> get "type" obj
getValues :: JSObject JSValue -> Result (String, Map.Map String String)
getValues obj = do
name <- get "name" obj
vs <- valFromObj "values" obj
vals <- mapM getValue vs
return (name, Map.fromList vals)