assistant.rs

  1mod active_thread;
  2mod agent_diff;
  3mod assistant_configuration;
  4mod assistant_model_selector;
  5mod assistant_panel;
  6mod buffer_codegen;
  7mod context;
  8mod context_picker;
  9mod context_server_configuration;
 10mod context_store;
 11mod context_strip;
 12mod history_store;
 13mod inline_assistant;
 14mod inline_prompt_editor;
 15mod message_editor;
 16mod profile_selector;
 17mod terminal_codegen;
 18mod terminal_inline_assistant;
 19mod thread;
 20mod thread_history;
 21mod thread_store;
 22mod tool_compatibility;
 23mod tool_use;
 24mod ui;
 25
 26use std::sync::Arc;
 27
 28use assistant_settings::{AgentProfileId, AssistantSettings};
 29use client::Client;
 30use command_palette_hooks::CommandPaletteFilter;
 31use feature_flags::{Assistant2FeatureFlag, FeatureFlagAppExt};
 32use fs::Fs;
 33use gpui::{App, actions, impl_actions};
 34use language::LanguageRegistry;
 35use prompt_store::PromptBuilder;
 36use schemars::JsonSchema;
 37use serde::Deserialize;
 38use settings::Settings as _;
 39use thread::ThreadId;
 40
 41pub use crate::active_thread::ActiveThread;
 42use crate::assistant_configuration::{AddContextServerModal, ManageProfilesModal};
 43pub use crate::assistant_panel::{AssistantPanel, ConcreteAssistantPanelDelegate};
 44pub use crate::context::{ContextLoadResult, LoadedContext};
 45pub use crate::inline_assistant::InlineAssistant;
 46pub use crate::thread::{Message, MessageSegment, Thread, ThreadEvent};
 47pub use crate::thread_store::ThreadStore;
 48pub use agent_diff::{AgentDiffPane, AgentDiffToolbar};
 49pub use context_store::ContextStore;
 50pub use ui::{all_agent_previews, get_agent_preview};
 51
 52actions!(
 53    agent,
 54    [
 55        NewTextThread,
 56        ToggleContextPicker,
 57        ToggleNavigationMenu,
 58        ToggleOptionsMenu,
 59        DeleteRecentlyOpenThread,
 60        ToggleProfileSelector,
 61        RemoveAllContext,
 62        ExpandMessageEditor,
 63        OpenHistory,
 64        AddContextServer,
 65        RemoveSelectedThread,
 66        Chat,
 67        CycleNextInlineAssist,
 68        CyclePreviousInlineAssist,
 69        FocusUp,
 70        FocusDown,
 71        FocusLeft,
 72        FocusRight,
 73        RemoveFocusedContext,
 74        AcceptSuggestedContext,
 75        OpenActiveThreadAsMarkdown,
 76        OpenAgentDiff,
 77        Keep,
 78        Reject,
 79        RejectAll,
 80        KeepAll
 81    ]
 82);
 83
 84#[derive(Default, Clone, PartialEq, Deserialize, JsonSchema)]
 85pub struct NewThread {
 86    #[serde(default)]
 87    from_thread_id: Option<ThreadId>,
 88}
 89
 90#[derive(PartialEq, Clone, Default, Debug, Deserialize, JsonSchema)]
 91pub struct ManageProfiles {
 92    #[serde(default)]
 93    pub customize_tools: Option<AgentProfileId>,
 94}
 95
 96impl ManageProfiles {
 97    pub fn customize_tools(profile_id: AgentProfileId) -> Self {
 98        Self {
 99            customize_tools: Some(profile_id),
100        }
101    }
102}
103
104impl_actions!(agent, [NewThread, ManageProfiles]);
105
106const NAMESPACE: &str = "agent";
107
108/// Initializes the `agent` crate.
109pub fn init(
110    fs: Arc<dyn Fs>,
111    client: Arc<Client>,
112    prompt_builder: Arc<PromptBuilder>,
113    language_registry: Arc<LanguageRegistry>,
114    cx: &mut App,
115) {
116    AssistantSettings::register(cx);
117    thread_store::init(cx);
118    assistant_panel::init(cx);
119    context_server_configuration::init(language_registry, cx);
120
121    inline_assistant::init(
122        fs.clone(),
123        prompt_builder.clone(),
124        client.telemetry().clone(),
125        cx,
126    );
127    terminal_inline_assistant::init(
128        fs.clone(),
129        prompt_builder.clone(),
130        client.telemetry().clone(),
131        cx,
132    );
133    cx.observe_new(AddContextServerModal::register).detach();
134    cx.observe_new(ManageProfilesModal::register).detach();
135
136    feature_gate_agent_actions(cx);
137}
138
139fn feature_gate_agent_actions(cx: &mut App) {
140    CommandPaletteFilter::update_global(cx, |filter, _cx| {
141        filter.hide_namespace(NAMESPACE);
142    });
143
144    cx.observe_flag::<Assistant2FeatureFlag, _>(move |is_enabled, cx| {
145        if is_enabled {
146            CommandPaletteFilter::update_global(cx, |filter, _cx| {
147                filter.show_namespace(NAMESPACE);
148            });
149        } else {
150            CommandPaletteFilter::update_global(cx, |filter, _cx| {
151                filter.hide_namespace(NAMESPACE);
152            });
153        }
154    })
155    .detach();
156}