git.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH 1/3] difftool: sanitize $workdir as early as possible
@ 2016-12-09  8:58 David Aguilar
  2016-12-09  8:58 ` [PATCH 2/3] difftool: chdir " David Aguilar
  2016-12-09  8:58 ` [PATCH 3/3] difftool: rename variables for consistency David Aguilar
  0 siblings, 2 replies; 5+ messages in thread
From: David Aguilar @ 2016-12-09  8:58 UTC (permalink / raw)
  To: Junio C Hamano; +Cc: Git ML

The double-slash fixup on the $workdir variable was being
performed just-in-time to avoid double-slashes in symlink
targets, but the rest of the code was silently using paths with
embedded "//" in them.

A recent user-reported error message contained double-slashes.
Eliminate the issue by sanitizing inputs as soon as they arrive.

Signed-off-by: David Aguilar <davvid@gmail.com>
---
 git-difftool.perl | 5 ++---
 1 file changed, 2 insertions(+), 3 deletions(-)

diff --git a/git-difftool.perl b/git-difftool.perl
index 959822d5f3..17c336321f 100755
--- a/git-difftool.perl
+++ b/git-difftool.perl
@@ -224,9 +224,7 @@ EOF
 	delete($ENV{GIT_INDEX_FILE});
 
 	# Changes in the working tree need special treatment since they are
-	# not part of the index. Remove any trailing slash from $workdir
-	# before starting to avoid double slashes in symlink targets.
-	$workdir =~ s|/$||;
+	# not part of the index.
 	for my $file (@working_tree) {
 		my $dir = dirname($file);
 		unless (-d "$rdir/$dir") {
@@ -389,6 +387,7 @@ sub dir_diff
 	my $repo = Git->repository();
 	my $repo_path = $repo->repo_path();
 	my $workdir = $repo->wc_path();
+	$workdir =~ s|/$||; # Avoid double slashes in symlink targets
 	my ($a, $b, $tmpdir, @worktree) = setup_dir_diff($workdir, $symlinks);
 
 	if (defined($extcmd)) {
-- 
2.11.0.26.gb65c994


^ permalink raw reply related	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2016-12-10  0:04 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2016-12-09  8:58 [PATCH 1/3] difftool: sanitize $workdir as early as possible David Aguilar
2016-12-09  8:58 ` [PATCH 2/3] difftool: chdir " David Aguilar
2016-12-09 23:02   ` Junio C Hamano
2016-12-10  0:03     ` David Aguilar
2016-12-09  8:58 ` [PATCH 3/3] difftool: rename variables for consistency David Aguilar

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).