callWithBuffer function
Uint8List?
callWithBuffer(
- BufferCallback fn, {
- int? maxSize,
- int? initialSize,
- bool preferTransient = false,
- bool? allowZeroCopy,
Calls a buffer callback function with dynamically sized buffers.
Starts with initialSize or initialBufferSize and doubles the buffer
size if the callback returns -2 (buffer too small), up to maxSize or
maxBufferSize.
When maxSize is null, maxBufferSize is used.
When initialSize is null, initialBufferSize is used.
Returns the data as Uint8List on success, null on failure.
Payloads at or above zeroCopyResultThresholdBytes use a transient native
allocation and return a view with a `NativeFinalizer` when
isZeroCopyResultBufferAvailable; otherwise they copy into the Dart heap.
Implementation
Uint8List? callWithBuffer(
BufferCallback fn, {
int? maxSize,
int? initialSize,
bool preferTransient = false,
bool? allowZeroCopy,
}) {
final limit = maxSize ?? maxBufferSize;
final size = initialSize ?? initialBufferSize;
final zeroCopy = allowZeroCopy ?? isZeroCopyResultBufferAvailable;
if (zeroCopy && (preferTransient || limit >= zeroCopyResultThresholdBytes)) {
return _callWithTransientBuffer(
fn,
limit: limit,
initialSize: size,
allowZeroCopy: true,
);
}
final scratch = _sharedScratchPool.tryAcquire();
if (scratch == null) {
return _callWithTransientBuffer(
fn,
limit: limit,
initialSize: size,
allowZeroCopy: zeroCopy,
);
}
try {
return scratch.call(
fn,
limit: limit,
initialSize: size,
allowZeroCopy: zeroCopy,
);
} finally {
scratch.release();
}
}