callWithBuffer function
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.
Implementation
Uint8List? callWithBuffer(BufferCallback fn, {int? maxSize, int? initialSize}) {
final limit = maxSize ?? maxBufferSize;
final size = initialSize ?? initialBufferSize;
final scratch = _sharedScratch.tryAcquire();
if (scratch == null) {
return _callWithTransientBuffer(fn, limit: limit, initialSize: size);
}
try {
return scratch.call(fn, limit: limit, initialSize: size);
} finally {
scratch.release();
}
}