From: Torsten Bögershausen <tbo...@web.de>

When a filter is configured, a different code-path is used in
convert.c and entry.c via get_stream_filter(), but there are no test cases yet.

Add tests for the filter API by configuring the ident filter.
The result of the SHA1 conversion is not checked, this is already
done in other TC.

Add a parameter to checkout_files() in t0027.
While changing the signature, add another parameter for the eol= attribute.
This is currently unused, tests for e.g.
"* text=auto eol=lf" will be added in a separate commit.

Signed-off-by: Torsten Bögershausen <tbo...@web.de>
---
- This needs to go on top of  tb/ls-files-eol
changes since v1:
- minor type, add signoff (Thanks Eric)
- Can not use sed as intended:
  Non-Gnu sed like Mac OS needs "lines" to have a LF at the end,
  otherwise they add one. Use tr instead.
  
t/t0027-auto-crlf.sh | 262 ++++++++++++++++++++++++++++-----------------------
 1 file changed, 146 insertions(+), 116 deletions(-)

diff --git a/t/t0027-auto-crlf.sh b/t/t0027-auto-crlf.sh
index 504e5a0..f830243 100755
--- a/t/t0027-auto-crlf.sh
+++ b/t/t0027-auto-crlf.sh
@@ -21,32 +21,45 @@ compare_ws_file () {
        pfx=$1
        exp=$2.expect
        act=$pfx.actual.$3
-       tr '\015\000' QN <"$2" >"$exp" &&
-       tr '\015\000' QN <"$3" >"$act" &&
+       tr '\015\000abcdef01234567890' QN00000000000000000 <"$2" >"$exp" &&
+       tr '\015\000abcdef01234567890' QN00000000000000000 <"$3" >"$act" &&
        test_cmp $exp $act &&
        rm $exp $act
 }
 
 create_gitattributes () {
        attr=$1
+       ident=$2
+       case "$2" in
+               "")
+                       >.gitattributes
+                       ;;
+               i)
+                       echo "* ident" >.gitattributes
+                       ;;
+               *)
+                       echo >&2 invalid ident: $2
+                       exit 1
+       esac
+
        case "$attr" in
                auto)
-               echo "*.txt text=auto" >.gitattributes
+               echo "*.txt text=auto" >>.gitattributes
                ;;
                text)
-               echo "*.txt text" >.gitattributes
+               echo "*.txt text" >>.gitattributes
                ;;
                -text)
-               echo "*.txt -text" >.gitattributes
+               echo "*.txt -text" >>.gitattributes
                ;;
                crlf)
-               echo "*.txt eol=crlf" >.gitattributes
+               echo "*.txt eol=crlf" >>.gitattributes
                ;;
                lf)
-               echo "*.txt eol=lf" >.gitattributes
+               echo "*.txt eol=lf" >>.gitattributes
                ;;
                "")
-               echo >.gitattributes
+               #echo >.gitattributes
                ;;
                *)
                echo >&2 invalid attribute: $attr
