{-# LANGUAGE TemplateHaskell #-} {-# LANGUAGE ViewPatterns #-} 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)]) []