(CommandList
  children: [
    (Assignment
      keyword: Assign_None
      pairs: [
        (assign_pair
          lhs: (LhsName name:test_description)
          op: Equal
          rhs: 
            {
              (SQ <'Pathspec restrictions\n'> <'\n'> <'Prepare:\n'> <'        file0\n'> 
                <'        path1/file1\n'>
              )
            }
          spids: [13]
        )
      ]
      spids: [13]
    )
    (C {(.)} {(./test-lib.sh)})
    (Sentence
      child: (C {(.)} {(DQ ($ VSub_Name '$TEST_DIRECTORY')) (/diff-lib.sh)})
      terminator: <Op_Semi ';'>
    )
    (C {(test_expect_success)} {(setup)} 
      {
        (SQ <'echo frotz >file0 &&\n'> <'     mkdir path1 &&\n'> <'     echo rezrov >path1/file1 &&\n'> 
          <'     git update-index --add file0 path1/file1 &&\n'> <'     tree=$(git write-tree) &&\n'> <'     echo "$tree" &&\n'> <'     echo nitfol >file0 &&\n'> 
          <'     echo yomin >path1/file1 &&\n'> <'     git update-index file0 path1/file1'>
        )
      }
    )
    (SimpleCommand
      words: [{(cat)}]
      redirects: [
        (Redir op_id:Redir_Great fd:16777215 arg_word:{(expected)} spids:[61])
        (HereDoc
          op_id: Redir_DLess
          fd: 16777215
          body: {}
          do_expansion: False
          here_end: EOF
          was_filled: True
          spids: [64]
        )
      ]
    )
    (C {(test_expect_success)} {(SQ <'limit to path should show nothing'>)} 
      {
        (SQ <'git diff-index --cached $tree -- path >current &&\n'> 
          <'     compare_diff_raw current expected'>
        )
      }
    )
    (SimpleCommand
      words: [{(cat)}]
      redirects: [
        (Redir op_id:Redir_Great fd:16777215 arg_word:{(expected)} spids:[86])
        (HereDoc
          op_id: Redir_DLess
          fd: 16777215
          body: 
            {
              (
':100644 100644 766498d93a4b06057a8e49d23f4068f1170ff38f 0a41e115ab61be0328a19b29f18cdcb49338d516 M\tpath1/file1\n'
              )
            }
          do_expansion: False
          here_end: EOF
          was_filled: True
          spids: [89]
        )
      ]
    )
    (C {(test_expect_success)} {(SQ <'limit to path1 should show path1/file1'>)} 
      {
        (SQ <'git diff-index --cached $tree -- path1 >current &&\n'> 
          <'     compare_diff_raw current expected'>
        )
      }
    )
    (SimpleCommand
      words: [{(cat)}]
      redirects: [
        (Redir op_id:Redir_Great fd:16777215 arg_word:{(expected)} spids:[111])
        (HereDoc
          op_id: Redir_DLess
          fd: 16777215
          body: 
            {
              (
':100644 100644 766498d93a4b06057a8e49d23f4068f1170ff38f 0a41e115ab61be0328a19b29f18cdcb49338d516 M\tpath1/file1\n'
              )
            }
          do_expansion: False
          here_end: EOF
          was_filled: True
          spids: [114]
        )
      ]
    )
    (C {(test_expect_success)} {(SQ <'limit to path1/ should show path1/file1'>)} 
      {
        (SQ <'git diff-index --cached $tree -- path1/ >current &&\n'> 
          <'     compare_diff_raw current expected'>
        )
      }
    )
    (SimpleCommand
      words: [{(cat)}]
      redirects: [
        (Redir op_id:Redir_Great fd:16777215 arg_word:{(expected)} spids:[136])
        (HereDoc
          op_id: Redir_DLess
          fd: 16777215
          body: 
            {
              (
':100644 100644 766498d93a4b06057a8e49d23f4068f1170ff38f 0a41e115ab61be0328a19b29f18cdcb49338d516 M\tpath1/file1\n'
              )
            }
          do_expansion: False
          here_end: EOF
          was_filled: True
          spids: [139]
        )
      ]
    )
    (C {(test_expect_success)} {(SQ <'"*file1" should show path1/file1'>)} 
      {
        (SQ <'git diff-index --cached $tree -- "*file1" >current &&\n'> 
          <'     compare_diff_raw current expected'>
        )
      }
    )
    (SimpleCommand
      words: [{(cat)}]
      redirects: [
        (Redir op_id:Redir_Great fd:16777215 arg_word:{(expected)} spids:[161])
        (HereDoc
          op_id: Redir_DLess
          fd: 16777215
          body: 
            {
              (
':100644 100644 8e4020bb5a8d8c873b25de15933e75cc0fc275df dca6b92303befc93086aa025d90a5facd7eb2812 M\tfile0\n'
              )
            }
          do_expansion: False
          here_end: EOF
          was_filled: True
          spids: [164]
        )
      ]
    )
    (C {(test_expect_success)} {(SQ <'limit to file0 should show file0'>)} 
      {
        (SQ <'git diff-index --cached $tree -- file0 >current &&\n'> 
          <'     compare_diff_raw current expected'>
        )
      }
    )
    (SimpleCommand
      words: [{(cat)}]
      redirects: [
        (Redir op_id:Redir_Great fd:16777215 arg_word:{(expected)} spids:[186])
        (HereDoc
          op_id: Redir_DLess
          fd: 16777215
          body: {}
          do_expansion: False
          here_end: EOF
          was_filled: True
          spids: [189]
        )
      ]
    )
    (C {(test_expect_success)} {(SQ <'limit to file0/ should emit nothing.'>)} 
      {
        (SQ <'git diff-index --cached $tree -- file0/ >current &&\n'> 
          <'     compare_diff_raw current expected'>
        )
      }
    )
    (C {(test_expect_success)} {(SQ <'diff-tree pathspec'>)} 
      {
        (SQ <'\n'> <'\ttree2=$(git write-tree) &&\n'> <'\techo "$tree2" &&\n'> 
          <'\tgit diff-tree -r --name-only $tree $tree2 -- pa path1/a >current &&\n'> <'\t>expected &&\n'> <'\ttest_cmp expected current\n'>
        )
      }
    )
    (C {(test_expect_success)} {(SQ <'diff-tree with wildcard shows dir also matches'>)} 
      {
        (SQ <'\n'> <'\tgit diff-tree --name-only $EMPTY_TREE $tree -- "f*" >result &&\n'> 
          <'\techo file0 >expected &&\n'> <'\ttest_cmp expected result\n'>
        )
      }
    )
    (C {(test_expect_success)} {(SQ <'diff-tree -r with wildcard'>)} 
      {
        (SQ <'\n'> <'\tgit diff-tree -r --name-only $EMPTY_TREE $tree -- "*file1" >result &&\n'> 
          <'\techo path1/file1 >expected &&\n'> <'\ttest_cmp expected result\n'>
        )
      }
    )
    (C {(test_expect_success)} {(SQ <'diff-tree with wildcard shows dir also matches'>)} 
      {
        (SQ <'\n'> <'\tgit diff-tree --name-only $tree $tree2 -- "path1/f*" >result &&\n'> 
          <'\techo path1 >expected &&\n'> <'\ttest_cmp expected result\n'>
        )
      }
    )
    (C {(test_expect_success)} {(SQ <'diff-tree -r with wildcard from beginning'>)} 
      {
        (SQ <'\n'> <'\tgit diff-tree -r --name-only $tree $tree2 -- "path1/*file1" >result &&\n'> 
          <'\techo path1/file1 >expected &&\n'> <'\ttest_cmp expected result\n'>
        )
      }
    )
    (C {(test_expect_success)} {(SQ <'diff-tree -r with wildcard'>)} 
      {
        (SQ <'\n'> <'\tgit diff-tree -r --name-only $tree $tree2 -- "path1/f*" >result &&\n'> 
          <'\techo path1/file1 >expected &&\n'> <'\ttest_cmp expected result\n'>
        )
      }
    )
    (C {(test_expect_success)} {(SQ <'setup submodules'>)} 
      {
        (SQ <'\n'> <'\ttest_tick &&\n'> <'\tgit init submod &&\n'> 
          <'\t( cd submod && test_commit first; ) &&\n'> <'\tgit add submod &&\n'> <'\tgit commit -m first &&\n'> 
          <'\t( cd submod && test_commit second; ) &&\n'> <'\tgit add submod &&\n'> <'\tgit commit -m second\n'>
        )
      }
    )
    (C {(test_expect_success)} {(SQ <'diff-tree ignores trailing slash on submodule path'>)} 
      {
        (SQ <'\n'> <'\tgit diff --name-only HEAD^ HEAD submod >expect &&\n'> 
          <'\tgit diff --name-only HEAD^ HEAD submod/ >actual &&\n'> <'\ttest_cmp expect actual\n'>
        )
      }
    )
    (C {(test_expect_success)} {(SQ <'diff multiple wildcard pathspecs'>)} 
      {
        (SQ <'\n'> <'\tmkdir path2 &&\n'> <'\techo rezrov >path2/file1 &&\n'> 
          <'\tgit update-index --add path2/file1 &&\n'> <'\ttree3=$(git write-tree) &&\n'> 
          <'\tgit diff --name-only $tree $tree3 -- "path2*1" "path1*1" >actual &&\n'> <'\tcat <<-\\EOF >expect &&\n'> <'\tpath1/file1\n'> <'\tpath2/file1\n'> <'\tEOF\n'> 
          <'\ttest_cmp expect actual\n'>
        )
      }
    )
    (C {(test_expect_success)} {(SQ <'diff-cache ignores trailing slash on submodule path'>)} 
      {
        (SQ <'\n'> <'\tgit diff --name-only HEAD^ submod >expect &&\n'> 
          <'\tgit diff --name-only HEAD^ submod/ >actual &&\n'> <'\ttest_cmp expect actual\n'>
        )
      }
    )
    (C {(test_done)})
  ]
)