module Network.Lastfm.TH where
import Language.Haskell.TH
instances ∷ String → [(String, String)] → Q [Dec]
instances f = mapM (instanceDeclaration "Argument")
where instanceDeclaration (mkName → tc) (mkName → n, m) = instanceD (cxt []) (appT (conT tc) (conT n)) [first, second]
where first = funD (mkName "key") [clause [] (normalB [e| const m |]) []]
second = let var = mkName "a"
func = mkName f
in funD (mkName "value") [clause [conP n [varP var]] (normalB $ appE (varE func) (varE var)) []]
newtypes ∷ String → [String] → Q [Dec]
newtypes (mkName → t) (map mkName → ns) = mapM newtypeDeclaration ns
where newtypeDeclaration n = newtypeD (cxt []) n [] (normalC n [strictType notStrict (conT t)]) []