summaryrefslogtreecommitdiff
path: root/diff.c
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2010-11-17 22:59:10 (GMT)
committerJunio C Hamano <gitster@pobox.com>2010-11-17 22:59:10 (GMT)
commit6a2e93f1074d5a8b25c2020805e6b8d795d13e4d (patch)
tree137792eaffc80800186318ae6c894144fda8ffbb /diff.c
parentfbfe5de5bdaaf9572c1811e3b4ddfaa35e6bb227 (diff)
parentd391c0ff94e1b314b0664db0e8eb5bd92934f9cb (diff)
downloadgit-6a2e93f1074d5a8b25c2020805e6b8d795d13e4d.zip
git-6a2e93f1074d5a8b25c2020805e6b8d795d13e4d.tar.gz
git-6a2e93f1074d5a8b25c2020805e6b8d795d13e4d.tar.bz2
Merge branch 'jk/no-textconv-symlink'
* jk/no-textconv-symlink: diff: don't use pathname-based diff drivers for symlinks
Diffstat (limited to 'diff.c')
-rw-r--r--diff.c11
1 files changed, 8 insertions, 3 deletions
diff --git a/diff.c b/diff.c
index d1c6b91..c8e4366 100644
--- a/diff.c
+++ b/diff.c
@@ -1771,8 +1771,14 @@ static void emit_binary_diff(FILE *file, mmfile_t *one, mmfile_t *two, char *pre
static void diff_filespec_load_driver(struct diff_filespec *one)
{
- if (!one->driver)
+ /* Use already-loaded driver */
+ if (one->driver)
+ return;
+
+ if (S_ISREG(one->mode))
one->driver = userdiff_find_by_path(one->path);
+
+ /* Fallback to default settings */
if (!one->driver)
one->driver = userdiff_find_by_name("default");
}
@@ -1820,8 +1826,7 @@ struct userdiff_driver *get_textconv(struct diff_filespec *one)
{
if (!DIFF_FILE_VALID(one))
return NULL;
- if (!S_ISREG(one->mode))
- return NULL;
+
diff_filespec_load_driver(one);
if (!one->driver->textconv)
return NULL;