-
Introduce convenience class MonadPrim
and MonadPrimBase
.
-
Add PrimMonad
and PrimBase
instances for Lazy.ST
(GHC >= 8.2).
thanks to Avi Dessauer (@Avi-D-coder) for this first contribution
-
Add freezeByteArray
and freezePrimArray
.
-
Add compareByteArrays
.
-
Add shrinkMutableByteArray
.
-
Add Eq
instances for MutableByteArray
and MutablePrimArray
.
by Andrew Martin
-
Add functions for manipulating pinned Prim Arrays
by Andrew Martin
-
Add copyPtrToMutableByteArray
.
-
Add NFData
instances for ByteArray
, MutableByteArray
,
PrimArray
and MutablePrimArray
.
by Callan McGill
-
Add shrinkSmallMutableArray
.
-
Add clonePrimArray
and cloneMutablePrimArray
.
-
Add cloneMutableByteArray
and cloneByteArray
.
-
Add Prim
instances for WordPtr
and IntPtr
.
-
Add NFData
instances for Array
and SmallArray
.
by Callan McGill
-
Add copyByteArrayToPtr
and copyMutableByteArrayToPtr
.
-
Export arrayFromList
and arrayFromListN
.
-
Introduce Data.Primitive.PrimArray
, which offers types and function
for dealing with a ByteArray
tagged with a phantom type variable for
tracking the element type.
-
Implement isByteArrayPinned
and isMutableByteArrayPinned
.
-
Add Eq1
, Ord1
, Show1
, and Read1
instances for Array
and
SmallArray
.
-
Improve the test suite. This includes having property tests for
typeclasses from base
such as Eq
, Ord
, Functor
, Applicative
,
Monad
, IsList
, Monoid
, Foldable
, and Traversable
.
-
Fix the broken IsList
instance for ByteArray
. The old definition
would allocate a byte array of the correct size and then leave the
memory unitialized instead of writing the list elements to it.
-
Fix the broken Functor
instance for Array
. The old definition
would allocate an array of the correct size with thunks for erroring
installed at every index. It failed to replace these thunks with
the result of the function applied to the elements of the argument array.
-
Fix the broken Applicative
instances of Array
and SmallArray
.
The old implementation of <*>
for Array
failed to initialize
some elements but correctly initialized others in the resulting
Array
. It is unclear what the old behavior of <*>
was for
SmallArray
, but it was incorrect.
-
Fix the broken Monad
instances for Array
and SmallArray
.
-
Fix the implementation of foldl1
in the Foldable
instances for
Array
and SmallArray
. In both cases, the old implementation
simply returned the first element of the array and made no use of
the other elements in the array.
-
Fix the implementation of mconcat
in the Monoid
instance for
SmallArray
.
-
Implement Data.Primitive.Ptr
, implementations of Ptr
functions
that require a Prim
constraint instead of a Storable
constraint.
-
Add PrimUnlifted
instances for TVar
and MVar
.
-
Use compareByteArrays#
for the Eq
and Ord
instances of
ByteArray
when building with GHC 8.4 and newer.
-
Add Prim
instances for lots of types in Foreign.C.Types
and
System.Posix.Types
.
-
Reexport Data.Primitive.SmallArray
and Data.Primitive.UnliftedArray
from Data.Primitive
.
-
Add fold functions and map function to Data.Primitive.UnliftedArray
.
Add typeclass instances for IsList
, Ord
, and Show
.
-
Add defaultSetByteArray#
and defaultSetOffAddr#
to
Data.Primitive.Types
.
-
Add Data.Primitive.MVar
, a replacement for Control.Concurrent.MVar
that can run in any PrimMonad
instead of just IO
. It is not a full
replacement. Notably, it’s missing masking functions and support for
adding finalizers.