2020-09-30 03:42:59 +00:00
|
|
|
--------------------------------------------------------------------------------
|
2022-05-19 14:39:52 +00:00
|
|
|
module Utils where
|
2020-09-30 03:42:59 +00:00
|
|
|
--------------------------------------------------------------------------------
|
2022-05-19 14:39:52 +00:00
|
|
|
import Data.Function ((&))
|
2020-09-30 03:42:59 +00:00
|
|
|
--------------------------------------------------------------------------------
|
|
|
|
|
2022-05-19 14:39:52 +00:00
|
|
|
(|>) :: a -> (a -> b) -> b
|
|
|
|
(|>) = (&)
|
|
|
|
|
|
|
|
-- | Rotate `xs` as a cycle `n` times.
|
|
|
|
rotate :: Int -> [a] -> [a]
|
|
|
|
rotate n xs = take size . drop (n `mod` size) . cycle $ xs
|
|
|
|
where size = length xs
|