@@ -90,7 +103,7 @@ commit_check_warn () {
        lfmixcr=$6
        crlfnul=$7
        pfx=crlf_${crlf}_attr_${attr}
-       create_gitattributes "$attr" &&
+       create_gitattributes "$attr" "" &&
        for f in LF CRLF LF_mix_CR CRLF_mix_LF LF_nul CRLF_nul
        do
                fname=${pfx}_$f.txt &&
@@ -115,7 +128,7 @@ commit_chk_wrnNNO () {
        crlfnul=$7
        pfx=NNO_${crlf}_attr_${attr}
        #Commit files on top of existing file
-       create_gitattributes "$attr" &&
+       create_gitattributes "$attr" "" &&
        for f in LF CRLF CRLF_mix_LF LF_mix_CR CRLF_nul
        do
                fname=${pfx}_$f.txt &&
@@ -208,28 +221,30 @@ check_in_repo_NNO () {
 }
 
 checkout_files () {
-       eol=$1
-       crlf=$2
-       attr=$3
-       lfname=$4
-       crlfname=$5
-       lfmixcrlf=$6
-       lfmixcr=$7
-       crlfnul=$8
-       create_gitattributes $attr &&
+       attr=$1 ; shift
+       ident=$1; shift
+       aeol=$1 ; shift
+       crlf=$1 ; shift
+       ceol=$1 ; shift
+       lfname=$1 ; shift
+       crlfname=$1 ; shift
+       lfmixcrlf=$1 ; shift
+       lfmixcr=$1 ; shift
+       crlfnul=$1 ; shift
+       create_gitattributes "$attr" "$ident" &&
        git config core.autocrlf $crlf &&
-       pfx=eol_${eol}_crlf_${crlf}_attr_${attr}_ &&
+       pfx=eol_${ceol}_crlf_${crlf}_attr_${attr}_ &&
        for f in LF CRLF LF_mix_CR CRLF_mix_LF LF_nul
        do
                rm crlf_false_attr__$f.txt &&
-               if test -z "$eol"; then
+               if test -z "$ceol"; then
                        git checkout crlf_false_attr__$f.txt
                else
-                       git -c core.eol=$eol checkout crlf_false_attr__$f.txt
+                       git -c core.eol=$ceol checkout crlf_false_attr__$f.txt
                fi
        done
 
-       test_expect_success "ls-files --eol $lfname ${pfx}LF.txt" '
+       test_expect_success "ls-files --eol i=$ident attributes=$attr $aeol 
core.autocrlf=$crlf core.eol=$ceol" '
                test_when_finished "rm expect actual" &&
                sort <<-EOF >expect &&
                i/crlf w/$(stats_ascii $crlfname) crlf_false_attr__CRLF.txt
@@ -244,19 +259,19 @@ checkout_files () {
                sort >actual &&
                test_cmp expect actual
        '
-       test_expect_success "checkout core.eol=$eol core.autocrlf=$crlf 
gitattributes=$attr file=LF" "
+       test_expect_success "checkout i=$ident attributes=$attr $aeol 
core.autocrlf=$crlf core.eol=$ceol file=LF" "
                compare_ws_file $pfx $lfname    crlf_false_attr__LF.txt
        "
-       test_expect_success "checkout core.eol=$eol core.autocrlf=$crlf 
gitattributes=$attr file=CRLF" "
+       test_expect_success "checkout i=$ident attributes=$attr $aeol 
core.autocrlf=$crlf core.eol=$ceol file=CRLF" "
                compare_ws_file $pfx $crlfname  crlf_false_attr__CRLF.txt
        "
-       test_expect_success "checkout core.eol=$eol core.autocrlf=$crlf 
gitattributes=$attr file=CRLF_mix_LF" "
+       test_expect_success "checkout i=$ident attributes=$attr $aeol 
core.autocrlf=$crlf core.eol=$ceol file=CRLF_mix_LF" "
                compare_ws_file $pfx $lfmixcrlf crlf_false_attr__CRLF_mix_LF.txt
        "
-       test_expect_success "checkout core.eol=$eol core.autocrlf=$crlf 
gitattributes=$attr file=LF_mix_CR" "
+       test_expect_success "checkout i=$ident attributes=$attr $aeol 
core.autocrlf=$crlf core.eol=$ceol file=LF_mix_CR" "
                compare_ws_file $pfx $lfmixcr   crlf_false_attr__LF_mix_CR.txt
        "
-       test_expect_success "checkout core.eol=$eol core.autocrlf=$crlf 
gitattributes=$attr file=LF_nul" "
+       test_expect_success "checkout i=$ident attributes=$attr $aeol 
core.autocrlf=$crlf core.eol=$ceol file=LF_nul" "
                compare_ws_file $pfx $crlfnul   crlf_false_attr__LF_nul.txt
        "
 }
@@ -301,14 +316,13 @@ test_expect_success 'setup master' '
        git checkout -b master &&
        git add .gitattributes &&
        git commit -m "add .gitattributes" "" &&
-       printf "line1\nline2\nline3"     >LF &&
-       printf "line1\r\nline2\r\nline3" >CRLF &&
-       printf "line1\r\nline2\nline3"   >repoMIX &&
-       printf "line1\r\nline2\nline3"   >CRLF_mix_LF &&
-       printf "line1\nline2\rline3"     >LF_mix_CR &&
-       printf "line1\r\nline2\rline3"   >CRLF_mix_CR &&
-       printf "line1Q\r\nline2\r\nline3" | q_to_nul >CRLF_nul &&
-       printf "line1Q\nline2\nline3" | q_to_nul >LF_nul &&
+       printf "\$Id: 0000000000000000000000000000000000000000 
\$\nLINEONE\nLINETWO\nLINETHREE"     >LF &&
+       printf "\$Id: 0000000000000000000000000000000000000000 
\$\r\nLINEONE\r\nLINETWO\r\nLINETHREE" >CRLF &&
+       printf "\$Id: 0000000000000000000000000000000000000000 
\$\nLINEONE\r\nLINETWO\nLINETHREE"   >CRLF_mix_LF &&
+       printf "\$Id: 0000000000000000000000000000000000000000 
\$\nLINEONE\nLINETWO\rLINETHREE"     >LF_mix_CR &&
+       printf "\$Id: 0000000000000000000000000000000000000000 
\$\r\nLINEONE\r\nLINETWO\rLINETHREE"   >CRLF_mix_CR &&
+       printf "\$Id: 0000000000000000000000000000000000000000 
\$\r\nLINEONEQ\r\nLINETWO\r\nLINETHREE" | q_to_nul >CRLF_nul &&
+       printf "\$Id: 0000000000000000000000000000000000000000 
\$\nLINEONEQ\nLINETWO\nLINETHREE" | q_to_nul >LF_nul &&
        create_NNO_files CRLF_mix_LF CRLF_mix_LF CRLF_mix_LF CRLF_mix_LF 
CRLF_mix_LF &&
        git -c core.autocrlf=false add NNO_*.txt &&
        git commit -m "mixed line endings" &&
@@ -449,23 +463,18 @@ check_in_repo_NNO input "-text" LF        CRLF      
CRLF_mix_LF  LF_mix_CR        CRLF
 # How to read the table below:
 # - checkout_files will check multiple files with a combination of settings
 #   and attributes (core.autocrlf=input is forbidden with core.eol=crlf)
-# - parameter $1 : core.eol               lf | crlf
-# - parameter $2 : core.autocrlf          false | true | input
-# - parameter $3 : text in .gitattributs  "" (empty) | auto | text | -text
-# - parameter $4 : reference for a file with only LF in the repo
-# - parameter $5 : reference for a file with only CRLF in the repo
-# - parameter $6 : reference for a file with mixed LF and CRLF in the repo
-# - parameter $7 : reference for a file with LF and CR in the repo (does 
somebody uses this ?)
-# - parameter $8 : reference for a file with CRLF and a NUL (should be handled 
as binary when auto)
-
-#                                            What we have in the repo:
-#                                            ----------------- EOL in repo 
----------------
-#                                            LF    CRLF  CRLF_mix_LF  
LF_mix_CR    CRLF_nul
-#                   settings with checkout:
-#                   core.   core.   .gitattr
-#                    eol     acrlf
-#                                            
----------------------------------------------
-#                                            What we want to have in the 
working tree:
+#
+# - parameter $1       : text in .gitattributs  "" (empty) | auto | text | 
-text
+# - parameter $2       : ident                  "" | i (i == ident)
+# - parameter $3       : eol in .gitattributs   "" (empty) | lf | crlf
+# - parameter $4       : core.autocrlf          false | true | input
+# - parameter $5       : core.eol               "" | lf | crlf | "native"
+# - parameter $6       : reference for a file with only LF in the repo
+# - parameter $7       : reference for a file with only CRLF in the repo
+# - parameter $8       : reference for a file with mixed LF and CRLF in the 
repo
+# - parameter $9       : reference for a file with LF and CR in the repo
+# - parameter $10 : reference for a file with CRLF and a NUL (should be 
handled as binary when auto)
+
 if test_have_prereq NATIVE_CRLF
 then
 MIX_CRLF_LF=CRLF
