1 2 3 4 5
{-# LANGUAGE PartialTypeSignatures, RankNTypes #-} module HigherRank2 where foo :: (forall a. [a] -> [a]) -> (_, _ _) foo x = (x [True, False], x ['a', 'b'])