assistant2: Don't block ThreadStore
initialization on reloading the threads (#23728)
This PR changes the `ThreadStore` constructor to not block on reloading the threads before we finish initializing it. This allows us to make the constructor synchronous instead of asynchronous. Release Notes: - N/A
This commit is contained in:
parent
9705764892
commit
f096a28a19
2 changed files with 33 additions and 41 deletions
|
@ -119,12 +119,10 @@ impl AssistantPanel {
|
|||
cx.spawn(|mut cx| async move {
|
||||
let tools = Arc::new(ToolWorkingSet::default());
|
||||
log::info!("[assistant2-debug] initializing ThreadStore");
|
||||
let thread_store = workspace
|
||||
.update(&mut cx, |workspace, cx| {
|
||||
let thread_store = workspace.update(&mut cx, |workspace, cx| {
|
||||
let project = workspace.project().clone();
|
||||
ThreadStore::new(project, tools.clone(), cx)
|
||||
})?
|
||||
.await?;
|
||||
})??;
|
||||
log::info!("[assistant2-debug] finished initializing ThreadStore");
|
||||
|
||||
let slash_commands = Arc::new(SlashCommandWorkingSet::default());
|
||||
|
|
|
@ -34,11 +34,9 @@ impl ThreadStore {
|
|||
project: Entity<Project>,
|
||||
tools: Arc<ToolWorkingSet>,
|
||||
cx: &mut App,
|
||||
) -> Task<Result<Entity<Self>>> {
|
||||
cx.spawn(|mut cx| async move {
|
||||
let this = cx.new(|cx: &mut Context<Self>| {
|
||||
let context_server_factory_registry =
|
||||
ContextServerFactoryRegistry::default_global(cx);
|
||||
) -> Result<Entity<Self>> {
|
||||
let this = cx.new(|cx| {
|
||||
let context_server_factory_registry = ContextServerFactoryRegistry::default_global(cx);
|
||||
let context_server_manager = cx.new(|cx| {
|
||||
ContextServerManager::new(context_server_factory_registry, project.clone(), cx)
|
||||
});
|
||||
|
@ -63,16 +61,12 @@ impl ThreadStore {
|
|||
database_future,
|
||||
};
|
||||
this.register_context_server_handlers(cx);
|
||||
this.reload(cx).detach_and_log_err(cx);
|
||||
|
||||
this
|
||||
})?;
|
||||
|
||||
log::info!("[assistant2-debug] reloading threads");
|
||||
this.update(&mut cx, |this, cx| this.reload(cx))?.await?;
|
||||
log::info!("[assistant2-debug] finished reloading threads");
|
||||
});
|
||||
|
||||
Ok(this)
|
||||
})
|
||||
}
|
||||
|
||||
/// Returns the number of threads.
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue