module Data.List.Match.Private where
import Data.Maybe (fromJust, isNothing, )
import Data.Maybe.HT (toMaybe, )
import Data.Tuple.HT (mapFst, forcePair, )
import Data.Bool.HT (if', )
import qualified Data.List as List
import Control.Functor.HT (void, )
import Prelude hiding (take, drop, splitAt, replicate, )
take :: [b] -> [a] -> [a]
take :: forall b a. [b] -> [a] -> [a]
take = forall a b c. (a -> b -> c) -> [a] -> [b] -> [c]
zipWith (forall a b c. (a -> b -> c) -> b -> a -> c
flip forall a b. a -> b -> a
const)
drop :: [b] -> [a] -> [a]
drop :: forall b a. [b] -> [a] -> [a]
drop [b]
xs [a]
ys0 =
forall (t :: * -> *) b a.
Foldable t =>
(b -> a -> b) -> b -> t a -> b
foldl (\[a]
ys b
_ -> forall a. [a] -> [a]
laxTail [a]
ys) [a]
ys0 [b]
xs
dropRec :: [b] -> [a] -> [a]
dropRec :: forall b a. [b] -> [a] -> [a]
dropRec (b
_:[b]
xs) (a
_:[a]
ys) = forall b a. [b] -> [a] -> [a]
dropRec [b]
xs [a]
ys
dropRec [b]
_ [a]
ys = [a]
ys
drop0 :: [b] -> [a] -> [a]
drop0 :: forall b a. [b] -> [a] -> [a]
drop0 [b]
xs [a]
ys =
forall a b. (a -> b) -> [a] -> [b]
map forall a. HasCallStack => Maybe a -> a
fromJust (forall a. (a -> Bool) -> [a] -> [a]
dropWhile forall a. Maybe a -> Bool
isNothing
(forall a b c. (a -> b -> c) -> [a] -> [b] -> [c]
zipWith (forall a. Bool -> a -> Maybe a
toMaybe forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (t :: * -> *) a. Foldable t => t a -> Bool
null) (forall a. (a -> a) -> a -> [a]
iterate forall a. [a] -> [a]
laxTail [b]
xs) [a]
ys))
drop1 :: [b] -> [a] -> [a]
drop1 :: forall b a. [b] -> [a] -> [a]
drop1 [b]
xs [a]
ys =
forall a b. (a -> b) -> [a] -> [b]
map forall a b. (a, b) -> b
snd (forall a. (a -> Bool) -> [a] -> [a]
dropWhile (Bool -> Bool
not forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (t :: * -> *) a. Foldable t => t a -> Bool
null forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a b. (a, b) -> a
fst) (forall a b. [a] -> [b] -> [(a, b)]
zip (forall a. (a -> a) -> a -> [a]
iterate forall a. [a] -> [a]
laxTail [b]
xs) [a]
ys))
drop2 :: [b] -> [a] -> [a]
drop2 :: forall b a. [b] -> [a] -> [a]
drop2 [b]
xs [a]
ys =
forall a b. (a, b) -> b
snd forall a b. (a -> b) -> a -> b
$ forall a. [a] -> a
head forall a b. (a -> b) -> a -> b
$
forall a. (a -> Bool) -> [a] -> [a]
dropWhile (Bool -> Bool
not forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (t :: * -> *) a. Foldable t => t a -> Bool
null forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a b. (a, b) -> a
fst) forall a b. (a -> b) -> a -> b
$
forall a b. [a] -> [b] -> [(a, b)]
zip (forall a. (a -> a) -> a -> [a]
iterate forall a. [a] -> [a]
laxTail [b]
xs) (forall a. (a -> a) -> a -> [a]
iterate forall a. [a] -> [a]
laxTail [a]
ys)
laxTail :: [a] -> [a]
laxTail :: forall a. [a] -> [a]
laxTail [a]
xt = case [a]
xt of [] -> []; a
_:[a]
xs -> [a]
xs
laxTail0 :: [a] -> [a]
laxTail0 :: forall a. [a] -> [a]
laxTail0 = forall a. Int -> [a] -> [a]
List.drop Int
1
splitAt :: [b] -> [a] -> ([a],[a])
splitAt :: forall b a. [b] -> [a] -> ([a], [a])
splitAt [b]
nt [a]
xt =
forall a b. (a, b) -> (a, b)
forcePair forall a b. (a -> b) -> a -> b
$
case ([b]
nt,[a]
xt) of
(b
_:[b]
ns, a
x:[a]
xs) -> forall a c b. (a -> c) -> (a, b) -> (c, b)
mapFst (a
xforall a. a -> [a] -> [a]
:) forall a b. (a -> b) -> a -> b
$ forall b a. [b] -> [a] -> ([a], [a])
splitAt [b]
ns [a]
xs
([b]
_, [a]
xs) -> ([],[a]
xs)
takeRev :: [b] -> [a] -> [a]
takeRev :: forall b a. [b] -> [a] -> [a]
takeRev [b]
ys [a]
xs = forall b a. [b] -> [a] -> [a]
drop (forall b a. [b] -> [a] -> [a]
drop [b]
ys [a]
xs) [a]
xs
dropRev :: [b] -> [a] -> [a]
dropRev :: forall b a. [b] -> [a] -> [a]
dropRev [b]
ys [a]
xs = forall b a. [b] -> [a] -> [a]
take (forall b a. [b] -> [a] -> [a]
drop [b]
ys [a]
xs) [a]
xs
equalLength :: [a] -> [b] -> Bool
equalLength :: forall a b. [a] -> [b] -> Bool
equalLength [a]
xs [b]
ys =
forall (f :: * -> *) a. Functor f => f a -> f ()
void [a]
xs forall a. Eq a => a -> a -> Bool
== forall (f :: * -> *) a. Functor f => f a -> f ()
void [b]
ys
compareLength :: [a] -> [b] -> Ordering
compareLength :: forall a b. [a] -> [b] -> Ordering
compareLength [a]
xs [b]
ys =
forall a. Ord a => a -> a -> Ordering
compare (forall (f :: * -> *) a. Functor f => f a -> f ()
void [a]
xs) (forall (f :: * -> *) a. Functor f => f a -> f ()
void [b]
ys)
compareLength0 :: [a] -> [b] -> Ordering
compareLength0 :: forall a b. [a] -> [b] -> Ordering
compareLength0 =
let recourse :: [a] -> [a] -> Ordering
recourse (a
_:[a]
xs) (a
_:[a]
ys) = [a] -> [a] -> Ordering
recourse [a]
xs [a]
ys
recourse [] [] = Ordering
EQ
recourse (a
_:[a]
_) [] = Ordering
GT
recourse [] (a
_:[a]
_) = Ordering
LT
in forall a b. [a] -> [b] -> Ordering
recourse
compareLength1 :: [a] -> [b] -> Ordering
compareLength1 :: forall a b. [a] -> [b] -> Ordering
compareLength1 [a]
xs [b]
ys =
forall a. Ord a => a -> a -> Ordering
compare (forall (t :: * -> *) a. Foldable t => t a -> Int
length [a]
xs) (forall (t :: * -> *) a. Foldable t => t a -> Int
length [b]
ys)
lessOrEqualLength :: [a] -> [b] -> Bool
lessOrEqualLength :: forall a b. [a] -> [b] -> Bool
lessOrEqualLength [] [b]
_ = Bool
True
lessOrEqualLength [a]
_ [] = Bool
False
lessOrEqualLength (a
_:[a]
xs) (b
_:[b]
ys) = forall a b. [a] -> [b] -> Bool
lessOrEqualLength [a]
xs [b]
ys
shorterList :: [a] -> [a] -> [a]
shorterList :: forall a. [a] -> [a] -> [a]
shorterList [a]
xs [a]
ys =
let useX :: Bool
useX = forall a b. [a] -> [b] -> Bool
lessOrEqualLength [a]
xs [a]
ys
in forall a b c. (a -> b -> c) -> [a] -> [b] -> [c]
zipWith (forall a. Bool -> a -> a -> a
if' Bool
useX) [a]
xs [a]
ys
shorterListEq :: (Eq a) => [a] -> [a] -> [a]
shorterListEq :: forall a. Eq a => [a] -> [a] -> [a]
shorterListEq [a]
xs [a]
ys =
let useX :: Bool
useX = forall a b. [a] -> [b] -> Bool
lessOrEqualLength [a]
xs [a]
ys
in forall a b c. (a -> b -> c) -> [a] -> [b] -> [c]
zipWith (\a
x a
y -> forall a. Bool -> a -> a -> a
if' (a
xforall a. Eq a => a -> a -> Bool
==a
y Bool -> Bool -> Bool
|| Bool
useX) a
x a
y) [a]
xs [a]
ys
replicate :: [a] -> b -> [b]
replicate :: forall a b. [a] -> b -> [b]
replicate [a]
xs b
y =
forall b a. [b] -> [a] -> [a]
take [a]
xs (forall a. a -> [a]
repeat b
y)