@@ -480,69 +489,90 @@ LFNUL=LF_nul
 fi
 export CRLF_MIX_LF_CR MIX NL
 
-checkout_files    lf      false  ""       LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    lf      true   ""       CRLF  CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    lf      input  ""       LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    lf      false "auto"    LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    lf      true  "auto"    CRLF  CRLF  CRLF         LF_mix_CR   
 LF_nul
-checkout_files    lf      input "auto"    LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    lf      false "text"    LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    lf      true  "text"    CRLF  CRLF  CRLF         CRLF_mix_CR 
 CRLF_nul
-checkout_files    lf      input "text"    LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    lf      false "-text"   LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    lf      true  "-text"   LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    lf      input "-text"   LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    lf      false "lf"      LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    lf      true  "lf"      LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    lf      input "lf"      LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    lf      false "crlf"    CRLF  CRLF  CRLF         CRLF_mix_CR 
 CRLF_nul
-checkout_files    lf      true  "crlf"    CRLF  CRLF  CRLF         CRLF_mix_CR 
 CRLF_nul
-checkout_files    lf      input "crlf"    CRLF  CRLF  CRLF         CRLF_mix_CR 
 CRLF_nul
-
-checkout_files    crlf    false  ""       LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    crlf    true   ""       CRLF  CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    crlf    false "auto"    CRLF  CRLF  CRLF         LF_mix_CR   
 LF_nul
