A redesign of the Quick and Dirty Allocation Profiling Tool.
Although #[no_std]
is intended, it isn't currently supported due to the lack of portable
thread_local
implementation. This may be "fixed" with a feature flag to use a global atomic
under the contract that the program is single threaded.
Count allocations, reallocations and deallocations individually with count_alloc
.
Allow, deny, and forbid use of the global allocator with allow_alloc
, deny_alloc
and
forbid_alloc
.
#[no_alloc]
function attribute to deny and #[no_alloc(forbid)]
to forbid use of the
global allocator.
#[count_alloc]
function attribute to print the counts to stderr. Alternatively use
#[count_alloc(func = "my_function")]
where my_function
accepts a triple of usize
s
and returns ()
to redirect the output.
Methods must either take a reference to self
or Self
must be a Copy
type.
Ordinary and async functions must be treated differently. Use count_alloc
for functions
and count_alloc_future
for futures.
An AllocCounter<A>
wraps an allocator A
to individually count the number of calls to
alloc
, realloc
, and dealloc
.
```rust use alloc_counter::AllocCounter;
type MyAllocator = std::alloc::System; const MyAllocator: MyAllocator = std::alloc::System;
static A: AllocCounter
Std-users may prefer to inherit their system's allocator.
```rust use alloc_counter::AllocCounterSystem;
static A: AllocCounterSystem = AllocCounterSystem; ```
To count the allocations of an expression, use count_alloc
.
```rust
let (counts, v) = countalloc(|| { // no alloc let mut v = Vec::new(); // alloc v.push(0); // realloc v.push(1); // return the vector without deallocating v }); asserteq!(counts, (1, 1, 0)); ```
To deny allocations for an expression use deny_alloc
.
```rust,should_panic
fn foo(b: Box
Similar to Rust's lints, you can still allow allocation inside a deny block.
```rust
fn foo(b: Box
Forbidding allocations forces a panic even when allow_alloc
is used.
```rust,should_panic
fn foo(b: Boxforbid
, even though drop happens in an allow block
forbidalloc(|| allowalloc(|| drop(b)))
}
foo(Box::new(0));
```
For added sugar you may use the #[no_alloc]
attribute on functions, including methods with
self-binds. #[no_alloc]
expands to calling deny_alloc
and forcefully moves the parameters
into the checked block. #[no_alloc(forbid)]
calls forbid_alloc
.
```rust,should_panic
fn foo(b: Box
```
License: MIT OR Apache-2.0