{-# LANGUAGE MagicHash, UnboxedSums, NoImplicitPrelude #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE MultiParamTypeClasses #-}
{-# LANGUAGE FunctionalDependencies #-}
{-# LANGUAGE TypeInType #-}
{-# LANGUAGE GADTs #-}
{-# LANGUAGE UnboxedTuples #-}
{-# LANGUAGE PatternSynonyms#-}
{-# LANGUAGE BangPatterns #-}
module Data.Unboxed.Maybe where
import GHC.Exts
data family Maybe (x :: TYPE (r :: RuntimeRep))
data instance Maybe (a :: * ) where
  MaybeSum :: !(# a  | (# #) #) -> Maybe a
pattern Just :: ( a :: *) -> Maybe a
pattern Just a <-  MaybeSum (# !a | #) where
  Just !a = MaybeSum (# a | #)
pattern Nothing :: forall (a :: *) .  Maybe a
pattern Nothing = MaybeSum (# | (# #) #)
type TypeUnlifted = TYPE 'UnliftedRep
data instance Maybe (x :: TYPE 'UnliftedRep) where
  MaybeSumU :: !(# x | (# #) #) -> Maybe (x :: TYPE 'UnliftedRep)
pattern JustU :: forall (x :: TypeUnlifted) . x -> Maybe x
pattern JustU  a <- MaybeSumU (#  !a |  #) where
  JustU !a = MaybeSumU (# a |   #)