3 test_description='word diff colors'
 
   6 . "$TEST_DIRECTORY"/diff-lib.sh
 
   8 cat >pre.simple <<-\EOF
 
  13 cat >post.simple <<-\EOF
 
  22 pre=$(git rev-parse --short $(git hash-object pre.simple))
 
  23 post=$(git rev-parse --short $(git hash-object post.simple))
 
  24 cat >expect.letter-runs-are-words <<-EOF
 
  25         <BOLD>diff --git a/pre b/post<RESET>
 
  26         <BOLD>index $pre..$post 100644<RESET>
 
  27         <BOLD>--- a/pre<RESET>
 
  28         <BOLD>+++ b/post<RESET>
 
  29         <CYAN>@@ -1,3 +1,7 @@<RESET>
 
  30         h(4),<GREEN>hh<RESET>[44]
 
  36         <GREEN>aeff = aeff * ( aaa<RESET> )
 
  38 cat >expect.non-whitespace-is-word <<-EOF
 
  39         <BOLD>diff --git a/pre b/post<RESET>
 
  40         <BOLD>index $pre..$post 100644<RESET>
 
  41         <BOLD>--- a/pre<RESET>
 
  42         <BOLD>+++ b/post<RESET>
 
  43         <CYAN>@@ -1,3 +1,7 @@<RESET>
 
  44         h(4)<GREEN>,hh[44]<RESET>
 
  50         <GREEN>aeff = aeff * ( aaa )<RESET>
 
  54         pre=$(git rev-parse --short $(git hash-object pre)) &&
 
  55         post=$(git rev-parse --short $(git hash-object post)) &&
 
  56         test_must_fail git diff --no-index "$@" pre post >output &&
 
  57         test_decode_color <output >output.decrypted &&
 
  58         sed -e "2s/index [^ ]*/index $pre..$post/" expect >expected
 
  59         test_cmp expected output.decrypted
 
  62 test_language_driver () {
 
  64         test_expect_success "diff driver '$lang'" '
 
  65                 cp "$TEST_DIRECTORY/t4034/'"$lang"'/pre" \
 
  66                         "$TEST_DIRECTORY/t4034/'"$lang"'/post" \
 
  67                         "$TEST_DIRECTORY/t4034/'"$lang"'/expect" . &&
 
  68                 echo "* diff='"$lang"'" >.gitattributes &&
 
  69                 word_diff --color-words
 
  73 test_expect_success setup '
 
  74         git config diff.color.old red &&
 
  75         git config diff.color.new green &&
 
  76         git config diff.color.func magenta
 
  79 test_expect_success 'set up pre and post with runs of whitespace' '
 
  84 test_expect_success 'word diff with runs of whitespace' '
 
  86                 <BOLD>diff --git a/pre b/post<RESET>
 
  87                 <BOLD>index $pre..$post 100644<RESET>
 
  88                 <BOLD>--- a/pre<RESET>
 
  89                 <BOLD>+++ b/post<RESET>
 
  90                 <CYAN>@@ -1,3 +1,7 @@<RESET>
 
  91                 <RED>h(4)<RESET><GREEN>h(4),hh[44]<RESET>
 
  97                 <GREEN>aeff = aeff * ( aaa )<RESET>
 
  99         word_diff --color-words &&
 
 100         word_diff --word-diff=color &&
 
 101         word_diff --color --word-diff=color
 
 104 test_expect_success '--word-diff=porcelain' '
 
 105         sed 's/#.*$//' >expect <<-EOF &&
 
 106                 diff --git a/pre b/post
 
 107                 index $pre..$post 100644
 
 122                 +aeff = aeff * ( aaa )
 
 125         word_diff --word-diff=porcelain
 
 128 test_expect_success '--word-diff=plain' '
 
 129         cat >expect <<-EOF &&
 
 130                 diff --git a/pre b/post
 
 131                 index $pre..$post 100644
 
 135                 [-h(4)-]{+h(4),hh[44]+}
 
 141                 {+aeff = aeff * ( aaa )+}
 
 143         word_diff --word-diff=plain &&
 
 144         word_diff --word-diff=plain --no-color
 
 147 test_expect_success '--word-diff=plain --color' '
 
 148         cat >expect <<-EOF &&
 
 149                 <BOLD>diff --git a/pre b/post<RESET>
 
 150                 <BOLD>index $pre..$post 100644<RESET>
 
 151                 <BOLD>--- a/pre<RESET>
 
 152                 <BOLD>+++ b/post<RESET>
 
 153                 <CYAN>@@ -1,3 +1,7 @@<RESET>
 
 154                 <RED>[-h(4)-]<RESET><GREEN>{+h(4),hh[44]+}<RESET>
 
 158                 <GREEN>{+aa = a+}<RESET>
 
 160                 <GREEN>{+aeff = aeff * ( aaa )+}<RESET>
 
 162         word_diff --word-diff=plain --color
 
 165 test_expect_success 'word diff without context' '
 
 166         cat >expect <<-EOF &&
 
 167                 <BOLD>diff --git a/pre b/post<RESET>
 
 168                 <BOLD>index $pre..$post 100644<RESET>
 
 169                 <BOLD>--- a/pre<RESET>
 
 170                 <BOLD>+++ b/post<RESET>
 
 171                 <CYAN>@@ -1 +1 @@<RESET>
 
 172                 <RED>h(4)<RESET><GREEN>h(4),hh[44]<RESET>
 
 173                 <CYAN>@@ -3,0 +4,4 @@<RESET> <RESET><MAGENTA>a = b + c<RESET>
 
 177                 <GREEN>aeff = aeff * ( aaa )<RESET>
 
 179         word_diff --color-words --unified=0
 
 182 test_expect_success 'word diff with a regular expression' '
 
 183         cp expect.letter-runs-are-words expect &&
 
 184         word_diff --color-words="[a-z]+"
 
 187 test_expect_success 'set up a diff driver' '
 
 188         git config diff.testdriver.wordRegex "[^[:space:]]" &&
 
 189         cat <<-\EOF >.gitattributes
 
 195 test_expect_success 'option overrides .gitattributes' '
 
 196         cp expect.letter-runs-are-words expect &&
 
 197         word_diff --color-words="[a-z]+"
 
 200 test_expect_success 'use regex supplied by driver' '
 
 201         cp expect.non-whitespace-is-word expect &&
 
 202         word_diff --color-words
 
 205 test_expect_success 'set up diff.wordRegex option' '
 
 206         git config diff.wordRegex "[[:alnum:]]+"
 
 209 test_expect_success 'command-line overrides config' '
 
 210         cp expect.letter-runs-are-words expect &&
 
 211         word_diff --color-words="[a-z]+"
 
 214 test_expect_success 'command-line overrides config: --word-diff-regex' '
 
 215         cat >expect <<-EOF &&
 
 216                 <BOLD>diff --git a/pre b/post<RESET>
 
 217                 <BOLD>index $pre..$post 100644<RESET>
 
 218                 <BOLD>--- a/pre<RESET>
 
 219                 <BOLD>+++ b/post<RESET>
 
 220                 <CYAN>@@ -1,3 +1,7 @@<RESET>
 
 221                 h(4),<GREEN>{+hh+}<RESET>[44]
 
 225                 <GREEN>{+aa = a+}<RESET>
 
 227                 <GREEN>{+aeff = aeff * ( aaa+}<RESET> )
 
 229         word_diff --color --word-diff-regex="[a-z]+"
 
 232 test_expect_success '.gitattributes override config' '
 
 233         cp expect.non-whitespace-is-word expect &&
 
 234         word_diff --color-words
 
 237 test_expect_success 'setup: remove diff driver regex' '
 
 238         test_unconfig diff.testdriver.wordRegex
 
 241 test_expect_success 'use configured regex' '
 
 242         cat >expect <<-EOF &&
 
 243                 <BOLD>diff --git a/pre b/post<RESET>
 
 244                 <BOLD>index $pre..$post 100644<RESET>
 
 245                 <BOLD>--- a/pre<RESET>
 
 246                 <BOLD>+++ b/post<RESET>
 
 247                 <CYAN>@@ -1,3 +1,7 @@<RESET>
 
 248                 h(4),<GREEN>hh[44<RESET>]
 
 254                 <GREEN>aeff = aeff * ( aaa<RESET> )
 
 256         word_diff --color-words
 
 259 test_expect_success 'test parsing words for newline' '
 
 260         echo "aaa (aaa)" >pre &&
 
 261         echo "aaa (aaa) aaa" >post &&
 
 262         pre=$(git rev-parse --short $(git hash-object pre)) &&
 
 263         post=$(git rev-parse --short $(git hash-object post)) &&
 
 264         cat >expect <<-EOF &&
 
 265                 <BOLD>diff --git a/pre b/post<RESET>
 
 266                 <BOLD>index $pre..$post 100644<RESET>
 
 267                 <BOLD>--- a/pre<RESET>
 
 268                 <BOLD>+++ b/post<RESET>
 
 269                 <CYAN>@@ -1 +1 @@<RESET>
 
 270                 aaa (aaa) <GREEN>aaa<RESET>
 
 272         word_diff --color-words="a+"
 
 275 test_expect_success 'test when words are only removed at the end' '
 
 278         pre=$(git rev-parse --short $(git hash-object pre)) &&
 
 279         post=$(git rev-parse --short $(git hash-object post)) &&
 
 280         cat >expect <<-EOF &&
 
 281                 <BOLD>diff --git a/pre b/post<RESET>
 
 282                 <BOLD>index $pre..$post 100644<RESET>
 
 283                 <BOLD>--- a/pre<RESET>
 
 284                 <BOLD>+++ b/post<RESET>
 
 285                 <CYAN>@@ -1 +1 @@<RESET>
 
 288         word_diff --color-words=.
 
 291 test_expect_success '--word-diff=none' '
 
 294         pre=$(git rev-parse --short $(git hash-object pre)) &&
 
 295         post=$(git rev-parse --short $(git hash-object post)) &&
 
 296         cat >expect <<-EOF &&
 
 297                 diff --git a/pre b/post
 
 298                 index $pre..$post 100644
 
 305         word_diff --word-diff=plain --word-diff=none
 
 308 test_expect_success 'unset default driver' '
 
 309         test_unconfig diff.wordregex
 
 312 test_language_driver ada
 
 313 test_language_driver bibtex
 
 314 test_language_driver cpp
 
 315 test_language_driver csharp
 
 316 test_language_driver css
 
 317 test_language_driver dts
 
 318 test_language_driver fortran
 
 319 test_language_driver html
 
 320 test_language_driver java
 
 321 test_language_driver matlab
 
 322 test_language_driver objc
 
 323 test_language_driver pascal
 
 324 test_language_driver perl
 
 325 test_language_driver php
 
 326 test_language_driver python
 
 327 test_language_driver ruby
 
 328 test_language_driver tex
 
 330 test_expect_success 'word-diff with diff.sbe' '
 
 341         pre=$(git rev-parse --short $(git hash-object pre)) &&
 
 342         post=$(git rev-parse --short $(git hash-object post)) &&
 
 343         cat >expect <<-EOF &&
 
 344         diff --git a/pre b/post
 
 345         index $pre..$post 100644
 
 353         test_config diff.suppress-blank-empty true &&
 
 354         word_diff --word-diff=plain
 
 357 test_expect_success 'word-diff with no newline at EOF' '
 
 358         printf "%s" "a a a a a" >pre &&
 
 359         printf "%s" "a a ab a a" >post &&
 
 360         pre=$(git rev-parse --short $(git hash-object pre)) &&
 
 361         post=$(git rev-parse --short $(git hash-object post)) &&
 
 362         cat >expect <<-EOF &&
 
 363         diff --git a/pre b/post
 
 364         index $pre..$post 100644
 
 370         word_diff --word-diff=plain
 
 373 test_expect_success 'setup history with two files' '
 
 374         echo "a b; c" >a.tex &&
 
 375         echo "a b; c" >z.txt &&
 
 376         git add a.tex z.txt &&
 
 377         git commit -minitial &&
 
 380         echo "a bx; c" >a.tex &&
 
 381         echo "a bx; c" >z.txt &&
 
 382         git commit -mmodified -a
 
 385 test_expect_success 'wordRegex for the first file does not apply to the second' '
 
 386         echo "*.tex diff=tex" >.gitattributes &&
 
 387         test_config diff.tex.wordRegex "[a-z]+|." &&
 
 388         cat >expect <<-\EOF &&
 
 389                 diff --git a/a.tex b/a.tex
 
 394                 diff --git a/z.txt b/z.txt
 
 400         git diff --word-diff HEAD~ >actual &&
 
 401         compare_diff_patch expect actual