{-# LANGUAGE DataKinds #-}
{-# LANGUAGE DerivingVia #-}
{-# LANGUAGE TypeFamilies #-}
{-# LANGUAGE UndecidableInstances #-}
{-# LANGUAGE UnboxedTuples #-}
module Data.Emacs.Module.Value.Internal
( Value(..)
) where
import Control.DeepSeq
import Data.Primitive.Types
import Data.Vector.Generic qualified as G
import Data.Vector.Generic.Mutable qualified as GM
import Data.Vector.Primitive qualified as P
import Data.Vector.Unboxed qualified as U
import Data.Vector.Unboxed.Base qualified as U
import GHC.Generics (Generic)
import Prettyprinter (Pretty)
import Data.Emacs.Module.Raw.Value
newtype Value (s :: k) = Value
{ forall k (s :: k). Value s -> RawValue 'Regular
unValue :: RawValue 'Regular
} deriving (Int -> Value s -> ShowS
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
forall k (s :: k). Int -> Value s -> ShowS
forall k (s :: k). [Value s] -> ShowS
forall k (s :: k). Value s -> String
showList :: [Value s] -> ShowS
$cshowList :: forall k (s :: k). [Value s] -> ShowS
show :: Value s -> String
$cshow :: forall k (s :: k). Value s -> String
showsPrec :: Int -> Value s -> ShowS
$cshowsPrec :: forall k (s :: k). Int -> Value s -> ShowS
Show, Value s -> ()
forall a. (a -> ()) -> NFData a
forall k (s :: k). Value s -> ()
rnf :: Value s -> ()
$crnf :: forall k (s :: k). Value s -> ()
NFData, forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
forall k (s :: k) x. Rep (Value s) x -> Value s
forall k (s :: k) x. Value s -> Rep (Value s) x
$cto :: forall k (s :: k) x. Rep (Value s) x -> Value s
$cfrom :: forall k (s :: k) x. Value s -> Rep (Value s) x
Generic, Addr# -> Int# -> Value s
ByteArray# -> Int# -> Value s
Value s -> Int#
forall s. Addr# -> Int# -> Int# -> Value s -> State# s -> State# s
forall s. Addr# -> Int# -> State# s -> (# State# s, Value s #)
forall s. Addr# -> Int# -> Value s -> State# s -> State# s
forall s.
MutableByteArray# s
-> Int# -> Int# -> Value s -> State# s -> State# s
forall s.
MutableByteArray# s -> Int# -> State# s -> (# State# s, Value s #)
forall s.
MutableByteArray# s -> Int# -> Value s -> State# s -> State# s
forall a.
(a -> Int#)
-> (a -> Int#)
-> (ByteArray# -> Int# -> a)
-> (forall s.
MutableByteArray# s -> Int# -> State# s -> (# State# s, a #))
-> (forall s.
MutableByteArray# s -> Int# -> a -> State# s -> State# s)
-> (forall s.
MutableByteArray# s -> Int# -> Int# -> a -> State# s -> State# s)
-> (Addr# -> Int# -> a)
-> (forall s. Addr# -> Int# -> State# s -> (# State# s, a #))
-> (forall s. Addr# -> Int# -> a -> State# s -> State# s)
-> (forall s. Addr# -> Int# -> Int# -> a -> State# s -> State# s)
-> Prim a
forall k (s :: k). Addr# -> Int# -> Value s
forall k (s :: k). ByteArray# -> Int# -> Value s
forall k (s :: k). Value s -> Int#
forall k (s :: k) s.
Addr# -> Int# -> Int# -> Value s -> State# s -> State# s
forall k (s :: k) s.
Addr# -> Int# -> State# s -> (# State# s, Value s #)
forall k (s :: k) s.
Addr# -> Int# -> Value s -> State# s -> State# s
forall k (s :: k) s.
MutableByteArray# s
-> Int# -> Int# -> Value s -> State# s -> State# s
forall k (s :: k) s.
MutableByteArray# s -> Int# -> State# s -> (# State# s, Value s #)
forall k (s :: k) s.
MutableByteArray# s -> Int# -> Value s -> State# s -> State# s
setOffAddr# :: forall s. Addr# -> Int# -> Int# -> Value s -> State# s -> State# s
$csetOffAddr# :: forall k (s :: k) s.
Addr# -> Int# -> Int# -> Value s -> State# s -> State# s
writeOffAddr# :: forall s. Addr# -> Int# -> Value s -> State# s -> State# s
$cwriteOffAddr# :: forall k (s :: k) s.
Addr# -> Int# -> Value s -> State# s -> State# s
readOffAddr# :: forall s. Addr# -> Int# -> State# s -> (# State# s, Value s #)
$creadOffAddr# :: forall k (s :: k) s.
Addr# -> Int# -> State# s -> (# State# s, Value s #)
indexOffAddr# :: Addr# -> Int# -> Value s
$cindexOffAddr# :: forall k (s :: k). Addr# -> Int# -> Value s
setByteArray# :: forall s.
MutableByteArray# s
-> Int# -> Int# -> Value s -> State# s -> State# s
$csetByteArray# :: forall k (s :: k) s.
MutableByteArray# s
-> Int# -> Int# -> Value s -> State# s -> State# s
writeByteArray# :: forall s.
MutableByteArray# s -> Int# -> Value s -> State# s -> State# s
$cwriteByteArray# :: forall k (s :: k) s.
MutableByteArray# s -> Int# -> Value s -> State# s -> State# s
readByteArray# :: forall s.
MutableByteArray# s -> Int# -> State# s -> (# State# s, Value s #)
$creadByteArray# :: forall k (s :: k) s.
MutableByteArray# s -> Int# -> State# s -> (# State# s, Value s #)
indexByteArray# :: ByteArray# -> Int# -> Value s
$cindexByteArray# :: forall k (s :: k). ByteArray# -> Int# -> Value s
alignment# :: Value s -> Int#
$calignment# :: forall k (s :: k). Value s -> Int#
sizeOf# :: Value s -> Int#
$csizeOf# :: forall k (s :: k). Value s -> Int#
Prim, forall ann. [Value s] -> Doc ann
forall ann. Value s -> Doc ann
forall a.
(forall ann. a -> Doc ann)
-> (forall ann. [a] -> Doc ann) -> Pretty a
forall k (s :: k) ann. [Value s] -> Doc ann
forall k (s :: k) ann. Value s -> Doc ann
prettyList :: forall ann. [Value s] -> Doc ann
$cprettyList :: forall k (s :: k) ann. [Value s] -> Doc ann
pretty :: forall ann. Value s -> Doc ann
$cpretty :: forall k (s :: k) ann. Value s -> Doc ann
Pretty)
newtype instance U.MVector s (Value s') = MV_Value (P.MVector s (Value s'))
newtype instance U.Vector (Value s') = V_Value (P.Vector (Value s'))
deriving via (U.UnboxViaPrim (Value s')) instance GM.MVector U.MVector (Value s')
deriving via (U.UnboxViaPrim (Value s')) instance G.Vector U.Vector (Value s')
instance U.Unbox (Value s')