78 releases (46 breaking)

new 0.46.0 Jan 14, 2025
0.44.0 Dec 25, 2024
0.38.0 Nov 26, 2024
0.22.1 Jul 28, 2024
0.0.1 Mar 30, 2023

#763 in Programming languages

Download history 54025/week @ 2024-09-25 56486/week @ 2024-10-02 42872/week @ 2024-10-09 29115/week @ 2024-10-16 16969/week @ 2024-10-23 14584/week @ 2024-10-30 15662/week @ 2024-11-06 16719/week @ 2024-11-13 16798/week @ 2024-11-20 10682/week @ 2024-11-27 17084/week @ 2024-12-04 14555/week @ 2024-12-11 12126/week @ 2024-12-18 7768/week @ 2024-12-25 12250/week @ 2025-01-01 13966/week @ 2025-01-08

48,422 downloads per month
Used in 32 crates (21 directly)

MIT license

34KB
574 lines

⚓ Oxc Memory Allocator

Oxc uses a bump-based memory arena for faster AST allocations. This crate contains an Allocator for creating such arenas, as well as ports of memory management data types from std adapted to use this arena.

No Drops

Objects allocated into oxc memory arenas are never Dropped, making it relatively easy to leak memory if you're not careful. Memory is released in bulk when the allocator is dropped.

Examples

use oxc_allocator::{Allocator, Box};

struct Foo {
    pub a: i32
}
impl std::ops::Drop for Foo {
    fn drop(&mut self) {
        // Arena boxes are never dropped.
        unreachable!();
    }
}

let allocator = Allocator::default();
let foo = Box::new_in(Foo { a: 0 }, &allocator);
drop(foo);

Consumers of the oxc umbrella crate pass Allocator references to other tools.

use oxc::{allocator::Allocator, parser::Parser, span::SourceType};

let allocator = Allocator::default()
let parsed = Parser::new(&allocator, "let x = 1;", SourceType::default());
assert!(parsed.errors.is_empty());

Dependencies

~510–750KB
~11K SLoC