diff options
| author | Harry Garrood <harry@garrood.me> | 2022-08-21 20:09:53 +0100 | 
|---|---|---|
| committer | Marge Bot <ben+marge-bot@smart-cactus.org> | 2022-08-25 20:06:10 -0400 | 
| commit | d387f687930e4d44c1ef569b4ec8091cb8b92765 (patch) | |
| tree | fde4990d1587d986ecdc35922ac828718a55a6e6 /libraries/base/tests | |
| parent | 46924b75c78c2fcb92cba91796bc22986c796ed3 (diff) | |
| download | haskell-d387f687930e4d44c1ef569b4ec8091cb8b92765.tar.gz | |
Add inits1 and tails1 to Data.List.NonEmpty
See https://github.com/haskell/core-libraries-committee/issues/67
Diffstat (limited to 'libraries/base/tests')
| -rw-r--r-- | libraries/base/tests/all.T | 1 | ||||
| -rw-r--r-- | libraries/base/tests/inits1tails1.hs | 48 | 
2 files changed, 49 insertions, 0 deletions
| diff --git a/libraries/base/tests/all.T b/libraries/base/tests/all.T index 7f0580b84a..9da1923e49 100644 --- a/libraries/base/tests/all.T +++ b/libraries/base/tests/all.T @@ -274,3 +274,4 @@ test('T19719', normal, compile_and_run, [''])  test('T20107', extra_run_opts('+RTS -M50M'), compile_and_run, ['-package bytestring'])  test('trace', normal, compile_and_run, [''])  test('listThreads', normal, compile_and_run, ['']) +test('inits1tails1', normal, compile_and_run, ['']) diff --git a/libraries/base/tests/inits1tails1.hs b/libraries/base/tests/inits1tails1.hs new file mode 100644 index 0000000000..a9f1a1557b --- /dev/null +++ b/libraries/base/tests/inits1tails1.hs @@ -0,0 +1,48 @@ +{-# LANGUAGE RankNTypes #-} +module Main (main) where + +import Data.List qualified as List +import Data.List.NonEmpty (NonEmpty(..)) +import Data.List.NonEmpty qualified as NEL + +-- The inits implementation added in 7.10 uses a queue rotated around +-- powers of 2, starting the rotation only at size 255, so we want to check +-- around powers of 2 and around the switch. +ranges :: [Int] +ranges = [1..20] ++ [252..259] ++ [508..515] + +nonEmptyUpTo :: Int -> NonEmpty Int +nonEmptyUpTo n | n >= 1 = NEL.fromList [1..n] +nonEmptyUpTo n = error $ "nonEmptyUpTo: invalid argument: " ++ show n + +simple :: (forall a . NonEmpty a -> [[a]]) -> [[[Int]]] +simple impl = [impl (nonEmptyUpTo n) | n <- ranges] + +nonEmptyInits1 :: NonEmpty a -> [[a]] +nonEmptyInits1 = map NEL.toList . NEL.toList . NEL.inits1 + +-- inits1 should be the same as inits on nonempty lists, except that the first +-- element should not be included +alternativeInits1 :: NonEmpty a -> [[a]] +alternativeInits1 = tail . List.inits . NEL.toList + +nonEmptyTails1 :: NonEmpty a -> [[a]] +nonEmptyTails1 = map NEL.toList . NEL.toList . NEL.tails1 + +-- tails1 should be the same as tails on nonempty lists, except that the last +-- element should not be included +alternativeTails1 :: NonEmpty a -> [[a]] +alternativeTails1 = init . List.tails . NEL.toList + +-- We want inits1 (xs <> undefined) = inits1 xs <> undefined +-- (there's no similar property for tails1 because that function starts with the +-- longest suffix) +lazinessInits1 :: Bool +lazinessInits1 = [take n (nonEmptyInits1 (nonEmptyUpTo n <> undefined)) | n <- ranges] +                  == simple nonEmptyInits1 + +main :: IO () +main | simple nonEmptyInits1 /= simple alternativeInits1 = error "inits1 failed simple test" +     | simple nonEmptyTails1 /= simple alternativeTails1 = error "tails1 failed simple test" +     | not lazinessInits1 = error "inits1 failed laziness test" +     | otherwise = return () | 
