{-# LANGUAGE DerivingStrategies #-} {-# LANGUAGE TypeFamilies #-} module Data.Monoid.LastMax where import qualified Data.Vector.Generic as G import qualified Data.Vector.Generic.Mutable as GM import qualified Data.Vector.Unboxed as U newtype LastMax a = LastMax a deriving (LastMax a -> LastMax a -> Bool (LastMax a -> LastMax a -> Bool) -> (LastMax a -> LastMax a -> Bool) -> Eq (LastMax a) forall a. Eq a => LastMax a -> LastMax a -> Bool forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a $c== :: forall a. Eq a => LastMax a -> LastMax a -> Bool == :: LastMax a -> LastMax a -> Bool $c/= :: forall a. Eq a => LastMax a -> LastMax a -> Bool /= :: LastMax a -> LastMax a -> Bool Eq, Int -> LastMax a -> ShowS [LastMax a] -> ShowS LastMax a -> String (Int -> LastMax a -> ShowS) -> (LastMax a -> String) -> ([LastMax a] -> ShowS) -> Show (LastMax a) forall a. Show a => Int -> LastMax a -> ShowS forall a. Show a => [LastMax a] -> ShowS forall a. Show a => LastMax a -> String forall a. (Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a $cshowsPrec :: forall a. Show a => Int -> LastMax a -> ShowS showsPrec :: Int -> LastMax a -> ShowS $cshow :: forall a. Show a => LastMax a -> String show :: LastMax a -> String $cshowList :: forall a. Show a => [LastMax a] -> ShowS showList :: [LastMax a] -> ShowS Show, LastMax a LastMax a -> LastMax a -> Bounded (LastMax a) forall a. a -> a -> Bounded a forall a. Bounded a => LastMax a $cminBound :: forall a. Bounded a => LastMax a minBound :: LastMax a $cmaxBound :: forall a. Bounded a => LastMax a maxBound :: LastMax a Bounded) instance (Eq a, Bounded a) => Semigroup (LastMax a) where LastMax a x <> :: LastMax a -> LastMax a -> LastMax a <> LastMax a y | LastMax a y LastMax a -> LastMax a -> Bool forall a. Eq a => a -> a -> Bool == LastMax a forall a. Bounded a => a minBound = LastMax a x | Bool otherwise = LastMax a y instance (Eq a, Bounded a) => Monoid (LastMax a) where mempty :: LastMax a mempty = LastMax a forall a. Bounded a => a minBound mconcat :: [LastMax a] -> LastMax a mconcat = [LastMax a] -> LastMax a forall a. HasCallStack => [a] -> a last ([LastMax a] -> LastMax a) -> ([LastMax a] -> [LastMax a]) -> [LastMax a] -> LastMax a forall b c a. (b -> c) -> (a -> b) -> a -> c . (LastMax a forall a. Monoid a => a mempty LastMax a -> [LastMax a] -> [LastMax a] forall a. a -> [a] -> [a] :) newtype instance U.MVector s (LastMax a) = MV_LastMax (U.MVector s a) newtype instance U.Vector (LastMax a) = V_LastMax (U.Vector a) deriving newtype instance (U.Unbox a) => GM.MVector U.MVector (LastMax a) deriving newtype instance (U.Unbox a) => G.Vector U.Vector (LastMax a) instance (U.Unbox a) => U.Unbox (LastMax a)