Skip to content

Commit

Permalink
added Ptr arrays
Browse files Browse the repository at this point in the history
  • Loading branch information
BebeSparkelSparkel committed Jun 30, 2024
1 parent de5d0a5 commit 76dc63e
Showing 1 changed file with 22 additions and 3 deletions.
25 changes: 22 additions & 3 deletions mutable-containers/src/Data/Mutable/Class.hs
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,10 @@ import qualified Data.Vector.Primitive.Mutable as MPV
import qualified Data.Vector.Storable.Mutable as MSV
import qualified Data.Vector.Unboxed.Mutable as MUV
import qualified GHC.Arr
import qualified Foreign.Marshal.Array as Foreign
import Foreign.Ptr (Ptr)
import Foreign.Storable (Storable)
import qualified Foreign.Storable as Foreign

-- | The parent typeclass for all mutable containers.
--
Expand Down Expand Up @@ -72,6 +76,8 @@ instance MutableContainer (MUV.MVector s a) where
type MCState (MUV.MVector s a) = s
instance MutableContainer (GHC.Arr.STArray s i e) where
type MCState (GHC.Arr.STArray s i e) = s
instance MutableContainer (Ptr a) where
type MCState (Ptr a) = PrimState IO

-- | Typeclass for single-cell mutable references.
--
Expand Down Expand Up @@ -227,7 +233,7 @@ instance MPV.Prim a => MutableCollection (MPV.MVector s a) where
type CollElement (MPV.MVector s a) = a
newColl = MPV.new 0
{-# INLINE newColl #-}
instance MSV.Storable a => MutableCollection (MSV.MVector s a) where
instance Storable a => MutableCollection (MSV.MVector s a) where
type CollElement (MSV.MVector s a) = a
newColl = MSV.new 0
{-# INLINE newColl #-}
Expand All @@ -239,6 +245,10 @@ instance (GHC.Arr.Ix i, Num i) => MutableCollection (GHC.Arr.STArray s i e) wher
type CollElement (GHC.Arr.STArray s i e) = e
newColl = primToPrim $ GHC.Arr.newSTArray (0,0) undefined
{-# INLINE newColl #-}
instance Storable a => MutableCollection (Ptr a) where
type CollElement (Ptr a) = a
newColl = primToPrim $ Foreign.mallocArray 0
{-# INLINE newColl #-}

-- | Containers that can be initialized with n elements.
class MutableCollection c => MutableInitialSizedCollection c where
Expand All @@ -254,7 +264,7 @@ instance MPV.Prim a => MutableInitialSizedCollection (MPV.MVector s a) where
type CollIndex (MPV.MVector s a) = Int
newCollOfSize = MPV.new
{-# INLINE newCollOfSize #-}
instance MSV.Storable a => MutableInitialSizedCollection (MSV.MVector s a) where
instance Storable a => MutableInitialSizedCollection (MSV.MVector s a) where
type CollIndex (MSV.MVector s a) = Int
newCollOfSize = MSV.new
{-# INLINE newCollOfSize #-}
Expand All @@ -266,6 +276,10 @@ instance (GHC.Arr.Ix i, Num i) => MutableInitialSizedCollection (GHC.Arr.STArray
type CollIndex (GHC.Arr.STArray s i e) = i
newCollOfSize x = primToPrim $ GHC.Arr.newSTArray (0,x) undefined
{-# INLINE newCollOfSize #-}
instance Storable a => MutableInitialSizedCollection (Ptr a) where
type CollIndex (Ptr a) = Int
newCollOfSize = primToPrim . Foreign.mallocArray
{-# INLINE newCollOfSize #-}

class MutableInitialSizedCollection c => MutableIndexing c where
readIndex :: (PrimMonad m, PrimState m ~ MCState c) => c -> CollIndex c -> m (CollElement c)
Expand All @@ -280,7 +294,7 @@ instance MPV.Prim a => MutableIndexing (MPV.MVector s a) where
{-# INLINE readIndex #-}
writeIndex = MPV.write
{-# INLINE writeIndex #-}
instance MSV.Storable a => MutableIndexing (MSV.MVector s a) where
instance Storable a => MutableIndexing (MSV.MVector s a) where
readIndex = MSV.read
{-# INLINE readIndex #-}
writeIndex = MSV.write
Expand All @@ -295,6 +309,11 @@ instance (GHC.Arr.Ix i, Num i) => MutableIndexing (GHC.Arr.STArray s i e) where
{-# INLINE readIndex #-}
writeIndex c i e = primToPrim $ GHC.Arr.writeSTArray c i e
{-# INLINE writeIndex #-}
instance Storable a => MutableIndexing (Ptr a) where
readIndex p i = primToPrim $ Foreign.peekElemOff p i
{-# INLINE readIndex #-}
writeIndex p i e = primToPrim $ Foreign.pokeElemOff p i e
{-# INLINE writeIndex #-}

-- | Take a value from the front of the collection, if available.
--
Expand Down

0 comments on commit 76dc63e

Please sign in to comment.