Skip to main content

TextSearchBuilder

Struct TextSearchBuilder 

Source
pub struct TextSearchBuilder<'e> { /* private fields */ }
Expand description

Tethered text-search builder returned from NodeQueryBuilder::text_search.

Accumulates filter predicates alongside the text-search step and dispatches .execute() through fathomdb_engine::ExecutionCoordinator::execute_compiled_search, returning SearchRows populated with score, source, snippet, and active-version written_at values.

Implementations§

Source§

impl TextSearchBuilder<'_>

Source

pub fn with_match_attribution(self) -> Self

Request per-hit match attribution.

When set, the coordinator populates SearchHit::attribution on every hit with the set of property paths (or "text_content" for chunk hits) that contributed to the match. Without this flag (the default), attribution stays None and the Phase 4 position map is not read at all — it is a pay-as-you-go feature.

Source

pub fn filter_logical_id_eq(self, logical_id: impl Into<String>) -> Self

Filter results to a single logical ID.

Source

pub fn filter_kind_eq(self, kind: impl Into<String>) -> Self

Filter results to nodes matching the given kind.

Source

pub fn filter_source_ref_eq(self, source_ref: impl Into<String>) -> Self

Filter results to nodes matching the given source_ref.

Source

pub fn filter_content_ref_not_null(self) -> Self

Filter results to nodes where content_ref is not NULL.

Source

pub fn filter_content_ref_eq(self, content_ref: impl Into<String>) -> Self

Filter results to nodes matching the given content_ref URI.

Source

pub fn filter_json_text_eq( self, path: impl Into<String>, value: impl Into<String>, ) -> Self

Filter results where a JSON property at path equals the given text value.

Source

pub fn filter_json_bool_eq(self, path: impl Into<String>, value: bool) -> Self

Filter results where a JSON property at path equals the given boolean value.

Source

pub fn filter_json_integer_gt(self, path: impl Into<String>, value: i64) -> Self

Filter results where a JSON integer at path is greater than value.

Source

pub fn filter_json_integer_gte( self, path: impl Into<String>, value: i64, ) -> Self

Filter results where a JSON integer at path is greater than or equal to value.

Source

pub fn filter_json_integer_lt(self, path: impl Into<String>, value: i64) -> Self

Filter results where a JSON integer at path is less than value.

Source

pub fn filter_json_integer_lte( self, path: impl Into<String>, value: i64, ) -> Self

Filter results where a JSON integer at path is less than or equal to value.

Source

pub fn filter_json_timestamp_gt( self, path: impl Into<String>, value: i64, ) -> Self

Filter results where a JSON timestamp at path is after value.

Source

pub fn filter_json_timestamp_gte( self, path: impl Into<String>, value: i64, ) -> Self

Filter results where a JSON timestamp at path is at or after value.

Source

pub fn filter_json_timestamp_lt( self, path: impl Into<String>, value: i64, ) -> Self

Filter results where a JSON timestamp at path is before value.

Source

pub fn filter_json_timestamp_lte( self, path: impl Into<String>, value: i64, ) -> Self

Filter results where a JSON timestamp at path is at or before value.

Source

pub fn filter_json_fused_text_eq( self, path: impl Into<String>, value: impl Into<String>, ) -> Result<Self, BuilderValidationError>

Filter results where a JSON text property at path equals value, with fusion semantics. See NodeQueryBuilder::filter_json_fused_text_eq for the contract.

§Errors

Returns BuilderValidationError if the root kind has no registered property-FTS schema or the schema does not cover path.

Source

pub fn filter_json_fused_text_in( self, path: impl Into<String>, values: Vec<String>, ) -> Result<Self, BuilderValidationError>

Filter results where a JSON text property at path is one of values, with fusion semantics.

§Errors

See Self::filter_json_fused_text_eq.

Source

pub fn filter_json_text_in( self, path: impl Into<String>, values: Vec<String>, ) -> Self

Filter results where a JSON text property at path is one of values. Non-fused; no FTS schema required.

Source

