mirror of
https://github.com/martinvonz/jj.git
synced 2025-01-07 05:16:33 +00:00
working_copy: move creation of parent dirs to one place
I'm about to add handling of parent dirs that are existing ignored files, so it's better to have it in one place. The only functional difference should be that we now create parent directories for git submodules. I don't think that matters.
This commit is contained in:
parent
7f4fe22a98
commit
4601c87710
1 changed files with 3 additions and 3 deletions
|
@ -1076,7 +1076,6 @@ impl TreeState {
|
|||
id: &FileId,
|
||||
executable: bool,
|
||||
) -> Result<FileState, CheckoutError> {
|
||||
create_parent_dirs(&self.working_copy_path, path)?;
|
||||
let mut file = OpenOptions::new()
|
||||
.write(true)
|
||||
.create_new(true) // Don't overwrite un-ignored file. Don't follow symlink.
|
||||
|
@ -1109,7 +1108,6 @@ impl TreeState {
|
|||
path: &RepoPath,
|
||||
id: &SymlinkId,
|
||||
) -> Result<FileState, CheckoutError> {
|
||||
create_parent_dirs(&self.working_copy_path, path)?;
|
||||
let target = self.store.read_symlink(path, id)?;
|
||||
#[cfg(windows)]
|
||||
{
|
||||
|
@ -1139,7 +1137,6 @@ impl TreeState {
|
|||
path: &RepoPath,
|
||||
conflict: &Merge<Option<TreeValue>>,
|
||||
) -> Result<FileState, CheckoutError> {
|
||||
create_parent_dirs(&self.working_copy_path, path)?;
|
||||
let mut file = OpenOptions::new()
|
||||
.write(true)
|
||||
.create_new(true) // Don't overwrite un-ignored file. Don't follow symlink.
|
||||
|
@ -1238,6 +1235,9 @@ impl TreeState {
|
|||
if before.is_present() {
|
||||
fs::remove_file(&disk_path).ok();
|
||||
}
|
||||
if after.is_present() {
|
||||
create_parent_dirs(&self.working_copy_path, &path)?;
|
||||
}
|
||||
// TODO: Check that the file has not changed before overwriting/removing it.
|
||||
match after.into_resolved() {
|
||||
Ok(None) => {
|
||||
|
|
Loading…
Reference in a new issue