module Data.Record.HT.Private where
import Data.Monoid (mconcat, )
import Data.List.HT (switchL, )
{-# INLINE compare #-}
compare :: [a -> a -> Ordering] -> a -> a -> Ordering
compare :: forall a. [a -> a -> Ordering] -> a -> a -> Ordering
compare [a -> a -> Ordering]
cs a
x a
y =
forall a. Monoid a => [a] -> a
mconcat forall a b. (a -> b) -> a -> b
$ forall a b. (a -> b) -> [a] -> [b]
map (\a -> a -> Ordering
c -> a -> a -> Ordering
c a
x a
y) [a -> a -> Ordering]
cs
{-# INLINE compare1 #-}
compare1 :: [a -> a -> Ordering] -> a -> a -> Ordering
compare1 :: forall a. [a -> a -> Ordering] -> a -> a -> Ordering
compare1 [a -> a -> Ordering]
cs a
x a
y =
forall b a. b -> (a -> [a] -> b) -> [a] -> b
switchL Ordering
EQ forall a b. a -> b -> a
const forall a b. (a -> b) -> a -> b
$ forall a. (a -> Bool) -> [a] -> [a]
dropWhile (Ordering
EQforall a. Eq a => a -> a -> Bool
==) forall a b. (a -> b) -> a -> b
$ forall a b. (a -> b) -> [a] -> [b]
map (\a -> a -> Ordering
c -> a -> a -> Ordering
c a
x a
y) [a -> a -> Ordering]
cs
{-# INLINE compare2 #-}
compare2 :: [a -> a -> Ordering] -> a -> a -> Ordering
compare2 :: forall a. [a -> a -> Ordering] -> a -> a -> Ordering
compare2 [a -> a -> Ordering]
cs a
x a
y =
forall a. [a] -> a
head forall a b. (a -> b) -> a -> b
$ forall a. (a -> Bool) -> [a] -> [a]
dropWhile (Ordering
EQforall a. Eq a => a -> a -> Bool
==) (forall a b. (a -> b) -> [a] -> [b]
map (\a -> a -> Ordering
c -> a -> a -> Ordering
c a
x a
y) [a -> a -> Ordering]
cs) forall a. [a] -> [a] -> [a]
++ [Ordering
EQ]
{-# INLINE equal #-}
equal :: [a -> a -> Bool] -> a -> a -> Bool
equal :: forall a. [a -> a -> Bool] -> a -> a -> Bool
equal [a -> a -> Bool]
cs a
x a
y = forall (t :: * -> *) a. Foldable t => (a -> Bool) -> t a -> Bool
all (\a -> a -> Bool
c -> a -> a -> Bool
c a
x a
y) [a -> a -> Bool]
cs