ok/jj
1
0
Fork 0
forked from mirrors/jj

git: use forward slashes in relative path to backing git repo

Closes #2403.
This commit is contained in:
Martin von Zweigbergk 2023-10-19 16:05:09 -07:00 committed by Austin Seipp
parent cfcc76571c
commit 578d61ec2e

View file

@ -138,8 +138,22 @@ impl GitBackend {
let extra_path = store_path.join("extra"); let extra_path = store_path.join("extra");
fs::create_dir(&extra_path).context(&extra_path)?; fs::create_dir(&extra_path).context(&extra_path)?;
let target_path = store_path.join("git_target"); let target_path = store_path.join("git_target");
fs::write(&target_path, git_repo_path.to_str().unwrap().as_bytes()) if cfg!(windows) && git_repo_path.is_relative() {
.context(&target_path)?; // When a repository is created in Windows, format the path with *forward
// slashes* and not backwards slashes. This makes it possible to use the same
// repository under Windows Subsystem for Linux.
//
// This only works for relative paths. If the path is absolute, there's not much
// we can do, and it simply won't work inside and outside WSL at the same time.
let git_repo_path_string = git_repo_path
.components()
.map(|component| component.as_os_str().to_str().unwrap().to_owned())
.join("/");
fs::write(&target_path, git_repo_path_string.as_bytes()).context(&target_path)?;
} else {
fs::write(&target_path, git_repo_path.to_str().unwrap().as_bytes())
.context(&target_path)?;
};
let repo = git2::Repository::open(store_path.join(git_repo_path)) let repo = git2::Repository::open(store_path.join(git_repo_path))
.map_err(GitBackendInitError::OpenRepository)?; .map_err(GitBackendInitError::OpenRepository)?;
let extra_metadata_store = TableStore::init(extra_path, HASH_LENGTH); let extra_metadata_store = TableStore::init(extra_path, HASH_LENGTH);