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::{AgentDiff, AgentDiffToolbar};
49
50actions!(
51 agent,
52 [
53 NewTextThread,
54 ToggleContextPicker,
55 ToggleNavigationMenu,
56 ToggleOptionsMenu,
57 DeleteRecentlyOpenThread,
58 ToggleProfileSelector,
59 RemoveAllContext,
60 ExpandMessageEditor,
61 OpenHistory,
62 AddContextServer,
63 RemoveSelectedThread,
64 Chat,
65 CycleNextInlineAssist,
66 CyclePreviousInlineAssist,
67 FocusUp,
68 FocusDown,
69 FocusLeft,
70 FocusRight,
71 RemoveFocusedContext,
72 AcceptSuggestedContext,
73 OpenActiveThreadAsMarkdown,
74 OpenAgentDiff,
75 Keep,
76 Reject,
77 RejectAll,
78 KeepAll
79 ]
80);
81
82#[derive(Default, Clone, PartialEq, Deserialize, JsonSchema)]
83pub struct NewThread {
84 #[serde(default)]
85 from_thread_id: Option<ThreadId>,
86}
87
88#[derive(PartialEq, Clone, Default, Debug, Deserialize, JsonSchema)]
89pub struct ManageProfiles {
90 #[serde(default)]
91 pub customize_tools: Option<AgentProfileId>,
92}
93
94impl ManageProfiles {
95 pub fn customize_tools(profile_id: AgentProfileId) -> Self {
96 Self {
97 customize_tools: Some(profile_id),
98 }
99 }
100}
101
102impl_actions!(agent, [NewThread, ManageProfiles]);
103
104const NAMESPACE: &str = "agent";
105
106/// Initializes the `agent` crate.
107pub fn init(
108 fs: Arc<dyn Fs>,
109 client: Arc<Client>,
110 prompt_builder: Arc<PromptBuilder>,
111 language_registry: Arc<LanguageRegistry>,
112 cx: &mut App,
113) {
114 AssistantSettings::register(cx);
115 thread_store::init(cx);
116 assistant_panel::init(cx);
117 context_server_configuration::init(language_registry, cx);
118
119 inline_assistant::init(
120 fs.clone(),
121 prompt_builder.clone(),
122 client.telemetry().clone(),
123 cx,
124 );
125 terminal_inline_assistant::init(
126 fs.clone(),
127 prompt_builder.clone(),
128 client.telemetry().clone(),
129 cx,
130 );
131 cx.observe_new(AddContextServerModal::register).detach();
132 cx.observe_new(ManageProfilesModal::register).detach();
133
134 feature_gate_agent_actions(cx);
135}
136
137fn feature_gate_agent_actions(cx: &mut App) {
138 CommandPaletteFilter::update_global(cx, |filter, _cx| {
139 filter.hide_namespace(NAMESPACE);
140 });
141
142 cx.observe_flag::<Assistant2FeatureFlag, _>(move |is_enabled, cx| {
143 if is_enabled {
144 CommandPaletteFilter::update_global(cx, |filter, _cx| {
145 filter.show_namespace(NAMESPACE);
146 });
147 } else {
148 CommandPaletteFilter::update_global(cx, |filter, _cx| {
149 filter.hide_namespace(NAMESPACE);
150 });
151 }
152 })
153 .detach();
154}