pub fn filter_json_fused_timestamp_gt( self, path: impl Into<String>, value: i64, ) -> Result<Self, BuilderValidationError>

Filter results where a JSON timestamp at path is strictly greater than value, with fusion semantics.

§Errors

See Self::filter_json_fused_text_eq.

Source

pub fn filter_json_fused_timestamp_gte( self, path: impl Into<String>, value: i64, ) -> Result<Self, BuilderValidationError>

Filter results where a JSON timestamp at path is at or after value, with fusion semantics.

§Errors

See Self::filter_json_fused_text_eq.

Source

pub fn filter_json_fused_timestamp_lt( self, path: impl Into<String>, value: i64, ) -> Result<Self, BuilderValidationError>

Filter results where a JSON timestamp at path is strictly before value, with fusion semantics.

§Errors

See Self::filter_json_fused_text_eq.

Source

pub fn filter_json_fused_timestamp_lte( self, path: impl Into<String>, value: i64, ) -> Result<Self, BuilderValidationError>

Filter results where a JSON timestamp at path is at or before value, with fusion semantics.

§Errors

See Self::filter_json_fused_text_eq.

Source

pub fn filter_json_fused_bool_eq( self, path: impl Into<String>, value: bool, ) -> Result<Self, BuilderValidationError>

Filter results where a JSON boolean property at path equals value, with fusion semantics. See Self::filter_json_fused_text_eq for the contract.

§Errors

See Self::filter_json_fused_text_eq.

Source

pub fn limit(self, limit: usize) -> Self

Set the final row limit on the underlying AST.

Phase 1 note: CompiledSearch derives its effective limit from the text_search step, not from this field. limit is still delegated to the inner builder so callers that later fall back to [TextSearchBuilder::compile_query] keep the same shape.

Source

pub fn traverse( self, direction: TraverseDirection, label: impl Into<String>, max_depth: usize, ) -> Self

Add a graph traversal step. Applied after the text-search step when the inner AST is compiled via [TextSearchBuilder::compile_query]. The Phase 1 TextSearchBuilder::execute path ignores traversals.

Source

pub fn expand( self, slot: impl Into<String>, direction: TraverseDirection, label: impl Into<String>, max_depth: usize, filter: Option<Predicate>, edge_filter: Option<Predicate>, ) -> Self

Add an expansion slot. Applied when compiling via [TextSearchBuilder::compile_grouped_query]; ignored by TextSearchBuilder::execute in Phase 1.

Pass filter: None to preserve the existing behavior. filter: Some(_) is accepted by the AST but the compilation is not yet implemented (Pack 3). Pass edge_filter: None to preserve pre-Pack-D behavior.

Source

pub fn as_builder(&self) -> &QueryBuilder

Borrow the underlying QueryBuilder.

Source

pub fn compile(&self) -> Result<CompiledQuery, CompileError>

Compile the underlying AST as a flat CompiledQuery. Provided for call sites that mix search with traversal steps and still need to run the flat node-row pipeline.

§Errors

Returns CompileError if compilation fails.

Source

pub fn compile_grouped(&self) -> Result<CompiledGroupedQuery, CompileError>

Compile the underlying AST as a CompiledGroupedQuery.

§Errors

Returns CompileError if compilation fails.

Source

pub fn into_ast(self) -> QueryAst

Consume the tether and return the underlying QueryAst.

Source

pub fn execute(&self) -> Result<SearchRows, EngineError>

Execute the text search and return matching hits.

§Errors

Returns EngineError if compilation or execution fails.

Auto Trait Implementations§

§

impl<'e> Freeze for TextSearchBuilder<'e>

§

impl<'e> !RefUnwindSafe for TextSearchBuilder<'e>

§

impl<'e> Send for TextSearchBuilder<'e>

§

impl<'e> Sync for TextSearchBuilder<'e>

§

impl<'e> Unpin for TextSearchBuilder<'e>

§

impl<'e> UnsafeUnpin for TextSearchBuilder<'e>

§

impl<'e> !UnwindSafe for TextSearchBuilder<'e>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V