summaryrefslogtreecommitdiff
path: root/testsuite/tests/perf/should_run/DeriveNullTermination.hs
blob: b08881c2f6ddbe25d2d743e17932ce456ff7432d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
{-# LANGUAGE DeriveFoldable #-}

module Main where

-- Trying to check if this is null from left to right or right to left
-- will produce an infinite loop.
data Ouch a = Ouch (Ouch a) a (Ouch a) deriving Foldable

ouch :: a -> Ouch a
ouch a = v where v = Ouch v a v

newtype Tuplouch a = Tuplouch (Ouch (a, Int)) deriving Foldable

main :: IO ()
main = do
  print $ null (ouch ())
  print $ null (Tuplouch (ouch ((), 3)))