{-# LANGUAGE DerivingStrategies #-}
{-# LANGUAGE TypeFamilies #-}

module Data.Monoid.LastMin where

import qualified Data.Vector.Generic as G
import qualified Data.Vector.Generic.Mutable as GM
import qualified Data.Vector.Unboxed as U

newtype LastMin a = LastMin a
  deriving (LastMin a -> LastMin a -> Bool
(LastMin a -> LastMin a -> Bool)
-> (LastMin a -> LastMin a -> Bool) -> Eq (LastMin a)
forall a. Eq a => LastMin a -> LastMin a -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: forall a. Eq a => LastMin a -> LastMin a -> Bool
== :: LastMin a -> LastMin a -> Bool
$c/= :: forall a. Eq a => LastMin a -> LastMin a -> Bool
/= :: LastMin a -> LastMin a -> Bool
Eq, Int -> LastMin a -> ShowS
[LastMin a] -> ShowS
LastMin a -> String
(Int -> LastMin a -> ShowS)
-> (LastMin a -> String)
-> ([LastMin a] -> ShowS)
-> Show (LastMin a)
forall a. Show a => Int -> LastMin a -> ShowS
forall a. Show a => [LastMin a] -> ShowS
forall a. Show a => LastMin a -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: forall a. Show a => Int -> LastMin a -> ShowS
showsPrec :: Int -> LastMin a -> ShowS
$cshow :: forall a. Show a => LastMin a -> String
show :: LastMin a -> String
$cshowList :: forall a. Show a => [LastMin a] -> ShowS
showList :: [LastMin a] -> ShowS
Show, LastMin a
LastMin a -> LastMin a -> Bounded (LastMin a)
forall a. a -> a -> Bounded a
forall a. Bounded a => LastMin a
$cminBound :: forall a. Bounded a => LastMin a
minBound :: LastMin a
$cmaxBound :: forall a. Bounded a => LastMin a
maxBound :: LastMin a
Bounded)

instance (Eq a, Bounded a) => Semigroup (LastMin a) where
  LastMin a
x <> :: LastMin a -> LastMin a -> LastMin a
<> LastMin a
y
    | LastMin a
y LastMin a -> LastMin a -> Bool
forall a. Eq a => a -> a -> Bool
== LastMin a
forall a. Bounded a => a
maxBound = LastMin a
x
    | Bool
otherwise = LastMin a
y

instance (Eq a, Bounded a) => Monoid (LastMin a) where
  mempty :: LastMin a
mempty = LastMin a
forall a. Bounded a => a
maxBound
  mconcat :: [LastMin a] -> LastMin a
mconcat = [LastMin a] -> LastMin a
forall a. HasCallStack => [a] -> a
last ([LastMin a] -> LastMin a)
-> ([LastMin a] -> [LastMin a]) -> [LastMin a] -> LastMin a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (LastMin a
forall a. Monoid a => a
mempty LastMin a -> [LastMin a] -> [LastMin a]
forall a. a -> [a] -> [a]
:)

newtype instance U.MVector s (LastMin a) = MV_LastMin (U.MVector s a)
newtype instance U.Vector (LastMin a) = V_LastMin (U.Vector a)
deriving newtype instance (U.Unbox a) => GM.MVector U.MVector (LastMin a)
deriving newtype instance (U.Unbox a) => G.Vector U.Vector (LastMin a)
instance (U.Unbox a) => U.Unbox (LastMin a)