use crate::ffi;
use core::ptr::NonNull;
pub struct PyObjectFreeList {
entries: Box<[Option<NonNull<ffi::PyObject>>]>,
split: usize,
capacity: usize,
}
unsafe impl Send for PyObjectFreeList {}
impl PyObjectFreeList {
pub fn with_capacity(capacity: usize) -> PyObjectFreeList {
let entries = vec![None; capacity].into_boxed_slice();
PyObjectFreeList {
entries,
split: 0,
capacity,
}
}
pub fn pop(&mut self) -> Option<NonNull<ffi::PyObject>> {
let idx = self.split;
if idx == 0 {
None
} else {
let val = self.entries[idx - 1]
.take()
.expect("PyObjectFreeList is corrupt");
self.split = idx - 1;
Some(val)
}
}
pub fn insert(&mut self, val: NonNull<ffi::PyObject>) -> Option<NonNull<ffi::PyObject>> {
let next = self.split + 1;
if next < self.capacity {
self.entries[self.split] = Some(val);
self.split = next;
None
} else {
Some(val)
}
}
}