zeta2: Max retrieved definitions option (#40515)

Release Notes:

- N/A
This commit is contained in:
Agus Zubiaga 2025-10-20 12:26:41 -03:00 committed by GitHub
parent 8bef4800f0
commit eda7a49f01
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
4 changed files with 26 additions and 9 deletions

View file

@ -27,9 +27,9 @@ pub use predict_edits_v3::Line;
#[derive(Clone, Debug, PartialEq)]
pub struct EditPredictionContextOptions {
pub use_imports: bool,
pub use_references: bool,
pub excerpt: EditPredictionExcerptOptions,
pub score: EditPredictionScoreOptions,
pub max_retrieved_declarations: u8,
}
#[derive(Clone, Debug)]
@ -118,7 +118,7 @@ impl EditPredictionContext {
)?;
let excerpt_text = excerpt.text(buffer);
let declarations = if options.use_references
let declarations = if options.max_retrieved_declarations > 0
&& let Some(index_state) = index_state
{
let excerpt_occurrences =
@ -136,7 +136,7 @@ impl EditPredictionContext {
let references = get_references(&excerpt, &excerpt_text, buffer);
scored_declarations(
let mut declarations = scored_declarations(
&options.score,
&index_state,
&excerpt,
@ -146,7 +146,10 @@ impl EditPredictionContext {
references,
cursor_offset_in_file,
buffer,
)
);
// TODO [zeta2] if we need this when we ship, we should probably do it in a smarter way
declarations.truncate(options.max_retrieved_declarations as usize);
declarations
} else {
vec![]
};
@ -200,7 +203,6 @@ mod tests {
buffer_snapshot,
EditPredictionContextOptions {
use_imports: true,
use_references: true,
excerpt: EditPredictionExcerptOptions {
max_bytes: 60,
min_bytes: 10,
@ -209,6 +211,7 @@ mod tests {
score: EditPredictionScoreOptions {
omit_excerpt_overlaps: true,
},
max_retrieved_declarations: u8::MAX,
},
Some(index.clone()),
cx,

View file

@ -48,7 +48,7 @@ const MAX_EVENT_COUNT: usize = 16;
pub const DEFAULT_CONTEXT_OPTIONS: EditPredictionContextOptions = EditPredictionContextOptions {
use_imports: true,
use_references: false,
max_retrieved_declarations: 0,
excerpt: EditPredictionExcerptOptions {
max_bytes: 512,
min_bytes: 128,

View file

@ -68,6 +68,7 @@ pub struct Zeta2Inspector {
min_excerpt_bytes_input: Entity<SingleLineInput>,
cursor_context_ratio_input: Entity<SingleLineInput>,
max_prompt_bytes_input: Entity<SingleLineInput>,
max_retrieved_declarations: Entity<SingleLineInput>,
active_view: ActiveView,
zeta: Entity<Zeta>,
_active_editor_subscription: Option<Subscription>,
@ -133,6 +134,7 @@ impl Zeta2Inspector {
min_excerpt_bytes_input: Self::number_input("Min Excerpt Bytes", window, cx),
cursor_context_ratio_input: Self::number_input("Cursor Context Ratio", window, cx),
max_prompt_bytes_input: Self::number_input("Max Prompt Bytes", window, cx),
max_retrieved_declarations: Self::number_input("Max Retrieved Definitions", window, cx),
zeta: zeta.clone(),
_active_editor_subscription: None,
_update_state_task: Task::ready(()),
@ -170,6 +172,13 @@ impl Zeta2Inspector {
self.max_prompt_bytes_input.update(cx, |input, cx| {
input.set_text(options.max_prompt_bytes.to_string(), window, cx);
});
self.max_retrieved_declarations.update(cx, |input, cx| {
input.set_text(
options.context.max_retrieved_declarations.to_string(),
window,
cx,
);
});
cx.notify();
}
@ -246,6 +255,10 @@ impl Zeta2Inspector {
cx,
),
},
max_retrieved_declarations: number_input_value(
&this.max_retrieved_declarations,
cx,
),
..zeta_options.context
};
@ -536,6 +549,7 @@ impl Zeta2Inspector {
h_flex()
.gap_2()
.items_end()
.child(self.max_retrieved_declarations.clone())
.child(self.max_prompt_bytes_input.clone())
.child(self.render_prompt_format_dropdown(window, cx)),
),

View file

@ -94,8 +94,8 @@ struct Zeta2Args {
file_indexing_parallelism: usize,
#[arg(long, default_value_t = false)]
disable_imports_gathering: bool,
#[arg(long, default_value_t = false)]
disable_reference_retrieval: bool,
#[arg(long, default_value_t = u8::MAX)]
max_retrieved_definitions: u8,
}
#[derive(clap::ValueEnum, Default, Debug, Clone)]
@ -302,7 +302,7 @@ impl Zeta2Args {
fn to_options(&self, omit_excerpt_overlaps: bool) -> zeta2::ZetaOptions {
zeta2::ZetaOptions {
context: EditPredictionContextOptions {
use_references: !self.disable_reference_retrieval,
max_retrieved_declarations: self.max_retrieved_definitions,
use_imports: !self.disable_imports_gathering,
excerpt: EditPredictionExcerptOptions {
max_bytes: self.max_excerpt_bytes,