parent
1a3597d726
commit
c37d6d5fed
12 changed files with 11 additions and 93 deletions
1
Cargo.lock
generated
1
Cargo.lock
generated
|
@ -4458,7 +4458,6 @@ dependencies = [
|
||||||
"env_logger 0.11.6",
|
"env_logger 0.11.6",
|
||||||
"feature_flags",
|
"feature_flags",
|
||||||
"fs",
|
"fs",
|
||||||
"git",
|
|
||||||
"gpui",
|
"gpui",
|
||||||
"http_client",
|
"http_client",
|
||||||
"language",
|
"language",
|
||||||
|
|
|
@ -3,7 +3,6 @@ use crate::{
|
||||||
tests::{rust_lang, TestServer},
|
tests::{rust_lang, TestServer},
|
||||||
};
|
};
|
||||||
use call::ActiveCall;
|
use call::ActiveCall;
|
||||||
use collections::HashMap;
|
|
||||||
use editor::{
|
use editor::{
|
||||||
actions::{
|
actions::{
|
||||||
ConfirmCodeAction, ConfirmCompletion, ConfirmRename, ContextMenuFirst, Redo, Rename,
|
ConfirmCodeAction, ConfirmCompletion, ConfirmRename, ContextMenuFirst, Redo, Rename,
|
||||||
|
@ -1983,7 +1982,6 @@ async fn test_git_blame_is_forwarded(cx_a: &mut TestAppContext, cx_b: &mut TestA
|
||||||
blame_entry("3a3a3a", 2..3),
|
blame_entry("3a3a3a", 2..3),
|
||||||
blame_entry("4c4c4c", 3..4),
|
blame_entry("4c4c4c", 3..4),
|
||||||
],
|
],
|
||||||
permalinks: HashMap::default(), // This field is deprecrated
|
|
||||||
messages: [
|
messages: [
|
||||||
("1b1b1b", "message for idx-0"),
|
("1b1b1b", "message for idx-0"),
|
||||||
("0d0d0d", "message for idx-1"),
|
("0d0d0d", "message for idx-1"),
|
||||||
|
|
|
@ -370,7 +370,6 @@ impl GitBlame {
|
||||||
async move {
|
async move {
|
||||||
let Some(Blame {
|
let Some(Blame {
|
||||||
entries,
|
entries,
|
||||||
permalinks,
|
|
||||||
messages,
|
messages,
|
||||||
remote_url,
|
remote_url,
|
||||||
}) = blame.await?
|
}) = blame.await?
|
||||||
|
@ -379,13 +378,8 @@ impl GitBlame {
|
||||||
};
|
};
|
||||||
|
|
||||||
let entries = build_blame_entry_sum_tree(entries, snapshot.max_point().row);
|
let entries = build_blame_entry_sum_tree(entries, snapshot.max_point().row);
|
||||||
let commit_details = parse_commit_messages(
|
let commit_details =
|
||||||
messages,
|
parse_commit_messages(messages, remote_url, provider_registry).await;
|
||||||
remote_url,
|
|
||||||
&permalinks,
|
|
||||||
provider_registry,
|
|
||||||
)
|
|
||||||
.await;
|
|
||||||
|
|
||||||
anyhow::Ok(Some((entries, commit_details)))
|
anyhow::Ok(Some((entries, commit_details)))
|
||||||
}
|
}
|
||||||
|
@ -477,7 +471,6 @@ fn build_blame_entry_sum_tree(entries: Vec<BlameEntry>, max_row: u32) -> SumTree
|
||||||
async fn parse_commit_messages(
|
async fn parse_commit_messages(
|
||||||
messages: impl IntoIterator<Item = (Oid, String)>,
|
messages: impl IntoIterator<Item = (Oid, String)>,
|
||||||
remote_url: Option<String>,
|
remote_url: Option<String>,
|
||||||
deprecated_permalinks: &HashMap<Oid, Url>,
|
|
||||||
provider_registry: Arc<GitHostingProviderRegistry>,
|
provider_registry: Arc<GitHostingProviderRegistry>,
|
||||||
) -> HashMap<Oid, ParsedCommitMessage> {
|
) -> HashMap<Oid, ParsedCommitMessage> {
|
||||||
let mut commit_details = HashMap::default();
|
let mut commit_details = HashMap::default();
|
||||||
|
@ -495,11 +488,7 @@ async fn parse_commit_messages(
|
||||||
},
|
},
|
||||||
))
|
))
|
||||||
} else {
|
} else {
|
||||||
// DEPRECATED (18 Apr 24): Sending permalinks over the wire is deprecated. Clients
|
continue;
|
||||||
// now do the parsing. This is here for backwards compatibility, so that
|
|
||||||
// when an old peer sends a client no `parsed_remote_url` but `deprecated_permalinks`,
|
|
||||||
// we fall back to that.
|
|
||||||
deprecated_permalinks.get(&oid).cloned()
|
|
||||||
};
|
};
|
||||||
|
|
||||||
let remote = parsed_remote_url
|
let remote = parsed_remote_url
|
||||||
|
|
|
@ -22,7 +22,6 @@ collections.workspace = true
|
||||||
env_logger.workspace = true
|
env_logger.workspace = true
|
||||||
feature_flags.workspace = true
|
feature_flags.workspace = true
|
||||||
fs.workspace = true
|
fs.workspace = true
|
||||||
git.workspace = true
|
|
||||||
gpui.workspace = true
|
gpui.workspace = true
|
||||||
http_client.workspace = true
|
http_client.workspace = true
|
||||||
language.workspace = true
|
language.workspace = true
|
||||||
|
|
|
@ -5,7 +5,6 @@ use client::{Client, UserStore};
|
||||||
use clock::RealSystemClock;
|
use clock::RealSystemClock;
|
||||||
use collections::BTreeMap;
|
use collections::BTreeMap;
|
||||||
use feature_flags::FeatureFlagAppExt as _;
|
use feature_flags::FeatureFlagAppExt as _;
|
||||||
use git::GitHostingProviderRegistry;
|
|
||||||
use gpui::{AppContext as _, AsyncApp, BackgroundExecutor, Entity};
|
use gpui::{AppContext as _, AsyncApp, BackgroundExecutor, Entity};
|
||||||
use http_client::{HttpClient, Method};
|
use http_client::{HttpClient, Method};
|
||||||
use language::LanguageRegistry;
|
use language::LanguageRegistry;
|
||||||
|
@ -274,8 +273,7 @@ async fn run_evaluation(
|
||||||
let repos_dir = Path::new(EVAL_REPOS_DIR);
|
let repos_dir = Path::new(EVAL_REPOS_DIR);
|
||||||
let db_path = Path::new(EVAL_DB_PATH);
|
let db_path = Path::new(EVAL_DB_PATH);
|
||||||
let api_key = std::env::var("OPENAI_API_KEY").unwrap();
|
let api_key = std::env::var("OPENAI_API_KEY").unwrap();
|
||||||
let git_hosting_provider_registry = Arc::new(GitHostingProviderRegistry::new());
|
let fs = Arc::new(RealFs::new(None)) as Arc<dyn Fs>;
|
||||||
let fs = Arc::new(RealFs::new(git_hosting_provider_registry, None)) as Arc<dyn Fs>;
|
|
||||||
let clock = Arc::new(RealSystemClock);
|
let clock = Arc::new(RealSystemClock);
|
||||||
let client = cx
|
let client = cx
|
||||||
.update(|cx| {
|
.update(|cx| {
|
||||||
|
|
|
@ -11,7 +11,6 @@ use collections::HashMap;
|
||||||
use git::status::StatusCode;
|
use git::status::StatusCode;
|
||||||
#[cfg(any(test, feature = "test-support"))]
|
#[cfg(any(test, feature = "test-support"))]
|
||||||
use git::status::TrackedStatus;
|
use git::status::TrackedStatus;
|
||||||
use git::GitHostingProviderRegistry;
|
|
||||||
#[cfg(any(test, feature = "test-support"))]
|
#[cfg(any(test, feature = "test-support"))]
|
||||||
use git::{repository::RepoPath, status::FileStatus};
|
use git::{repository::RepoPath, status::FileStatus};
|
||||||
|
|
||||||
|
@ -247,7 +246,6 @@ impl From<MTime> for proto::Timestamp {
|
||||||
|
|
||||||
#[derive(Default)]
|
#[derive(Default)]
|
||||||
pub struct RealFs {
|
pub struct RealFs {
|
||||||
git_hosting_provider_registry: Arc<GitHostingProviderRegistry>,
|
|
||||||
git_binary_path: Option<PathBuf>,
|
git_binary_path: Option<PathBuf>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -300,14 +298,8 @@ impl FileHandle for std::fs::File {
|
||||||
pub struct RealWatcher {}
|
pub struct RealWatcher {}
|
||||||
|
|
||||||
impl RealFs {
|
impl RealFs {
|
||||||
pub fn new(
|
pub fn new(git_binary_path: Option<PathBuf>) -> Self {
|
||||||
git_hosting_provider_registry: Arc<GitHostingProviderRegistry>,
|
Self { git_binary_path }
|
||||||
git_binary_path: Option<PathBuf>,
|
|
||||||
) -> Self {
|
|
||||||
Self {
|
|
||||||
git_hosting_provider_registry,
|
|
||||||
git_binary_path,
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -770,7 +762,6 @@ impl Fs for RealFs {
|
||||||
Some(Arc::new(RealGitRepository::new(
|
Some(Arc::new(RealGitRepository::new(
|
||||||
repo,
|
repo,
|
||||||
self.git_binary_path.clone(),
|
self.git_binary_path.clone(),
|
||||||
self.git_hosting_provider_registry.clone(),
|
|
||||||
)))
|
)))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,17 +1,15 @@
|
||||||
use crate::commit::get_messages;
|
use crate::commit::get_messages;
|
||||||
use crate::{parse_git_remote_url, BuildCommitPermalinkParams, GitHostingProviderRegistry, Oid};
|
use crate::Oid;
|
||||||
use anyhow::{anyhow, Context as _, Result};
|
use anyhow::{anyhow, Context as _, Result};
|
||||||
use collections::{HashMap, HashSet};
|
use collections::{HashMap, HashSet};
|
||||||
use serde::{Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
use std::io::Write;
|
use std::io::Write;
|
||||||
use std::process::Stdio;
|
use std::process::Stdio;
|
||||||
use std::sync::Arc;
|
|
||||||
use std::{ops::Range, path::Path};
|
use std::{ops::Range, path::Path};
|
||||||
use text::Rope;
|
use text::Rope;
|
||||||
use time::macros::format_description;
|
use time::macros::format_description;
|
||||||
use time::OffsetDateTime;
|
use time::OffsetDateTime;
|
||||||
use time::UtcOffset;
|
use time::UtcOffset;
|
||||||
use url::Url;
|
|
||||||
|
|
||||||
pub use git2 as libgit;
|
pub use git2 as libgit;
|
||||||
|
|
||||||
|
@ -19,7 +17,6 @@ pub use git2 as libgit;
|
||||||
pub struct Blame {
|
pub struct Blame {
|
||||||
pub entries: Vec<BlameEntry>,
|
pub entries: Vec<BlameEntry>,
|
||||||
pub messages: HashMap<Oid, String>,
|
pub messages: HashMap<Oid, String>,
|
||||||
pub permalinks: HashMap<Oid, Url>,
|
|
||||||
pub remote_url: Option<String>,
|
pub remote_url: Option<String>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -30,32 +27,15 @@ impl Blame {
|
||||||
path: &Path,
|
path: &Path,
|
||||||
content: &Rope,
|
content: &Rope,
|
||||||
remote_url: Option<String>,
|
remote_url: Option<String>,
|
||||||
provider_registry: Arc<GitHostingProviderRegistry>,
|
|
||||||
) -> Result<Self> {
|
) -> Result<Self> {
|
||||||
let output = run_git_blame(git_binary, working_directory, path, content)?;
|
let output = run_git_blame(git_binary, working_directory, path, content)?;
|
||||||
let mut entries = parse_git_blame(&output)?;
|
let mut entries = parse_git_blame(&output)?;
|
||||||
entries.sort_unstable_by(|a, b| a.range.start.cmp(&b.range.start));
|
entries.sort_unstable_by(|a, b| a.range.start.cmp(&b.range.start));
|
||||||
|
|
||||||
let mut permalinks = HashMap::default();
|
|
||||||
let mut unique_shas = HashSet::default();
|
let mut unique_shas = HashSet::default();
|
||||||
let parsed_remote_url = remote_url
|
|
||||||
.as_deref()
|
|
||||||
.and_then(|remote_url| parse_git_remote_url(provider_registry, remote_url));
|
|
||||||
|
|
||||||
for entry in entries.iter_mut() {
|
for entry in entries.iter_mut() {
|
||||||
unique_shas.insert(entry.sha);
|
unique_shas.insert(entry.sha);
|
||||||
// DEPRECATED (18 Apr 24): Sending permalinks over the wire is deprecated. Clients
|
|
||||||
// now do the parsing.
|
|
||||||
if let Some((provider, remote)) = parsed_remote_url.as_ref() {
|
|
||||||
permalinks.entry(entry.sha).or_insert_with(|| {
|
|
||||||
provider.build_commit_permalink(
|
|
||||||
remote,
|
|
||||||
BuildCommitPermalinkParams {
|
|
||||||
sha: entry.sha.to_string().as_str(),
|
|
||||||
},
|
|
||||||
)
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
let shas = unique_shas.into_iter().collect::<Vec<_>>();
|
let shas = unique_shas.into_iter().collect::<Vec<_>>();
|
||||||
|
@ -64,7 +44,6 @@ impl Blame {
|
||||||
|
|
||||||
Ok(Self {
|
Ok(Self {
|
||||||
entries,
|
entries,
|
||||||
permalinks,
|
|
||||||
messages,
|
messages,
|
||||||
remote_url,
|
remote_url,
|
||||||
})
|
})
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
use crate::status::FileStatus;
|
use crate::status::FileStatus;
|
||||||
use crate::GitHostingProviderRegistry;
|
|
||||||
use crate::{blame::Blame, status::GitStatus};
|
use crate::{blame::Blame, status::GitStatus};
|
||||||
use anyhow::{anyhow, Context, Result};
|
use anyhow::{anyhow, Context, Result};
|
||||||
use askpass::{AskPassResult, AskPassSession};
|
use askpass::{AskPassResult, AskPassSession};
|
||||||
|
@ -263,19 +262,13 @@ impl std::fmt::Debug for dyn GitRepository {
|
||||||
pub struct RealGitRepository {
|
pub struct RealGitRepository {
|
||||||
pub repository: Mutex<git2::Repository>,
|
pub repository: Mutex<git2::Repository>,
|
||||||
pub git_binary_path: PathBuf,
|
pub git_binary_path: PathBuf,
|
||||||
hosting_provider_registry: Arc<GitHostingProviderRegistry>,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
impl RealGitRepository {
|
impl RealGitRepository {
|
||||||
pub fn new(
|
pub fn new(repository: git2::Repository, git_binary_path: Option<PathBuf>) -> Self {
|
||||||
repository: git2::Repository,
|
|
||||||
git_binary_path: Option<PathBuf>,
|
|
||||||
hosting_provider_registry: Arc<GitHostingProviderRegistry>,
|
|
||||||
) -> Self {
|
|
||||||
Self {
|
Self {
|
||||||
repository: Mutex::new(repository),
|
repository: Mutex::new(repository),
|
||||||
git_binary_path: git_binary_path.unwrap_or_else(|| PathBuf::from("git")),
|
git_binary_path: git_binary_path.unwrap_or_else(|| PathBuf::from("git")),
|
||||||
hosting_provider_registry,
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -617,7 +610,6 @@ impl GitRepository for RealGitRepository {
|
||||||
path,
|
path,
|
||||||
&content,
|
&content,
|
||||||
remote_url,
|
remote_url,
|
||||||
self.hosting_provider_registry.clone(),
|
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -15,7 +15,6 @@ use git::{blame::Blame, repository::RepoPath};
|
||||||
use gpui::{
|
use gpui::{
|
||||||
App, AppContext as _, AsyncApp, Context, Entity, EventEmitter, Subscription, Task, WeakEntity,
|
App, AppContext as _, AsyncApp, Context, Entity, EventEmitter, Subscription, Task, WeakEntity,
|
||||||
};
|
};
|
||||||
use http_client::Url;
|
|
||||||
use language::{
|
use language::{
|
||||||
proto::{
|
proto::{
|
||||||
deserialize_line_ending, deserialize_version, serialize_line_ending, serialize_version,
|
deserialize_line_ending, deserialize_version, serialize_line_ending, serialize_version,
|
||||||
|
@ -34,7 +33,6 @@ use std::{
|
||||||
ops::Range,
|
ops::Range,
|
||||||
path::{Path, PathBuf},
|
path::{Path, PathBuf},
|
||||||
pin::pin,
|
pin::pin,
|
||||||
str::FromStr as _,
|
|
||||||
sync::Arc,
|
sync::Arc,
|
||||||
time::Instant,
|
time::Instant,
|
||||||
};
|
};
|
||||||
|
@ -2776,20 +2774,10 @@ fn serialize_blame_buffer_response(blame: Option<git::blame::Blame>) -> proto::B
|
||||||
})
|
})
|
||||||
.collect::<Vec<_>>();
|
.collect::<Vec<_>>();
|
||||||
|
|
||||||
let permalinks = blame
|
|
||||||
.permalinks
|
|
||||||
.into_iter()
|
|
||||||
.map(|(oid, url)| proto::CommitPermalink {
|
|
||||||
oid: oid.as_bytes().into(),
|
|
||||||
permalink: url.to_string(),
|
|
||||||
})
|
|
||||||
.collect::<Vec<_>>();
|
|
||||||
|
|
||||||
proto::BlameBufferResponse {
|
proto::BlameBufferResponse {
|
||||||
blame_response: Some(proto::blame_buffer_response::BlameResponse {
|
blame_response: Some(proto::blame_buffer_response::BlameResponse {
|
||||||
entries,
|
entries,
|
||||||
messages,
|
messages,
|
||||||
permalinks,
|
|
||||||
remote_url: blame.remote_url,
|
remote_url: blame.remote_url,
|
||||||
}),
|
}),
|
||||||
}
|
}
|
||||||
|
@ -2828,20 +2816,8 @@ fn deserialize_blame_buffer_response(
|
||||||
.filter_map(|message| Some((git::Oid::from_bytes(&message.oid).ok()?, message.message)))
|
.filter_map(|message| Some((git::Oid::from_bytes(&message.oid).ok()?, message.message)))
|
||||||
.collect::<HashMap<_, _>>();
|
.collect::<HashMap<_, _>>();
|
||||||
|
|
||||||
let permalinks = response
|
|
||||||
.permalinks
|
|
||||||
.into_iter()
|
|
||||||
.filter_map(|permalink| {
|
|
||||||
Some((
|
|
||||||
git::Oid::from_bytes(&permalink.oid).ok()?,
|
|
||||||
Url::from_str(&permalink.permalink).ok()?,
|
|
||||||
))
|
|
||||||
})
|
|
||||||
.collect::<HashMap<_, _>>();
|
|
||||||
|
|
||||||
Some(Blame {
|
Some(Blame {
|
||||||
entries,
|
entries,
|
||||||
permalinks,
|
|
||||||
messages,
|
messages,
|
||||||
remote_url: response.remote_url,
|
remote_url: response.remote_url,
|
||||||
})
|
})
|
||||||
|
|
|
@ -2321,8 +2321,8 @@ message BlameBufferResponse {
|
||||||
message BlameResponse {
|
message BlameResponse {
|
||||||
repeated BlameEntry entries = 1;
|
repeated BlameEntry entries = 1;
|
||||||
repeated CommitMessage messages = 2;
|
repeated CommitMessage messages = 2;
|
||||||
repeated CommitPermalink permalinks = 3;
|
|
||||||
optional string remote_url = 4;
|
optional string remote_url = 4;
|
||||||
|
reserved 3;
|
||||||
}
|
}
|
||||||
|
|
||||||
optional BlameResponse blame_response = 5;
|
optional BlameResponse blame_response = 5;
|
||||||
|
|
|
@ -445,7 +445,7 @@ pub fn execute_run(
|
||||||
let extension_host_proxy = ExtensionHostProxy::global(cx);
|
let extension_host_proxy = ExtensionHostProxy::global(cx);
|
||||||
|
|
||||||
let project = cx.new(|cx| {
|
let project = cx.new(|cx| {
|
||||||
let fs = Arc::new(RealFs::new(Default::default(), None));
|
let fs = Arc::new(RealFs::new(None));
|
||||||
let node_settings_rx = initialize_settings(session.clone(), fs.clone(), cx);
|
let node_settings_rx = initialize_settings(session.clone(), fs.clone(), cx);
|
||||||
|
|
||||||
let proxy_url = read_proxy_settings(cx);
|
let proxy_url = read_proxy_settings(cx);
|
||||||
|
|
|
@ -254,10 +254,7 @@ fn main() {
|
||||||
};
|
};
|
||||||
log::info!("Using git binary path: {:?}", git_binary_path);
|
log::info!("Using git binary path: {:?}", git_binary_path);
|
||||||
|
|
||||||
let fs = Arc::new(RealFs::new(
|
let fs = Arc::new(RealFs::new(git_binary_path));
|
||||||
git_hosting_provider_registry.clone(),
|
|
||||||
git_binary_path,
|
|
||||||
));
|
|
||||||
let user_settings_file_rx = watch_config_file(
|
let user_settings_file_rx = watch_config_file(
|
||||||
&app.background_executor(),
|
&app.background_executor(),
|
||||||
fs.clone(),
|
fs.clone(),
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue