Skip to content

Commit

Permalink
Improve documentation of customStrategy (haskell#692)
Browse files Browse the repository at this point in the history
* Clarify documentation of 'customStrategy' based on haskell#690

* Remove outdated comments on AllocationStrategy

(These were not visible in the Haddock output anyway.)
  • Loading branch information
adamgundry authored Sep 19, 2024
1 parent 3f9773d commit c967aca
Showing 1 changed file with 14 additions and 13 deletions.
27 changes: 14 additions & 13 deletions Data/ByteString/Builder/Internal.hs
Original file line number Diff line number Diff line change
Expand Up @@ -1042,14 +1042,6 @@ maximalCopySize = 2 * L.smallChunkSize
------------------------------------------------------------------------------

-- | A buffer allocation strategy for executing 'Builder's.

-- The strategy
--
-- > 'AllocationStrategy' firstBufSize bufSize trim
--
-- states that the first buffer is of size @firstBufSize@, all following buffers
-- are of size @bufSize@, and a buffer of size @n@ filled with @k@ bytes should
-- be trimmed iff @trim k n@ is 'True'.
data AllocationStrategy = AllocationStrategy
(Maybe (Buffer, Int) -> IO Buffer)
{-# UNPACK #-} !Int
Expand All @@ -1060,11 +1052,20 @@ data AllocationStrategy = AllocationStrategy
{-# INLINE customStrategy #-}
customStrategy
:: (Maybe (Buffer, Int) -> IO Buffer)
-- ^ Buffer allocation function. If 'Nothing' is given, then a new first
-- buffer should be allocated. If @'Just' (oldBuf, minSize)@ is given,
-- then a buffer with minimal size @minSize@ must be returned. The
-- strategy may reuse the @oldBuf@, if it can guarantee that this
-- referentially transparent and @oldBuf@ is large enough.
-- ^ Buffer allocation function.
--
-- * If 'Nothing' is given, then a new first buffer should be allocated.
--
-- * If @'Just' (oldBuf, minSize)@ is given, then a buffer with minimal
-- size @minSize@ must be returned. The strategy may reuse @oldBuf@ only if
-- @oldBuf@ is large enough and the consumer can guarantee that this will
-- not result in a violation of referential transparency.
--
-- /Warning:/ for multithreaded programs, it is generally unsafe to reuse
-- buffers when using the consumers of 'Builder' in this package. For
-- example, if 'toLazyByteStringWith' is called with an
-- 'AllocationStrategy' that reuses buffers, evaluating the result by
-- multiple threads simultaneously may lead to corrupted output.
-> Int
-- ^ Default buffer size.
-> (Int -> Int -> Bool)
Expand Down

0 comments on commit c967aca

Please sign in to comment.