primitive
Primitive memory-related operations
https://github.com/haskell/primitive
| LTS Haskell 24.16: | 0.9.1.0 | 
| Stackage Nightly 2025-10-25: | 0.9.1.0 | 
| Latest on Hackage: | 0.9.1.0 | 
primitive-0.9.1.0@sha256:dfdd6572944c11e69208237dd32a2eb9d975b4f4e9064a7b8dc952cb0e256846,3119Module documentation for 0.9.1.0
This package provides various primitive memory-related operations.
Changes
Changes in version 0.9.1.0
- 
Make fromListN functions good consumers for list fusion. 
- 
Add functions to improve MutVar’s interoperability withIORefandSTRef.
- 
Add createPrimArrayandcreateByteArray.
- 
Add byteArrayAsForeignPtrandmutableByteArrayAsForeignPtr.
- 
Use copyMutableByteArrayNonOverlapping#in the implementation ofcopyMutableByteArrayon sufficiently new GHCs. This does not change the contract forcopyMutableByteArray. This function has always been documented as having undefined behavior when the slices overlap. However, overlaps previously were handled gracefully (with the semantics of C’smemmove). Going forward, users who do not upholdcopyMutableByteArray’s precondition will be met with unpredictable results.
- 
Drop support for GHC 8.0. 
Changes in version 0.9.0.0
- 
Add withByteArrayContents,withMutableByteArrayContents,withPrimArrayContents,withMutablePrimArrayContents.
- 
Fix signature of keepAlive.
- 
Remove re-export of fromListandfromListNfromData.Primitive.Array.
- 
Use mutableByteArrayContents#in GHC 9.2+
- 
Add Priminstance forComplex.
- 
Add getSizeofSmallMutableArraythat wrapsgetSizeofSmallMutableArray#fromGHC.Exts.
- 
Add default definitions for the setByteArray#andsetOffAddr#methods, so they don’t need to be defined explicitly anymore.
- 
Add standalone sizeOfType/alignmentOfType(recommended oversizeOf/alignment) andPrimclass methodssizeOfType#/alignmentOfType#(recommended oversizeOf#/alignment#)
- 
Change Showinstances ofPrimArray,Array, andSmallArray. These previously used thefromListN n [...]form, but they now used the more terse[...]form.
- 
Correct the Readinstances ofArrayandSmallArray. These instances are supposed to be able to handle all three of these forms:fromList [...],fromListN n [...], and[...]. They had been rejected the last form, but this mistake was discovered by the test suite when the Show instances were changed.
Changes in version 0.8.0.0
- 
Add resizeSmallMutableArraythat wrapsresizeSmallMutableArray#fromGHC.Exts.
- 
New module Data.Primitive.PrimVar. This is essentiallyPrimArraywith element length 1. For types withPriminstances, this is a drop-in replacement forMutVarwith fewer indirections.
- 
PrimArray’s type argument has been given a nominal role instead of a phantom role. This is a breaking change.
- 
Add readCharArray,writeCharArray,indexCharArrayfor operating on 8-bit characters in a byte array.
- 
When building with base-4.17and newer, re-export theByteArrayandMutableByteArraytypes frombaseinstead of defining them in this library. This does not change the user-facing interface ofData.Primitive.ByteArray.
- 
Add keepAlivethat wrapskeepAlive#for GHC 9.2 and newer. It falls back to usingtouchfor older GHCs.
Changes in version 0.7.4.0
- 
Add Lift instances (#332) 
- 
Expose copyPtrToMutablePrimArray
- 
Improve definitions for stimes (#326) 
- 
Support GHC 9.4. Note: GHC 9.4 is not released at the time of primitive-0.7.4.0’s release, so this support might be reverted by a hackage metadata revision if things change. 
- 
Drop support for GHC 7.10 
Changes in version 0.7.3.0
- 
Correct implementations of *>forArrayandSmallArray.
- 
Drop support for GHC < 7.10 
- 
Export runByteArrayandrunPrimArray.
- 
Export createArrayandcreateSmallArray.
- 
Export emptyByteArray,emptyPrimArray,emptyArrayandemptySmallArray.
Changes in version 0.7.2.0
- 
Add thawByteArrayandthawPrimArray.
- 
Changed the Showinstance ofByteArray, so that all 8-bit words are rendered as two digits. For example, display0x0Dinstead of0xD.
Changes in version 0.7.1.0
- 
Introduce convenience class MonadPrimandMonadPrimBase.
- 
Add PrimMonadandPrimBaseinstances forLazy.ST(GHC >= 8.2). thanks to Avi Dessauer (@Avi-D-coder) for this first contribution
- 
Add freezeByteArrayandfreezePrimArray.
- 
Add compareByteArrays.
- 
Add shrinkMutableByteArray.
- 
Add Eqinstances forMutableByteArrayandMutablePrimArray. by Andrew Martin
- 
Add functions for manipulating pinned Prim Arrays by Andrew Martin 
- 
Add copyPtrToMutableByteArray.
- 
Add NFDatainstances forByteArray,MutableByteArray,PrimArrayandMutablePrimArray. by Callan McGill
- 
Add shrinkSmallMutableArray.
- 
Add clonePrimArrayandcloneMutablePrimArray.
- 
Add cloneMutableByteArrayandcloneByteArray.
- 
Add Priminstances forWordPtrandIntPtr.
- 
Add NFDatainstances forArrayandSmallArray. by Callan McGill
- 
Add copyByteArrayToPtrandcopyMutableByteArrayToPtr.
- 
Export arrayFromListandarrayFromListN.
Changes in version 0.7.0.1
- Allow building with GHC 8.12. Thanks Ryan GL Scott for this and every compat patch over time.
Changes in version 0.7.0.0
- 
Remove Addrdata type, lifted code should usePtr anow
- 
Define MonadFailinstances forArrayandSmallArray.
- 
Define unsafeInterleave.
- 
Add a Priminstance forStablePtr
- 
Remove UnliftedArrayand related type classes
- 
Add a lot more tests for PrimArray.
- 
Added PrimMonad instance for CPS Writer and RWS monads from Transformers 
- 
Remove useless accidental laziness in atomicModifyMutVar, making it matchatomicModifyIORef. The semantics should be the same.
- 
lots of little documentation twiddles. 
Changes in version 0.6.4.1
- 
Add instances for the following newtypes from base:Const,Identity,Down,Dual,Sum,Product,First,Last,Min,Max
- 
Add base-orphansdependency to test suite to accomodate older versions of GHC not having instances ofShowandEqfor some of the above newtypes.
Changes in version 0.6.4.0
- 
Introduce Data.Primitive.PrimArray, which offers types and function for dealing with aByteArraytagged with a phantom type variable for tracking the element type.
- 
Implement isByteArrayPinnedandisMutableByteArrayPinned.
- 
Add Eq1,Ord1,Show1, andRead1instances forArrayandSmallArray.
- 
Improve the test suite. This includes having property tests for typeclasses from basesuch asEq,Ord,Functor,Applicative,Monad,IsList,Monoid,Foldable, andTraversable.
- 
Fix the broken IsListinstance forByteArray. 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 Functorinstance forArray. 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 Applicativeinstances ofArrayandSmallArray. The old implementation of<*>forArrayfailed to initialize some elements but correctly initialized others in the resultingArray. It is unclear what the old behavior of<*>was forSmallArray, but it was incorrect.
- 
Fix the broken Monadinstances forArrayandSmallArray.
- 
Fix the implementation of foldl1in theFoldableinstances forArrayandSmallArray. 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 mconcatin theMonoidinstance forSmallArray.
- 
Implement Data.Primitive.Ptr, implementations ofPtrfunctions that require aPrimconstraint instead of aStorableconstraint.
- 
Add PrimUnliftedinstances forTVarandMVar.
- 
Use compareByteArrays#for theEqandOrdinstances ofByteArraywhen building with GHC 8.4 and newer.
- 
Add Priminstances for lots of types inForeign.C.TypesandSystem.Posix.Types.
- 
Reexport Data.Primitive.SmallArrayandData.Primitive.UnliftedArrayfromData.Primitive.
- 
Add fold functions and map function to Data.Primitive.UnliftedArray. Add typeclass instances forIsList,Ord, andShow.
- 
Add defaultSetByteArray#anddefaultSetOffAddr#toData.Primitive.Types.
- 
Add Data.Primitive.MVar, a replacement forControl.Concurrent.MVarthat can run in anyPrimMonadinstead of justIO. It is not a full replacement. Notably, it’s missing masking functions and support for adding finalizers.
Changes in version 0.6.3.0
- 
Add PrimMonadinstances forContT,AccumT, andSelectTfromtransformers
- 
Add Eq,Ord,Show, andIsListinstances forByteArray
- 
Add Semigroupinstances forArrayandSmallArray. This allowsprimitiveto build on GHC 8.4 and later.
Changes in version 0.6.2.0
- 
Drop support for GHCs before 7.4 
- 
SmallArraysupport
- 
ArrayArray#based support for more efficient arrays of unlifted pointer types
- 
Make Arrayand the like instances of various classes for convenient use
- 
Add Priminstances for Ptr and FunPtr
- 
Add ioToPrim,stToPrimand unsafe counterparts for situations that would otherwise require type ascriptions onprimToPrim
- 
Add evalPrim
- 
Add PrimBaseinstance forIdentityT
Changes in version 0.6.1.0
- 
Use more appropriate types in internal memset functions, which prevents overflows/segfaults on 64-bit systems. 
- 
Fixed a warning on GHC 7.10 
- 
Worked around a -dcore-lint bug in GHC 7.6/7.7 
Changes in version 0.6
- 
Split PrimMonad into two classes to allow automatic lifting of primitive operations into monad transformers. The internaloperation has moved to thePrimBaseclass.
- 
Fixed the test suite on older GHCs 
Changes in version 0.5.4.0
- 
Changed primitive_ to work around an oddity with GHC’s code generation on certain versions that led to side effects not happening when used in conjunction with certain very unsafe IO performers. 
- 
Allow primitive to build on GHC 7.9 
Changes in version 0.5.3.0
- Implement cloneArrayandcloneMutableArrayprimitives (with fall-back implementations for GHCs prior to version 7.2.1)
Changes in version 0.5.2.1
- 
Add strict variants of MutVarmodification functionsatomicModifyMutVar'andmodifyMutVar'
- 
Fix compilation on Solaris 10 with GNU C 3.4.3 
Changes in version 0.5.1.0
- Add support for GHC 7.7’s new primitive Boolrepresentation
Changes in version 0.5.0.1
- Disable array copying primitives for GHC 7.6.* and earlier
Changes in version 0.5
- 
New in Data.Primitive.MutVar:atomicModifyMutVar
- 
Efficient block fill operations: setByteArray,setAddr
Changes in version 0.4.1
- New module Data.Primitive.MutVar
Changes in version 0.4.0.1
- Critical bug fix in fillByteArray
Changes in version 0.4
- 
Support for GHC 7.2 array copying primitives 
- 
New in Data.Primitive.ByteArray:copyByteArray,copyMutableByteArray,moveByteArray,fillByteArray
- 
Deprecated in Data.Primitive.ByteArray:memcpyByteArray,memcpyByteArray',memmoveByteArray,memsetByteArray
- 
New in Data.Primitive.Array:copyArray,copyMutableByteArray
- 
New in Data.Primitive.Addr:copyAddr,moveAddr
- 
Deprecated in Data.Primitive.Addr:memcpyAddr
