Skip to main content

IndexConfig

Struct IndexConfig 

Source
pub struct IndexConfig {
Show 16 fields pub enabled: bool, pub search_enabled: bool, pub watch: bool, pub max_chunks: usize, pub score_threshold: f32, pub budget_ratio: f32, pub repo_map_tokens: usize, pub repo_map_ttl_secs: u64, pub mcp_enabled: bool, pub workspace_root: Option<PathBuf>, pub concurrency: usize, pub batch_size: usize, pub memory_batch_size: usize, pub max_file_bytes: usize, pub embed_provider: Option<String>, pub embed_concurrency: usize,
}
Expand description

Code indexing and repo-map configuration, nested under [index] in TOML.

When enabled = true, the agent indexes source files into Qdrant for semantic code search. The repo map is injected into the system prompt or served via IndexMcpServer tool calls when mcp_enabled = true.

§Example (TOML)

[index]
enabled = true
watch = false
max_chunks = 12
score_threshold = 0.25

Fields§

§enabled: bool

Enable code indexing. Default: false.

§search_enabled: bool

Enable semantic code search tool. Default: true (no-op when enabled = false).

§watch: bool§max_chunks: usize§score_threshold: f32§budget_ratio: f32§repo_map_tokens: usize§repo_map_ttl_secs: u64§mcp_enabled: bool

Enable IndexMcpServer tools (symbol_definition, find_text_references, call_graph, module_summary). When true, static repo-map injection is skipped and the LLM uses on-demand tool calls instead.

§workspace_root: Option<PathBuf>

Root directory to index. When None, falls back to the current working directory at startup. Relative paths are resolved relative to the process working directory.

§concurrency: usize

Number of files to process concurrently during initial indexing. Default: 4.

§batch_size: usize

Maximum number of new chunks to batch into a single Qdrant upsert per file. Default: 32.

§memory_batch_size: usize

Number of files to process per memory batch during initial indexing. After each batch the stream is dropped and the executor yields to allow the allocator to reclaim pages. Default: 32.

§max_file_bytes: usize

Maximum file size in bytes to index. Files larger than this are skipped. Protects against large generated files (e.g. lock files, minified JS). Default: 512 KiB.

§embed_provider: Option<String>

Name of a [[llm.providers]] entry to use exclusively for embedding calls during indexing. A dedicated provider prevents the indexer from contending with the guardrail at the API server level (rate limits, Ollama single-model lock). When unset or empty, falls back to the main agent provider.

§embed_concurrency: usize

Maximum parallel embed_batch calls during indexing (default: 2 to stay within provider TPM limits).

Trait Implementations§

Source§

impl Debug for IndexConfig

Source§

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

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

impl Default for IndexConfig

Source§

fn default() -> IndexConfig

Returns the “default value” for a type. Read more
Source§

impl<'de> Deserialize<'de> for IndexConfig

Source§

fn deserialize<__D>( __deserializer: __D, ) -> Result<IndexConfig, <__D as Deserializer<'de>>::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl Serialize for IndexConfig

Source§

fn serialize<__S>( &self, __serializer: __S, ) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more

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<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: 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: 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> 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

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

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,