-checkout_files    crlf    true  "auto"    CRLF  CRLF  CRLF         LF_mix_CR   
 LF_nul
-checkout_files    crlf    false "text"    CRLF  CRLF  CRLF         CRLF_mix_CR 
 CRLF_nul
-checkout_files    crlf    true  "text"    CRLF  CRLF  CRLF         CRLF_mix_CR 
 CRLF_nul
-checkout_files    crlf    false "-text"   LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    crlf    true  "-text"   LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    crlf    false "lf"      LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    crlf    true  "lf"      LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    crlf    false "crlf"    CRLF  CRLF  CRLF         CRLF_mix_CR 
 CRLF_nul
-checkout_files    crlf    true  "crlf"    CRLF  CRLF  CRLF         CRLF_mix_CR 
 CRLF_nul
-
-checkout_files    ""      false  ""       LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    ""      true   ""       CRLF  CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    ""      input  ""       LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    ""      false "auto"    $NL   CRLF  $MIX_CRLF_LF LF_mix_CR   
 LF_nul
-checkout_files    ""      true  "auto"    CRLF  CRLF  CRLF         LF_mix_CR   
 LF_nul
-checkout_files    ""      input "auto"    LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    ""      false "text"    $NL   CRLF  $MIX_CRLF_LF $MIX_LF_CR  
 $LFNUL
-checkout_files    ""      true  "text"    CRLF  CRLF  CRLF         CRLF_mix_CR 
 CRLF_nul
-checkout_files    ""      input "text"    LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    ""      false "-text"   LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    ""      true  "-text"   LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    ""      input "-text"   LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    ""      false "lf"      LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    ""      true  "lf"      LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    ""      input "lf"      LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    ""      false "crlf"    CRLF  CRLF  CRLF         CRLF_mix_CR 
 CRLF_nul
-checkout_files    ""      true  "crlf"    CRLF  CRLF  CRLF         CRLF_mix_CR 
 CRLF_nul
-checkout_files    ""      input "crlf"    CRLF  CRLF  CRLF         CRLF_mix_CR 
 CRLF_nul
-
-checkout_files    native  false  ""       LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    native  true   ""       CRLF  CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    native  false "auto"    $NL   CRLF  $MIX_CRLF_LF LF_mix_CR   
 LF_nul
-checkout_files    native  true  "auto"    CRLF  CRLF  CRLF         LF_mix_CR   
 LF_nul
-checkout_files    native  false "text"    $NL   CRLF  $MIX_CRLF_LF $MIX_LF_CR  
 $LFNUL
-checkout_files    native  true  "text"    CRLF  CRLF  CRLF         CRLF_mix_CR 
 CRLF_nul
-checkout_files    native  false "-text"   LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    native  true  "-text"   LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    native  false "lf"      LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    native  true  "lf"      LF    CRLF  CRLF_mix_LF  LF_mix_CR   
 LF_nul
-checkout_files    native  false "crlf"    CRLF  CRLF  CRLF         CRLF_mix_CR 
 CRLF_nul
-checkout_files    native  true  "crlf"    CRLF  CRLF  CRLF         CRLF_mix_CR 
 CRLF_nul
