bufkit 0.4.1

Memory-backed buffer toolkit with Chunk/ChunkMut traits for predictable, explicit, and retry-friendly access; ideal for Sans-I/O style protocol parsers, database engines, and embedded systems.
Documentation
<div align="center">
<h1>bufkit</h1>
</div>
<div align="center">

`no_std`-friendly, memory-backed buffer toolkit designed for **Sans-I/O style** encoding and decoding.
Provides `Chunk` (read-only view), `ChunkMut` (mutable view), and helpers for explicit, convenient bounds-checked access.

[<img alt="github" src="https://img.shields.io/badge/github-al8n/bufkit-8da0cb?style=for-the-badge&logo=Github" height="22">][Github-url]
<img alt="LoC" src="https://img.shields.io/endpoint?url=https%3A%2F%2Fgist.githubusercontent.com%2Fal8n%2F327b2a8aef9003246e45c6e47fe63937%2Fraw%2Fbufkit" height="22">
[<img alt="Build" src="https://img.shields.io/github/actions/workflow/status/al8n/bufkit/ci.yml?logo=Github-Actions&style=for-the-badge" height="22">][CI-url]
[<img alt="codecov" src="https://img.shields.io/codecov/c/gh/al8n/bufkit?style=for-the-badge&token=6R3QFWRWHL&logo=codecov" height="22">][codecov-url]

[<img alt="docs.rs" src="https://img.shields.io/badge/docs.rs-bufkit-66c2a5?style=for-the-badge&labelColor=555555&logo=" height="20">][doc-url]
[<img alt="crates.io" src="https://img.shields.io/crates/v/bufkit?style=for-the-badge&logo=" height="22">][crates-url]
[<img alt="crates.io" src="https://img.shields.io/crates/d/bufkit?color=critical&logo=&style=for-the-badge" height="22">][crates-url]
<img alt="license" src="https://img.shields.io/badge/License-Apache%202.0/MIT-blue.svg?style=for-the-badge&fontColor=white&logoColor=f5c076&logo=" height="22">

</div>

## Overview

**bufkit** is a small, focused toolkit for working with in-memory buffers in a predictable, controlled way.  
It’s Sans-I/O friendly — meaning it’s easy to integrate into network protocol parsers, database engines, binary file format decoders/encoders, and embedded systems that follow the Sans-I/O design pattern — but it doesn’t implement any I/O itself.

## Features

- **Predictable memory usage** – operates directly on memory you provide, no hidden allocations.
- **Explicit error handling** – choose panicking, `Option`, or detailed `Result` with requested vs. available byte counts.
- **Segmented views** – create independent `Chunk`/`ChunkMut` views into the same buffer.
- **Offset reads/writes** – operate at arbitrary positions without unsafe pointer math.
- **Embedded friendly** - **`no_std` & `no_alloc` ready** – works in embedded and constrained environments.
- **Retry-friendly** – `try_*` methods enable robust partial read/write handling.

## Installation

```toml
[dependencies]
bufkit = "0.4"
```

### Feature Flags

| Feature   | Default? | Description                                 |
| --------- | -------- | ------------------------------------------- |
| `std`     | Yes      | Enables `std` integration                   |
| `alloc`   | No       | Enables heap-allocated buffer support       |
| `varing`  | No       | LEB128 encoding & decoding                  |
| `bytes_1` | No       | Enable integration with `bytes` 1.x         |

## Alternatives

- [`bytes::{Buf, BufMut}`]: Chunkfer traits for the bytes may or may not be stored in contiguous memory.
- [`buffer-trait`](https://crates.io/crates/buffer-trait): A `Buffer` trait for reading into uninitialized buffers.

#### License

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

See [LICENSE-APACHE](LICENSE-APACHE), [LICENSE-MIT](LICENSE-MIT) for details.

Copyright (c) 2025 Al Liu.

[Github-url]: https://github.com/al8n/bufkit/
[CI-url]: https://github.com/al8n/bufkit/actions/workflows/ci.yml
[doc-url]: https://docs.rs/bufkit
[crates-url]: https://crates.io/crates/bufkit
[codecov-url]: https://app.codecov.io/gh/al8n/bufkit/
[`bytes::{Buf, BufMut}`]: https://docs.rs/bytes/latest/bytes/buf/#traits