{-# LANGUAGE FlexibleContexts #-} module G2.Initialization.ElimTypeSynonyms ( elimTypeSyms , elimTypeSymsTEnv) where import G2.Language import qualified Data.Map as M elimTypeSyms :: ASTContainer m Type => TypeEnv -> m -> m elimTypeSyms tenv = modifyASTsFix (elimTypeSyms' tenv) elimTypeSyms' :: TypeEnv -> Type -> Type elimTypeSyms' tenv t | (TyCon n _) <- tyAppCenter t , ts <- tyAppArgs t , Just (TypeSynonym { bound_ids = is, synonym_of = st }) <- M.lookup n tenv , length ts == length is = foldr (uncurry replaceASTs) st $ zip (map TyVar is) ts elimTypeSyms' _ t = t elimTypeSymsTEnv :: TypeEnv -> TypeEnv elimTypeSymsTEnv tenv = elimTypeSyms tenv . M.filter (not . typeSym) $ tenv typeSym :: AlgDataTy -> Bool typeSym (TypeSynonym _ _) = True typeSym _ = False