Skip to main content

IndexError

Enum IndexError 

Source
#[non_exhaustive]
pub enum IndexError { Io(Error), Sqlite(SqlxError), VectorStore(VectorStoreError), Llm(LlmError), Json(Error), Parse(String), UnsupportedLanguage, Watcher(Error), IntConversion(TryFromIntError), EmbedTimeout(u64), Other(String), }
Expand description

Errors that can occur during code indexing operations.

§Examples

use zeph_index::error::{IndexError, Result};

fn must_succeed() -> Result<()> {
    Err(IndexError::UnsupportedLanguage)
}

assert!(matches!(must_succeed(), Err(IndexError::UnsupportedLanguage)));

Variants (Non-exhaustive)§

This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
§

Io(Error)

I/O error reading source files from disk.

Raised when tokio::fs::read_to_string or std::fs::read_to_string fail, for example because a file was deleted between discovery and indexing.

§

Sqlite(SqlxError)

SQLite database error from sqlx.

Raised by metadata reads/writes in crate::store::CodeStore.

§

VectorStore(VectorStoreError)

Qdrant vector store error.

Raised by upsert, search, or collection management operations in crate::store::CodeStore.

§

Llm(LlmError)

LLM provider error during embedding.

Raised when the configured embedding provider returns an error, for example due to a network timeout or an unsupported model name.

§

Json(Error)

JSON serialization or deserialization error.

Raised when Qdrant payload values cannot be serialized or when point payloads contain unexpected types.

§

Parse(String)

Tree-sitter parsing error.

Raised when a grammar is unavailable for a language, or when tree-sitter fails to produce a parse tree (rare — tree-sitter is error-tolerant).

The inner String contains a human-readable description of the failure.

§

UnsupportedLanguage

Unsupported or unrecognized language.

Raised by crate::indexer when a file has a recognized extension but no corresponding tree-sitter grammar is available for it.

§

Watcher(Error)

Filesystem watcher initialization error.

Raised by crate::watcher::IndexWatcher::start when the underlying notify watcher cannot be created or the root path cannot be watched.

§

IntConversion(TryFromIntError)

Integer conversion error when mapping usize values to i64 or u64.

Raised when line numbers or chunk counts overflow the target integer type, which in practice only occurs on pathological inputs.

§

EmbedTimeout(u64)

Embedding call timed out.

Raised by crate::retriever::CodeRetriever and crate::indexer::CodeIndexer when provider.embed() does not complete within the configured timeout.

§

Other(String)

Generic catch-all error for cases that do not fit the variants above.

Used internally for errors like a panicking background thread (e.g., the directory walk spawn_blocking task).

Trait Implementations§

Source§

impl Debug for IndexError

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Display for IndexError

Source§

fn fmt(&self, __formatter: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Error for IndexError

Source§

fn source(&self) -> Option<&(dyn Error + 'static)>

Returns the lower-level source of this error, if any. Read more
1.0.0 · Source§

fn description(&self) -> &str

👎Deprecated since 1.42.0:

use the Display impl or to_string()

1.0.0 · Source§

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0:

replaced by Error::source, which can support downcasting

Source§

fn provide<'a>(&'a self, request: &mut Request<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access)
Provides type-based access to context intended for error reports. Read more
Source§

impl From<Error> for IndexError

Source§

fn from(source: Error) -> Self

Converts to this type from the input type.
Source§

impl From<Error> for IndexError

Source§

fn from(source: Error) -> Self

Converts to this type from the input type.
Source§

impl From<Error> for IndexError

Source§

fn from(source: Error) -> Self

Converts to this type from the input type.
Source§

impl From<Error> for IndexError

Source§

fn from(source: SqlxError) -> Self

Converts to this type from the input type.
Source§

impl From<LlmError> for IndexError

Source§

fn from(source: LlmError) -> Self

Converts to this type from the input type.
Source§

impl From<TryFromIntError> for IndexError

Source§

fn from(source: TryFromIntError) -> Self

Converts to this type from the input type.
Source§

impl From<VectorStoreError> for IndexError

Source§

fn from(source: VectorStoreError) -> Self

Converts to this type from the input type.

Auto Trait Implementations§

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<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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
Source§

impl<T> IntoRequest<T> for T

Source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

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

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Sized + Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Sized + Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Read<Exclusive, BecauseExclusive> for T
where T: ?Sized,

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
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

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more