+checkout_files ""      "" ""    false  ""       LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files ""      "" ""    false  crlf     LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files ""      "" ""    false  lf       LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files ""      "" ""    false  native   LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files ""      "" ""    input  ""       LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files ""      "" ""    input  lf       LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files ""      "" ""    true   ""       CRLF  CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files ""      "" ""    true   crlf     CRLF  CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files ""      "" ""    true   lf       CRLF  CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files ""      "" ""    true   native   CRLF  CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files ""      i  ""    false  ""       LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files ""      i  ""    false  crlf     LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files ""      i  ""    false  lf       LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files ""      i  ""    false  native   LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files ""      i  ""    input  ""       LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files ""      i  ""    input  lf       LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files ""      i  ""    true   ""       LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files ""      i  ""    true   crlf     LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files ""      i  ""    true   lf       LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files ""      i  ""    true   native   LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files "auto"  "" ""    false  ""       $NL   CRLF  $MIX_CRLF_LF 
LF_mix_CR    LF_nul
+checkout_files "auto"  "" ""    false  crlf     CRLF  CRLF  CRLF         
LF_mix_CR    LF_nul
+checkout_files "auto"  "" ""    false  lf       LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files "auto"  "" ""    false  native   $NL   CRLF  $MIX_CRLF_LF 
LF_mix_CR    LF_nul
+checkout_files "auto"  "" ""    input  ""       LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files "auto"  "" ""    input  lf       LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files "auto"  "" ""    true   ""       CRLF  CRLF  CRLF         
LF_mix_CR    LF_nul
+checkout_files "auto"  "" ""    true   crlf     CRLF  CRLF  CRLF         
LF_mix_CR    LF_nul
+checkout_files "auto"  "" ""    true   lf       CRLF  CRLF  CRLF         
LF_mix_CR    LF_nul
+checkout_files "auto"  "" ""    true   native   CRLF  CRLF  CRLF         
LF_mix_CR    LF_nul
+checkout_files "auto"  i  ""    false  ""       $NL   CRLF  $MIX_CRLF_LF 
LF_mix_CR    LF_nul
+checkout_files "auto"  i  ""    false  crlf     LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files "auto"  i  ""    false  lf       LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files "auto"  i  ""    false  native   $NL   CRLF  $MIX_CRLF_LF 
LF_mix_CR    LF_nul
+checkout_files "auto"  i  ""    input  ""       LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files "auto"  i  ""    input  lf       LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files "auto"  i  ""    true   ""       LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files "auto"  i  ""    true   crlf     LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files "auto"  i  ""    true   lf       LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+checkout_files "auto"  i  ""    true   native   LF    CRLF  CRLF_mix_LF  
LF_mix_CR    LF_nul
+
+for id in "" i;
+do
+       checkout_files "crlf"  "$id" ""    false  ""       CRLF  CRLF  CRLF     
    CRLF_mix_CR  CRLF_nul
+       checkout_files "crlf"  "$id" ""    false  crlf     CRLF  CRLF  CRLF     
    CRLF_mix_CR  CRLF_nul
+       checkout_files "crlf"  "$id" ""    false  lf       CRLF  CRLF  CRLF     
    CRLF_mix_CR  CRLF_nul
+       checkout_files "crlf"  "$id" ""    false  native   CRLF  CRLF  CRLF     
    CRLF_mix_CR  CRLF_nul
+       checkout_files "crlf"  "$id" ""    input  ""       CRLF  CRLF  CRLF     
    CRLF_mix_CR  CRLF_nul
+       checkout_files "crlf"  "$id" ""    input  lf       CRLF  CRLF  CRLF     
    CRLF_mix_CR  CRLF_nul
+       checkout_files "crlf"  "$id" ""    true   ""       CRLF  CRLF  CRLF     
    CRLF_mix_CR  CRLF_nul
+       checkout_files "crlf"  "$id" ""    true   crlf     CRLF  CRLF  CRLF     
    CRLF_mix_CR  CRLF_nul
+       checkout_files "crlf"  "$id" ""    true   lf       CRLF  CRLF  CRLF     
    CRLF_mix_CR  CRLF_nul
+       checkout_files "crlf"  "$id" ""    true   native   CRLF  CRLF  CRLF     
    CRLF_mix_CR  CRLF_nul
