(CommandList
  children: [
    (Assignment
      keyword: Assign_None
      pairs: [
        (assign_pair
          lhs: (LhsName name:test_description)
          op: Equal
          rhs: {(SQ <"difference in submodules">)}
          spids: [4]
        )
      ]
      spids: [4]
    )
    (C {(.)} {(./test-lib.sh)})
    (C {(.)} {(DQ ($ VSub_Name "$TEST_DIRECTORY")) (/diff-lib.sh)})
    (C {(test_expect_success)} {(setup)} 
      {
        (SQ <"\n"> <"\ttest_tick &&\n"> <"\ttest_create_repo sub &&\n"> <"\t(\n"> <"\t\tcd sub &&\n"> 
          <"\t\techo hello >world &&\n"> <"\t\tgit add world &&\n"> <"\t\tgit commit -m submodule\n"> <"\t) &&\n"> <"\n"> <"\ttest_tick &&\n"> 
          <"\techo frotz >nitfol &&\n"> <"\tgit add nitfol sub &&\n"> <"\tgit commit -m superproject &&\n"> <"\n"> <"\t(\n"> <"\t\tcd sub &&\n"> 
          <"\t\techo goodbye >world &&\n"> <"\t\tgit add world &&\n"> <"\t\tgit commit -m \"submodule #2\"\n"> <"\t) &&\n"> <"\n"> <"\tset x $(\n"> 
          <"\t\tcd sub &&\n"> <"\t\tgit rev-list HEAD\n"> <"\t) &&\n"> <"\techo \":160000 160000 $3 $_z40 M\tsub\" >expect &&\n"> 
          <"\tsubtip=$3 subprev=$2\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"git diff --raw HEAD">)} 
      {(SQ <"\n"> <"\tgit diff --raw --abbrev=40 HEAD >actual &&\n"> <"\ttest_cmp expect actual\n">)}
    )
    (C {(test_expect_success)} {(SQ <"git diff-index --raw HEAD">)} 
      {
        (SQ <"\n"> <"\tgit diff-index --raw HEAD >actual.index &&\n"> 
          <"\ttest_cmp expect actual.index\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"git diff-files --raw">)} 
      {
        (SQ <"\n"> <"\tgit diff-files --raw >actual.files &&\n"> <"\ttest_cmp expect actual.files\n">)
      }
    )
    (FuncDef
      name: expect_from_to
      body: 
        (BraceGroup
          children: [
            (C {(printf)} 
              {
                (DQ ("%sSubproject commit %s") (EscapedLiteralPart token:<Lit_EscapedChar "\\n">) 
                  ("+Subproject commit %s") (EscapedLiteralPart token:<Lit_EscapedChar "\\n">)
                )
              } {(DQ (-))} {(DQ ($ VSub_Number "$1"))} {(DQ ($ VSub_Number "$2"))}
            )
          ]
          spids: [102]
        )
      spids: [97 101]
    )
    (C {(test_expect_success)} {(SQ <"git diff HEAD">)} 
      {
        (SQ <"\n"> <"\tgit diff HEAD >actual &&\n"> <"\tsed -e \"1,/^@@/d\" actual >actual.body &&\n"> 
          <"\texpect_from_to >expect.body $subtip $subprev &&\n"> <"\ttest_cmp expect.body actual.body\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"git diff HEAD with dirty submodule (work tree)">)} 
      {
        (SQ <"\n"> <"\techo >>sub/world &&\n"> <"\tgit diff HEAD >actual &&\n"> 
          <"\tsed -e \"1,/^@@/d\" actual >actual.body &&\n"> <"\texpect_from_to >expect.body $subtip $subprev-dirty &&\n"> <"\ttest_cmp expect.body actual.body\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"git diff HEAD with dirty submodule (index)">)} 
      {
        (SQ <"\n"> <"\t(\n"> <"\t\tcd sub &&\n"> <"\t\tgit reset --hard &&\n"> <"\t\techo >>world &&\n"> 
          <"\t\tgit add world\n"> <"\t) &&\n"> <"\tgit diff HEAD >actual &&\n"> <"\tsed -e \"1,/^@@/d\" actual >actual.body &&\n"> 
          <"\texpect_from_to >expect.body $subtip $subprev-dirty &&\n"> <"\ttest_cmp expect.body actual.body\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"git diff HEAD with dirty submodule (untracked)">)} 
      {
        (SQ <"\n"> <"\t(\n"> <"\t\tcd sub &&\n"> <"\t\tgit reset --hard &&\n"> 
          <"\t\tgit clean -qfdx &&\n"> <"\t\t>cruft\n"> <"\t) &&\n"> <"\tgit diff HEAD >actual &&\n"> 
          <"\tsed -e \"1,/^@@/d\" actual >actual.body &&\n"> <"\texpect_from_to >expect.body $subtip $subprev-dirty &&\n"> <"\ttest_cmp expect.body actual.body\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"git diff HEAD with dirty submodule (work tree, refs match)">)} 
      {
        (SQ <"\n"> <"\tgit commit -m \"x\" sub &&\n"> <"\techo >>sub/world &&\n"> 
          <"\tgit diff HEAD >actual &&\n"> <"\tsed -e \"1,/^@@/d\" actual >actual.body &&\n"> 
          <"\texpect_from_to >expect.body $subprev $subprev-dirty &&\n"> <"\ttest_cmp expect.body actual.body &&\n"> <"\tgit diff --ignore-submodules HEAD >actual2 &&\n"> 
          <"\t! test -s actual2 &&\n"> <"\tgit diff --ignore-submodules=untracked HEAD >actual3 &&\n"> 
          <"\tsed -e \"1,/^@@/d\" actual3 >actual3.body &&\n"> <"\texpect_from_to >expect.body $subprev $subprev-dirty &&\n"> 
          <"\ttest_cmp expect.body actual3.body &&\n"> <"\tgit diff --ignore-submodules=dirty HEAD >actual4 &&\n"> <"\t! test -s actual4\n">
        )
      }
    )
    (C {(test_expect_success)} 
      {(SQ <"git diff HEAD with dirty submodule (work tree, refs match) [.git/config]">)} 
      {
        (SQ <"\n"> <"\tgit config diff.ignoreSubmodules all &&\n"> <"\tgit diff HEAD >actual &&\n"> 
          <"\t! test -s actual &&\n"> <"\tgit config submodule.subname.ignore none &&\n"> <"\tgit config submodule.subname.path sub &&\n"> 
          <"\tgit diff HEAD >actual &&\n"> <"\tsed -e \"1,/^@@/d\" actual >actual.body &&\n"> 
          <"\texpect_from_to >expect.body $subprev $subprev-dirty &&\n"> <"\ttest_cmp expect.body actual.body &&\n"> <"\tgit config submodule.subname.ignore all &&\n"> 
          <"\tgit diff HEAD >actual2 &&\n"> <"\t! test -s actual2 &&\n"> <"\tgit config submodule.subname.ignore untracked &&\n"> 
          <"\tgit diff HEAD >actual3 &&\n"> <"\tsed -e \"1,/^@@/d\" actual3 >actual3.body &&\n"> 
          <"\texpect_from_to >expect.body $subprev $subprev-dirty &&\n"> <"\ttest_cmp expect.body actual3.body &&\n"> <"\tgit config submodule.subname.ignore dirty &&\n"> 
          <"\tgit diff HEAD >actual4 &&\n"> <"\t! test -s actual4 &&\n"> <"\tgit diff HEAD --ignore-submodules=none >actual &&\n"> 
          <"\tsed -e \"1,/^@@/d\" actual >actual.body &&\n"> <"\texpect_from_to >expect.body $subprev $subprev-dirty &&\n"> 
          <"\ttest_cmp expect.body actual.body &&\n"> <"\tgit config --remove-section submodule.subname &&\n"> 
          <"\tgit config --unset diff.ignoreSubmodules\n">
        )
      }
    )
    (C {(test_expect_success)} 
      {(SQ <"git diff HEAD with dirty submodule (work tree, refs match) [.gitmodules]">)} 
      {
        (SQ <"\n"> <"\tgit config diff.ignoreSubmodules dirty &&\n"> <"\tgit diff HEAD >actual &&\n"> 
          <"\t! test -s actual &&\n"> <"\tgit config --add -f .gitmodules submodule.subname.ignore none &&\n"> 
          <"\tgit config --add -f .gitmodules submodule.subname.path sub &&\n"> <"\tgit diff HEAD >actual &&\n"> <"\tsed -e \"1,/^@@/d\" actual >actual.body &&\n"> 
          <"\texpect_from_to >expect.body $subprev $subprev-dirty &&\n"> <"\ttest_cmp expect.body actual.body &&\n"> 
          <"\tgit config -f .gitmodules submodule.subname.ignore all &&\n"> <"\tgit config -f .gitmodules submodule.subname.path sub &&\n"> <"\tgit diff HEAD >actual2 &&\n"> 
          <"\t! test -s actual2 &&\n"> <"\tgit config -f .gitmodules submodule.subname.ignore untracked &&\n"> 
          <"\tgit diff HEAD >actual3 &&\n"> <"\tsed -e \"1,/^@@/d\" actual3 >actual3.body &&\n"> 
          <"\texpect_from_to >expect.body $subprev $subprev-dirty &&\n"> <"\ttest_cmp expect.body actual3.body &&\n"> 
          <"\tgit config -f .gitmodules submodule.subname.ignore dirty &&\n"> <"\tgit diff HEAD >actual4 &&\n"> <"\t! test -s actual4 &&\n"> 
          <"\tgit config submodule.subname.ignore none &&\n"> <"\tgit config submodule.subname.path sub &&\n"> <"\tgit diff HEAD >actual &&\n"> 
          <"\tsed -e \"1,/^@@/d\" actual >actual.body &&\n"> <"\texpect_from_to >expect.body $subprev $subprev-dirty &&\n"> 
          <"\ttest_cmp expect.body actual.body &&\n"> <"\tgit config --remove-section submodule.subname &&\n"> 
          <"\tgit config --remove-section -f .gitmodules submodule.subname &&\n"> <"\tgit config --unset diff.ignoreSubmodules &&\n"> <"\trm .gitmodules\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"git diff HEAD with dirty submodule (index, refs match)">)} 
      {
        (SQ <"\n"> <"\t(\n"> <"\t\tcd sub &&\n"> <"\t\tgit reset --hard &&\n"> <"\t\techo >>world &&\n"> 
          <"\t\tgit add world\n"> <"\t) &&\n"> <"\tgit diff HEAD >actual &&\n"> <"\tsed -e \"1,/^@@/d\" actual >actual.body &&\n"> 
          <"\texpect_from_to >expect.body $subprev $subprev-dirty &&\n"> <"\ttest_cmp expect.body actual.body\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"git diff HEAD with dirty submodule (untracked, refs match)">)} 
      {
        (SQ <"\n"> <"\t(\n"> <"\t\tcd sub &&\n"> <"\t\tgit reset --hard &&\n"> 
          <"\t\tgit clean -qfdx &&\n"> <"\t\t>cruft\n"> <"\t) &&\n"> <"\tgit diff HEAD >actual &&\n"> 
          <"\tsed -e \"1,/^@@/d\" actual >actual.body &&\n"> <"\texpect_from_to >expect.body $subprev $subprev-dirty &&\n"> 
          <"\ttest_cmp expect.body actual.body &&\n"> <"\tgit diff --ignore-submodules=all HEAD >actual2 &&\n"> <"\t! test -s actual2 &&\n"> 
          <"\tgit diff --ignore-submodules=untracked HEAD >actual3 &&\n"> <"\t! test -s actual3 &&\n"> <"\tgit diff --ignore-submodules=dirty HEAD >actual4 &&\n"> 
          <"\t! test -s actual4\n">
        )
      }
    )
    (C {(test_expect_success)} 
      {(SQ <"git diff HEAD with dirty submodule (untracked, refs match) [.git/config]">)} 
      {
        (SQ <"\n"> <"\tgit config submodule.subname.ignore all &&\n"> 
          <"\tgit config submodule.subname.path sub &&\n"> <"\tgit diff HEAD >actual2 &&\n"> <"\t! test -s actual2 &&\n"> 
          <"\tgit config submodule.subname.ignore untracked &&\n"> <"\tgit diff HEAD >actual3 &&\n"> <"\t! test -s actual3 &&\n"> 
          <"\tgit config submodule.subname.ignore dirty &&\n"> <"\tgit diff HEAD >actual4 &&\n"> <"\t! test -s actual4 &&\n"> 
          <"\tgit diff --ignore-submodules=none HEAD >actual &&\n"> <"\tsed -e \"1,/^@@/d\" actual >actual.body &&\n"> 
          <"\texpect_from_to >expect.body $subprev $subprev-dirty &&\n"> <"\ttest_cmp expect.body actual.body &&\n"> <"\tgit config --remove-section submodule.subname\n">
        )
      }
    )
    (C {(test_expect_success)} 
      {(SQ <"git diff HEAD with dirty submodule (untracked, refs match) [.gitmodules]">)} 
      {
        (SQ <"\n"> <"\tgit config --add -f .gitmodules submodule.subname.ignore all &&\n"> 
          <"\tgit config --add -f .gitmodules submodule.subname.path sub &&\n"> <"\tgit diff HEAD >actual2 &&\n"> <"\t! test -s actual2 &&\n"> 
          <"\tgit config -f .gitmodules submodule.subname.ignore untracked &&\n"> <"\tgit diff HEAD >actual3 &&\n"> <"\t! test -s actual3 &&\n"> 
          <"\tgit config -f .gitmodules submodule.subname.ignore dirty &&\n"> <"\tgit diff HEAD >actual4 &&\n"> <"\t! test -s actual4 &&\n"> 
          <"\tgit config submodule.subname.ignore none &&\n"> <"\tgit config submodule.subname.path sub &&\n"> <"\tgit diff HEAD >actual &&\n"> 
          <"\tsed -e \"1,/^@@/d\" actual >actual.body &&\n"> <"\texpect_from_to >expect.body $subprev $subprev-dirty &&\n"> 
          <"\ttest_cmp expect.body actual.body &&\n"> <"\tgit config --remove-section submodule.subname &&\n"> 
          <"\tgit config --remove-section -f .gitmodules submodule.subname &&\n"> <"\trm .gitmodules\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"git diff between submodule commits">)} 
      {
        (SQ <"\n"> <"\tgit diff HEAD^..HEAD >actual &&\n"> 
          <"\tsed -e \"1,/^@@/d\" actual >actual.body &&\n"> <"\texpect_from_to >expect.body $subtip $subprev &&\n"> <"\ttest_cmp expect.body actual.body &&\n"> 
          <"\tgit diff --ignore-submodules=dirty HEAD^..HEAD >actual &&\n"> <"\tsed -e \"1,/^@@/d\" actual >actual.body &&\n"> 
          <"\texpect_from_to >expect.body $subtip $subprev &&\n"> <"\ttest_cmp expect.body actual.body &&\n"> 
          <"\tgit diff --ignore-submodules HEAD^..HEAD >actual &&\n"> <"\t! test -s actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"git diff between submodule commits [.git/config]">)} 
      {
        (SQ <"\n"> <"\tgit diff HEAD^..HEAD >actual &&\n"> 
          <"\tsed -e \"1,/^@@/d\" actual >actual.body &&\n"> <"\texpect_from_to >expect.body $subtip $subprev &&\n"> <"\ttest_cmp expect.body actual.body &&\n"> 
          <"\tgit config submodule.subname.ignore dirty &&\n"> <"\tgit config submodule.subname.path sub &&\n"> <"\tgit diff HEAD^..HEAD >actual &&\n"> 
          <"\tsed -e \"1,/^@@/d\" actual >actual.body &&\n"> <"\texpect_from_to >expect.body $subtip $subprev &&\n"> <"\ttest_cmp expect.body actual.body &&\n"> 
          <"\tgit config submodule.subname.ignore all &&\n"> <"\tgit diff HEAD^..HEAD >actual &&\n"> <"\t! test -s actual &&\n"> 
          <"\tgit diff --ignore-submodules=dirty HEAD^..HEAD >actual &&\n"> <"\tsed -e \"1,/^@@/d\" actual >actual.body &&\n"> 
          <"\texpect_from_to >expect.body $subtip $subprev &&\n"> <"\tgit config --remove-section submodule.subname\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"git diff between submodule commits [.gitmodules]">)} 
      {
        (SQ <"\n"> <"\tgit diff HEAD^..HEAD >actual &&\n"> 
          <"\tsed -e \"1,/^@@/d\" actual >actual.body &&\n"> <"\texpect_from_to >expect.body $subtip $subprev &&\n"> <"\ttest_cmp expect.body actual.body &&\n"> 
          <"\tgit config --add -f .gitmodules submodule.subname.ignore dirty &&\n"> <"\tgit config --add -f .gitmodules submodule.subname.path sub &&\n"> 
          <"\tgit diff HEAD^..HEAD >actual &&\n"> <"\tsed -e \"1,/^@@/d\" actual >actual.body &&\n"> 
          <"\texpect_from_to >expect.body $subtip $subprev &&\n"> <"\ttest_cmp expect.body actual.body &&\n"> 
          <"\tgit config -f .gitmodules submodule.subname.ignore all &&\n"> <"\tgit diff HEAD^..HEAD >actual &&\n"> <"\t! test -s actual &&\n"> 
          <"\tgit config submodule.subname.ignore dirty &&\n"> <"\tgit config submodule.subname.path sub &&\n"> <"\tgit diff  HEAD^..HEAD >actual &&\n"> 
          <"\tsed -e \"1,/^@@/d\" actual >actual.body &&\n"> <"\texpect_from_to >expect.body $subtip $subprev &&\n"> 
          <"\tgit config --remove-section submodule.subname &&\n"> <"\tgit config --remove-section -f .gitmodules submodule.subname &&\n"> <"\trm .gitmodules\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"git diff (empty submodule dir)">)} 
      {
        (SQ <"\n"> <"\t: >empty &&\n"> <"\trm -rf sub/* sub/.git &&\n"> 
          <"\tgit diff > actual.empty &&\n"> <"\ttest_cmp empty actual.empty\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"conflicted submodule setup">)} 
      {
        (SQ <"\n"> <"\n"> <"\t# 39 efs\n"> <"\tc=fffffffffffffffffffffffffffffffffffffff &&\n"> <"\t(\n"> 
          <"\t\techo \"000000 $_z40 0\tsub\" &&\n"> <"\t\techo \"160000 1$c 1\tsub\" &&\n"> <"\t\techo \"160000 2$c 2\tsub\" &&\n"> 
          <"\t\techo \"160000 3$c 3\tsub\"\n"> <"\t) | git update-index --index-info &&\n"> <"\techo >expect.nosub ">
        ) (EscapedLiteralPart token:<Lit_EscapedChar "\\'">) 
        (SQ <"diff --cc sub\n"> <"index 2ffffff,3ffffff..0000000\n"> <"--- a/sub\n"> <"+++ b/sub\n"> 
          <"@@@ -1,1 -1,1 +1,1 @@@\n"> <"- Subproject commit 2fffffffffffffffffffffffffffffffffffffff\n"> 
          <" -Subproject commit 3fffffffffffffffffffffffffffffffffffffff\n"> <"++Subproject commit 0000000000000000000000000000000000000000">
        ) (EscapedLiteralPart token:<Lit_EscapedChar "\\'">) 
        (SQ <" &&\n"> <"\n"> <"\thh=$(git rev-parse HEAD) &&\n"> 
          <"\tsed -e \"s/$_z40/$hh/\" expect.nosub >expect.withsub\n"> <"\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"combined (empty submodule)">)} 
      {
        (SQ <"\n"> <"\trm -fr sub && mkdir sub &&\n"> <"\tgit diff >actual &&\n"> 
          <"\ttest_cmp expect.nosub actual\n">
        )
      }
    )
    (C {(test_expect_success)} {(SQ <"combined (with submodule)">)} 
      {
        (SQ <"\n"> <"\trm -fr sub &&\n"> <"\tgit clone --no-checkout . sub &&\n"> 
          <"\tgit diff >actual &&\n"> <"\ttest_cmp expect.withsub actual\n">
        )
      }
    )
    (C {(test_done)})
  ]
)