From: Phillip Wood <phillip.wood123@gmail.com>
To: Caleb White <cdwhite3@pm.me>, git@vger.kernel.org
Cc: Taylor Blau <me@ttaylorr.com>, Junio C Hamano <gitster@pobox.com>,
Eric Sunshine <sunshine@sunshineco.com>
Subject: Re: [PATCH v4 6/8] worktree: add relative cli/config options to `move` command
Date: Fri, 22 Nov 2024 15:55:31 +0000 [thread overview]
Message-ID: <75b4023a-4005-49ff-a06d-e50fcd1c2b50@gmail.com> (raw)
In-Reply-To: <20241031-wt_relative_options-v4-6-07a3dc0f02a3@pm.me>
Hi Caleb
This looks good, I've left a couple of comments on the tests - they
could be cleaned up like the last patch. The implementation looks good.
On 01/11/2024 04:38, Caleb White wrote:
> This teaches the `worktree move` command to respect the
> `--[no-]relative-paths` CLI option and `worktree.useRelativePaths`
> config setting. If an existing worktree is moved with `--relative-paths`
> the new path will be relative (and visa-versa).
>
> Signed-off-by: Caleb White <cdwhite3@pm.me>
> ---
> builtin/worktree.c | 4 +++-
> t/t2403-worktree-move.sh | 22 ++++++++++++++++++++++
> worktree.c | 23 ++++++++++-------------
> worktree.h | 3 ++-
> 4 files changed, 37 insertions(+), 15 deletions(-)
>
> diff --git a/builtin/worktree.c b/builtin/worktree.c
> index e3b4a71ee0bc13d5e817cf7dcc398e9e2bd975de..302151506981718658db1cd338cd9064688f5c14 100644
> --- a/builtin/worktree.c
> +++ b/builtin/worktree.c
> @@ -1190,6 +1190,8 @@ static int move_worktree(int ac, const char **av, const char *prefix)
> OPT__FORCE(&force,
> N_("force move even if worktree is dirty or locked"),
> PARSE_OPT_NOCOMPLETE),
> + OPT_BOOL(0, "relative-paths", &use_relative_paths,
> + N_("use relative paths for worktrees")),
By the time this function is called we've already initialized
use_relative_paths from the config setting - good
> [...]
> +test_expect_success 'move worktree with absolute path to relative path' '
> + git config worktree.useRelativePaths false &&
> + git worktree add ./absolute &&
> + git worktree move --relative-paths absolute relative &&
> + cat relative/.git >actual &&
> + echo "gitdir: ../.git/worktrees/absolute" >expect &&
> + test_cmp expect actual &&
> + git config worktree.useRelativePaths true &&
> + git worktree move relative relative2 &&
> + cat relative2/.git >actual &&
> + echo "gitdir: ../.git/worktrees/absolute" >expect &&
> + test_cmp expect actual
> +'
As with the last patch we should use test_config and stop copying files
just to compare them. It's probably worth checking the gitdir file as
well as .git here as well.
> +test_expect_success 'move worktree with relative path to absolute path' '
> + git config worktree.useRelativePaths true &&
> + git worktree move --no-relative-paths relative2 absolute &&
> + cat absolute/.git >actual &&
> + echo "gitdir: $(pwd)/.git/worktrees/absolute" >expect &&
> + test_cmp expect actual
> +'
> +
> test_done
> [...]
> - strbuf_realpath(&repo, git_common_path("worktrees/%s", wt->id), 1);
> + strbuf_realpath(&gitdir, git_common_path("worktrees/%s/gitdir", wt->id), 1);
We used to append "/gitdir" below but now we do it all in one - nice.
> strbuf_realpath(&path, path_, 1);
> + strbuf_addf(&dotgit, "%s/.git", path.buf);
> if (fspathcmp(wt->path, path.buf)) {
get_linked_worktree guarentees that wt->path is absolute so this looks good.
> - strbuf_addf(&file, "%s/gitdir", repo.buf);
> - write_file(file.buf, "%s/.git", relative_path(path.buf, repo.buf, &tmp));
> - strbuf_reset(&file);
> - strbuf_addf(&file, "%s/.git", path.buf);
> - write_file(file.buf, "gitdir: %s", relative_path(repo.buf, path.buf, &tmp));
> + write_worktree_linking_files(dotgit, gitdir, use_relative_paths);
This is a nice simplification
Best Wishes
Phillip
next prev parent reply other threads:[~2024-11-22 15:55 UTC|newest]
Thread overview: 60+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-11-01 4:38 [PATCH v4 0/8] Allow relative worktree linking to be configured by the user Caleb White
2024-11-01 4:38 ` [PATCH v4 1/8] setup: correctly reinitialize repository version Caleb White
2024-11-01 4:38 ` [PATCH v4 2/8] worktree: add `relativeWorktrees` extension Caleb White
2024-11-19 15:07 ` Phillip Wood
2024-11-20 5:13 ` Caleb White
2024-11-22 16:44 ` Phillip Wood
2024-11-22 19:27 ` Caleb White
2024-11-01 4:38 ` [PATCH v4 3/8] worktree: refactor infer_backlink return Caleb White
2024-11-19 15:08 ` Phillip Wood
2024-11-20 5:20 ` Caleb White
2024-11-22 16:44 ` Phillip Wood
2024-11-22 19:26 ` Caleb White
2024-11-01 4:38 ` [PATCH v4 4/8] worktree: add `write_worktree_linking_files()` function Caleb White
2024-11-01 4:38 ` [PATCH v4 5/8] worktree: add relative cli/config options to `add` command Caleb White
2024-11-19 15:07 ` Phillip Wood
2024-11-20 5:01 ` Caleb White
2024-11-22 16:44 ` phillip.wood123
2024-11-23 4:40 ` Caleb White
2024-11-01 4:38 ` [PATCH v4 6/8] worktree: add relative cli/config options to `move` command Caleb White
2024-11-22 15:55 ` Phillip Wood [this message]
2024-11-23 4:11 ` Caleb White
2024-11-01 4:38 ` [PATCH v4 7/8] worktree: add relative cli/config options to `repair` command Caleb White
2024-11-22 15:55 ` Phillip Wood
2024-11-23 5:41 ` Caleb White
2024-11-24 19:27 ` phillip.wood123
2024-11-26 0:00 ` Caleb White
2024-11-01 4:39 ` [PATCH v4 8/8] worktree: refactor `repair_worktree_after_gitdir_move()` Caleb White
2024-11-22 15:58 ` Phillip Wood
2024-11-23 4:36 ` Caleb White
2024-11-01 7:14 ` [PATCH v4 0/8] Allow relative worktree linking to be configured by the user Junio C Hamano
2024-11-01 13:18 ` Caleb White
2024-11-02 10:09 ` Junio C Hamano
2024-11-02 14:36 ` Kristoffer Haugsbakk
2024-11-22 15:57 ` Phillip Wood
2024-11-23 5:45 ` Caleb White
2024-11-26 1:51 ` [PATCH v5 " Caleb White
2024-11-26 1:51 ` [PATCH v5 1/8] setup: correctly reinitialize repository version Caleb White
2024-11-26 1:51 ` [PATCH v5 2/8] worktree: add `relativeWorktrees` extension Caleb White
2024-11-26 1:51 ` [PATCH v5 3/8] worktree: refactor infer_backlink return Caleb White
2024-11-26 1:51 ` [PATCH v5 4/8] worktree: add `write_worktree_linking_files()` function Caleb White
2024-11-26 1:52 ` [PATCH v5 5/8] worktree: add relative cli/config options to `add` command Caleb White
2024-11-26 1:52 ` [PATCH v5 6/8] worktree: add relative cli/config options to `move` command Caleb White
2024-11-26 1:52 ` [PATCH v5 7/8] worktree: add relative cli/config options to `repair` command Caleb White
2024-11-26 1:52 ` [PATCH v5 8/8] worktree: refactor `repair_worktree_after_gitdir_move()` Caleb White
2024-11-26 6:18 ` [PATCH v5 0/8] Allow relative worktree linking to be configured by the user Junio C Hamano
2024-11-26 17:02 ` Caleb White
2024-11-28 14:44 ` Phillip Wood
2024-11-28 17:58 ` Caleb White
2024-11-29 22:22 ` [PATCH v6 " Caleb White
2024-11-29 22:22 ` [PATCH v6 1/8] setup: correctly reinitialize repository version Caleb White
2024-11-29 22:22 ` [PATCH v6 2/8] worktree: add `relativeWorktrees` extension Caleb White
2024-11-29 22:22 ` [PATCH v6 3/8] worktree: refactor infer_backlink return Caleb White
2024-11-29 22:22 ` [PATCH v6 4/8] worktree: add `write_worktree_linking_files()` function Caleb White
2024-11-29 22:22 ` [PATCH v6 5/8] worktree: add relative cli/config options to `add` command Caleb White
2024-11-29 22:23 ` [PATCH v6 6/8] worktree: add relative cli/config options to `move` command Caleb White
2024-11-29 22:23 ` [PATCH v6 7/8] worktree: add relative cli/config options to `repair` command Caleb White
2024-11-29 22:23 ` [PATCH v6 8/8] worktree: refactor `repair_worktree_after_gitdir_move()` Caleb White
2024-12-02 14:57 ` [PATCH v6 0/8] Allow relative worktree linking to be configured by the user Phillip Wood
2024-12-03 4:54 ` Junio C Hamano
2024-12-03 5:21 ` Caleb White
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=75b4023a-4005-49ff-a06d-e50fcd1c2b50@gmail.com \
--to=phillip.wood123@gmail.com \
--cc=cdwhite3@pm.me \
--cc=git@vger.kernel.org \
--cc=gitster@pobox.com \
--cc=me@ttaylorr.com \
--cc=phillip.wood@dunelm.org.uk \
--cc=sunshine@sunshineco.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.