grob

Crates.iogrob
lib.rsgrob
version0.1.3
sourcesrc
created_at2023-05-26 15:32:06.521238
updated_at2024-03-07 17:41:08.489834
descriptionGrowable buffer especially useful for Windows API calls.
homepage
repositoryhttps://github.com/Coding-Badly/grob
max_upload_size
id875120
size161,216
Brian Cook (Coding-Badly)

documentation

https://docs.rs/grob

README

Introduction

Welcome to the grob crate!

grob is short for growable buffer.

Many Windows API functions require the caller to provide a buffer. The pattern goes something like this...

  • Call the function with an initial buffer and size
  • If that works then process the returned data
  • If that does not work because the buffer is too small then create a larger buffer and try again
  • If that does not work for any other reason then deal with the error

There are copious examples of a growable buffer including a version in the Rust Standard Library. There is a lack of consistency amoungst all the examples. Some versions continue trying indefinately. Some versions make an arbitrary number of attempts like three then give up. Some versions double the size of the new buffer. Some versions increase the size by a fixed amount like 128 bytes. Even Microsoft's API examples are inconsistent.

The goal with this crate is to provide a single high quality growable buffer that any Rust developer can easily use.

License

grob is distributed under the terms of both the MIT license and the Apache License (Version 2.0).

See LICENSE-APACHE and LICENSE-MIT for details.

Build Status

Clippy Examples Miri Test

Commit count: 6

cargo fmt