#api-calls #winapi #buffer #api #growable #string

grob

Growable buffer especially useful for Windows API calls

4 releases

0.1.3 Mar 7, 2024
0.1.2 Feb 13, 2024
0.1.1 May 27, 2023
0.1.0 May 26, 2023

#65 in Windows APIs

Apache-2.0 OR MIT

100KB
906 lines

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

Dependencies

~0–38MB
~521K SLoC