pub struct WriteBatch<'s> { /* private fields */ }Expand description
A set of object writes that become durable and visible together.
Created by ObjectStore::batch. See the module docs for the
durability contract.
Implementations§
Source§impl<'s> WriteBatch<'s>
impl<'s> WriteBatch<'s>
Sourcepub fn write(&self, bytes: &[u8]) -> StoreResult<Hash>
pub fn write(&self, bytes: &[u8]) -> StoreResult<Hash>
Hash bytes, dedup against staged and on-disk objects, and
stage (policy Batch/None) or durably write (policy
PerObject) the object. Returns the BLAKE3 hash either way.
Sourcepub fn write_parts(&self, parts: &[&[u8]]) -> StoreResult<Hash>
pub fn write_parts(&self, parts: &[&[u8]]) -> StoreResult<Hash>
Self::write for an object whose bytes are the concatenation
of parts, hashed and written streaming — no concatenated
buffer is materialised.
§Panics
Panics only if the internal hash-to-path mapping produces a path without a parent directory (impossible by construction) or if a previous write panicked while holding the batch mutex.
Sourcepub fn contains(&self, h: &Hash) -> bool
pub fn contains(&self, h: &Hash) -> bool
True when h is staged in this batch or already in the store.
§Panics
Panics only if a previous write panicked while holding the batch mutex.
Sourcepub fn commit(self) -> StoreResult<()>
pub fn commit(self) -> StoreResult<()>
Make every staged object durable and visible: one full flush, then all renames, then deduplicated shard-directory flushes.
After commit() returns Ok, every hash returned by
Self::write/Self::write_parts is durable AND visible.
Callers MUST call this before reading any object written by this
batch and before writing any ref/index that references one.
If commit() fails partway, already-renamed objects remain
visible (content-addressing makes re-running the command
idempotent) and not-yet-renamed temp files are unlinked on drop.
§Panics
Panics only if a previous write panicked while holding the batch mutex.
Trait Implementations§
Source§impl<'s> Debug for WriteBatch<'s>
impl<'s> Debug for WriteBatch<'s>
Source§impl ObjectSink for WriteBatch<'_>
impl ObjectSink for WriteBatch<'_>
Auto Trait Implementations§
impl<'s> !Freeze for WriteBatch<'s>
impl<'s> !RefUnwindSafe for WriteBatch<'s>
impl<'s> !UnwindSafe for WriteBatch<'s>
impl<'s> Send for WriteBatch<'s>
impl<'s> Sync for WriteBatch<'s>
impl<'s> Unpin for WriteBatch<'s>
impl<'s> UnsafeUnpin for WriteBatch<'s>
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> FutureExt for T
impl<T> FutureExt for T
Source§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
Source§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
impl<A, B, T> HttpServerConnExec<A, B> for Twhere
B: Body,
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more