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 Follow
82 ]
83);
84
85#[derive(Default, Clone, PartialEq, Deserialize, JsonSchema)]
86pub struct NewThread {
87 #[serde(default)]
88 from_thread_id: Option<ThreadId>,
89}
90
91#[derive(PartialEq, Clone, Default, Debug, Deserialize, JsonSchema)]
92pub struct ManageProfiles {
93 #[serde(default)]
94 pub customize_tools: Option<AgentProfileId>,
95}
96
97impl ManageProfiles {
98 pub fn customize_tools(profile_id: AgentProfileId) -> Self {
99 Self {
100 customize_tools: Some(profile_id),
101 }
102 }
103}
104
105impl_actions!(agent, [NewThread, ManageProfiles]);
106
107const NAMESPACE: &str = "agent";
108
109/// Initializes the `agent` crate.
110pub fn init(
111 fs: Arc<dyn Fs>,
112 client: Arc<Client>,
113 prompt_builder: Arc<PromptBuilder>,
114 language_registry: Arc<LanguageRegistry>,
115 cx: &mut App,
116) {
117 AssistantSettings::register(cx);
118 thread_store::init(cx);
119 assistant_panel::init(cx);
120 context_server_configuration::init(language_registry, cx);
121
122 inline_assistant::init(
123 fs.clone(),
124 prompt_builder.clone(),
125 client.telemetry().clone(),
126 cx,
127 );
128 terminal_inline_assistant::init(
129 fs.clone(),
130 prompt_builder.clone(),
131 client.telemetry().clone(),
132 cx,
133 );
134 cx.observe_new(AddContextServerModal::register).detach();
135 cx.observe_new(ManageProfilesModal::register).detach();
136
137 feature_gate_agent_actions(cx);
138}
139
140fn feature_gate_agent_actions(cx: &mut App) {
141 CommandPaletteFilter::update_global(cx, |filter, _cx| {
142 filter.hide_namespace(NAMESPACE);
143 });
144
145 cx.observe_flag::<Assistant2FeatureFlag, _>(move |is_enabled, cx| {
146 if is_enabled {
147 CommandPaletteFilter::update_global(cx, |filter, _cx| {
148 filter.show_namespace(NAMESPACE);
149 });
150 } else {
151 CommandPaletteFilter::update_global(cx, |filter, _cx| {
152 filter.hide_namespace(NAMESPACE);
153 });
154 }
155 })
156 .detach();
157}