{-# LANGUAGE PatternSynonyms, ViewPatterns #-} data F = F [Int] [Int] concatF :: F -> [Int] concatF (F xs1 xs2) = xs1 <> xs2 -- a bidirectional pattern synonym -- which -- * when used to match: returns concatenation of constructor parameter -- * when used to construct: sets the list to the first constructor parameter pattern F' :: [Int] -> F pattern F' ys <- (concatF -> ys) where F' xs = F xs [] foo :: IO () foo = do let f = F [1,2,3] [4,5,6] f' = F' [7,8,9] F' x1 = f F' x2 = f' -- prints [1,2,3,4,5,6 print x1 -- prints [7,8,9] print x2 main = foo