----------------------------------------------------------------------------- -- -- Module : Language.PureScript.Optimizer.Unused -- Copyright : (c) Phil Freeman 2013-14 -- License : MIT -- -- Maintainer : Phil Freeman -- Stability : experimental -- Portability : -- -- | -- Removes unused variables -- ----------------------------------------------------------------------------- module Language.PureScript.Optimizer.Unused ( removeUnusedVariables, removeCodeAfterReturnStatements ) where import Data.Generics import Language.PureScript.CodeGen.JS.AST import Language.PureScript.Optimizer.Common removeUnusedVariables :: JS -> JS removeUnusedVariables = everywhere (mkT $ removeFromBlock go) where go :: [JS] -> [JS] go [] = [] go (JSVariableIntroduction var _ : sts) | not (isUsed var sts) = go sts go (s:sts) = s : go sts removeCodeAfterReturnStatements :: JS -> JS removeCodeAfterReturnStatements = everywhere (mkT $ removeFromBlock go) where go :: [JS] -> [JS] go jss | not (any isJSReturn jss) = jss | otherwise = let (body, ret : _) = span (not . isJSReturn) jss in body ++ [ret] isJSReturn (JSReturn _) = True isJSReturn _ = False