+       checkout_files "lf"    "$id" ""    false  ""       LF    CRLF  
CRLF_mix_LF  LF_mix_CR    LF_nul
+       checkout_files "lf"    "$id" ""    false  crlf     LF    CRLF  
CRLF_mix_LF  LF_mix_CR    LF_nul
+       checkout_files "lf"    "$id" ""    false  lf       LF    CRLF  
CRLF_mix_LF  LF_mix_CR    LF_nul
+       checkout_files "lf"    "$id" ""    false  native   LF    CRLF  
CRLF_mix_LF  LF_mix_CR    LF_nul
+       checkout_files "lf"    "$id" ""    input  ""       LF    CRLF  
CRLF_mix_LF  LF_mix_CR    LF_nul
+       checkout_files "lf"    "$id" ""    input  lf       LF    CRLF  
CRLF_mix_LF  LF_mix_CR    LF_nul
+       checkout_files "lf"    "$id" ""    true   ""       LF    CRLF  
CRLF_mix_LF  LF_mix_CR    LF_nul
+       checkout_files "lf"    "$id" ""    true   crlf     LF    CRLF  
CRLF_mix_LF  LF_mix_CR    LF_nul
+       checkout_files "lf"    "$id" ""    true   lf       LF    CRLF  
CRLF_mix_LF  LF_mix_CR    LF_nul
+       checkout_files "lf"    "$id" ""    true   native   LF    CRLF  
CRLF_mix_LF  LF_mix_CR    LF_nul
+       checkout_files "text"  "$id" ""    false  ""       $NL   CRLF  
$MIX_CRLF_LF $MIX_LF_CR   $LFNUL
+       checkout_files "text"  "$id" ""    false  crlf     CRLF  CRLF  CRLF     
    CRLF_mix_CR  CRLF_nul
+       checkout_files "text"  "$id" ""    false  lf       LF    CRLF  
CRLF_mix_LF  LF_mix_CR    LF_nul
+       checkout_files "text"  "$id" ""    false  native   $NL   CRLF  
$MIX_CRLF_LF $MIX_LF_CR   $LFNUL
+       checkout_files "text"  "$id" ""    input  ""       LF    CRLF  
CRLF_mix_LF  LF_mix_CR    LF_nul
+       checkout_files "text"  "$id" ""    input  lf       LF    CRLF  
CRLF_mix_LF  LF_mix_CR    LF_nul
+       checkout_files "text"  "$id" ""    true   ""       CRLF  CRLF  CRLF     
    CRLF_mix_CR  CRLF_nul
+       checkout_files "text"  "$id" ""    true   crlf     CRLF  CRLF  CRLF     
    CRLF_mix_CR  CRLF_nul
+       checkout_files "text"  "$id" ""    true   lf       CRLF  CRLF  CRLF     
    CRLF_mix_CR  CRLF_nul
+       checkout_files "text"  "$id" ""    true   native   CRLF  CRLF  CRLF     
    CRLF_mix_CR  CRLF_nul
+       checkout_files "-text" "$id" ""    false  ""       LF    CRLF  
CRLF_mix_LF  LF_mix_CR    LF_nul
+       checkout_files "-text" "$id" ""    false  crlf     LF    CRLF  
CRLF_mix_LF  LF_mix_CR    LF_nul
+       checkout_files "-text" "$id" ""    false  lf       LF    CRLF  
CRLF_mix_LF  LF_mix_CR    LF_nul
+       checkout_files "-text" "$id" ""    false  native   LF    CRLF  
CRLF_mix_LF  LF_mix_CR    LF_nul
+       checkout_files "-text" "$id" ""    input  ""       LF    CRLF  
CRLF_mix_LF  LF_mix_CR    LF_nul
+       checkout_files "-text" "$id" ""    input  lf       LF    CRLF  
CRLF_mix_LF  LF_mix_CR    LF_nul
+       checkout_files "-text" "$id" ""    true   ""       LF    CRLF  
CRLF_mix_LF  LF_mix_CR    LF_nul
+       checkout_files "-text" "$id" ""    true   crlf     LF    CRLF  
CRLF_mix_LF  LF_mix_CR    LF_nul
+       checkout_files "-text" "$id" ""    true   lf       LF    CRLF  
CRLF_mix_LF  LF_mix_CR    LF_nul
+       checkout_files "-text" "$id" ""    true   native   LF    CRLF  
CRLF_mix_LF  LF_mix_CR    LF_nul
+done
 
 # Should be the last test case: remove some files from the worktree
 test_expect_success 'ls-files --eol -d -z' '
-- 
2.7.0.303.g2c4f448.dirty

--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to