pub struct SpatialScatterGather {
pub source_node: u64,
pub shard_ids: Vec<u16>,
/* private fields */
}Expand description
Scatter-gather coordinator for distributed spatial queries.
Fields§
§source_node: u64§shard_ids: Vec<u16>Implementations§
Source§impl SpatialScatterGather
impl SpatialScatterGather
pub fn new(source_node: u64, shard_ids: Vec<u16>) -> Self
Sourcepub fn build_scatter_envelopes(
&self,
collection: &str,
field: &str,
predicate: &str,
query_geometry_json: &[u8],
distance_meters: f64,
limit: usize,
) -> Vec<(u16, VShardEnvelope)>
pub fn build_scatter_envelopes( &self, collection: &str, field: &str, predicate: &str, query_geometry_json: &[u8], distance_meters: f64, limit: usize, ) -> Vec<(u16, VShardEnvelope)>
Build scatter envelopes for a spatial query.
Each envelope contains the query geometry + predicate type + distance as JSON payload.
Sourcepub fn record_response(&mut self, result: &ShardSpatialResult)
pub fn record_response(&mut self, result: &ShardSpatialResult)
Record a shard’s response.
Sourcepub fn all_responded(&self) -> bool
pub fn all_responded(&self) -> bool
Whether all shards have responded.
Sourcepub fn merge_results(
&mut self,
limit: usize,
sort_by_distance: bool,
) -> Vec<SpatialHit>
pub fn merge_results( &mut self, limit: usize, sort_by_distance: bool, ) -> Vec<SpatialHit>
Merge results from all shards.
pub fn response_count(&self) -> usize
Auto Trait Implementations§
impl Freeze for SpatialScatterGather
impl RefUnwindSafe for SpatialScatterGather
impl Send for SpatialScatterGather
impl Sync for SpatialScatterGather
impl Unpin for SpatialScatterGather
impl UnsafeUnpin for SpatialScatterGather
impl UnwindSafe for SpatialScatterGather
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
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
Mutably borrows from an owned value. Read more
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> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Returns the layout of the type.
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Returns whether the given value has been niched. Read more
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
Writes data to
out indicating that a T is niched.