Unwind deprecated permalinks code (#26395)

Release Notes:

- N/A
This commit is contained in:
Conrad Irwin 2025-03-10 19:57:10 -06:00 committed by GitHub
parent 1a3597d726
commit c37d6d5fed
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
12 changed files with 11 additions and 93 deletions

1
Cargo.lock generated
View file

@ -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",

View file

@ -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"),

View file

@ -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

View file

@ -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

View file

@ -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| {

View file

@ -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(),
))) )))
} }

View file

@ -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,
}) })

View file

@ -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(),
) )
} }

View file

@ -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,
}) })

View file

@ -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;

View file

@ -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);

View file

@ -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(),