(command.CommandList children: [ (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:test_description) op: Equal rhs: {(SQ <'test git fast-import of notes objects'>)} ) ] ) (C {(.)} {(./test-lib.sh)}) (C {(test_tick)}) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_Great '>'> fd:16777215 arg_word:{(input)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(INPUT_END)} here_end_span_id: 118 stdin_parts: [ ('commit refs/heads/master\n') ('committer ') ($ VSub_DollarName '$GIT_COMMITTER_NAME') (' <') ($ VSub_DollarName '$GIT_COMMITTER_EMAIL') ('> ') ($ VSub_DollarName '$GIT_COMMITTER_DATE') ('\n') ('data <<COMMIT\n') ('first commit\n') ('COMMIT\n') ('\n') ('M 644 inline foo\n') ('data <<EOF\n') ('file foo in first commit\n') ('EOF\n') ('\n') ('M 755 inline bar\n') ('data <<EOF\n') ('file bar in first commit\n') ('EOF\n') ('\n') ('M 644 inline baz/xyzzy\n') ('data <<EOF\n') ('file baz/xyzzy in first commit\n') ('EOF\n') ('\n') ('commit refs/heads/master\n') ('committer ') ($ VSub_DollarName '$GIT_COMMITTER_NAME') (' <') ($ VSub_DollarName '$GIT_COMMITTER_EMAIL') ('> ') ($ VSub_DollarName '$GIT_COMMITTER_DATE') ('\n') ('data <<COMMIT\n') ('second commit\n') ('COMMIT\n') ('\n') ('M 644 inline foo\n') ('data <<EOF\n') ('file foo in second commit\n') ('EOF\n') ('\n') ('M 755 inline baz/xyzzy\n') ('data <<EOF\n') ('file baz/xyzzy in second commit\n') ('EOF\n') ('\n') ('commit refs/heads/master\n') ('committer ') ($ VSub_DollarName '$GIT_COMMITTER_NAME') (' <') ($ VSub_DollarName '$GIT_COMMITTER_EMAIL') ('> ') ($ VSub_DollarName '$GIT_COMMITTER_DATE') ('\n') ('data <<COMMIT\n') ('third commit\n') ('COMMIT\n') ('\n') ('M 644 inline foo\n') ('data <<EOF\n') ('file foo in third commit\n') ('EOF\n') ('\n') ('commit refs/heads/master\n') ('committer ') ($ VSub_DollarName '$GIT_COMMITTER_NAME') (' <') ($ VSub_DollarName '$GIT_COMMITTER_EMAIL') ('> ') ($ VSub_DollarName '$GIT_COMMITTER_DATE') ('\n') ('data <<COMMIT\n') ('fourth commit\n') ('COMMIT\n') ('\n') ('M 755 inline bar\n') ('data <<EOF\n') ('file bar in fourth commit\n') ('EOF\n') ('\n') ] ) ] ) (C {(test_expect_success)} {(SQ <'set up master branch'>)} {(SQ <'\n'> <'\n'> <'\tgit fast-import <input &&\n'> <'\tgit whatchanged master\n'>)} ) (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:commit4) op: Equal rhs: { (word_part.CommandSubPart command_list: (command.CommandList children: [(C {(git)} {(rev-parse)} {(refs/heads/master)})] ) left_token: <Left_CommandSub '$('> ) } ) ] ) (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:commit3) op: Equal rhs: { (word_part.CommandSubPart command_list: (command.CommandList children: [(C {(git)} {(rev-parse)} {(DQ ($ VSub_DollarName '$commit4') ('^'))})] ) left_token: <Left_CommandSub '$('> ) } ) ] ) (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:commit2) op: Equal rhs: { (word_part.CommandSubPart command_list: (command.CommandList children: [(C {(git)} {(rev-parse)} {(DQ ($ VSub_DollarName '$commit4') ('~2'))})] ) left_token: <Left_CommandSub '$('> ) } ) ] ) (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:commit1) op: Equal rhs: { (word_part.CommandSubPart command_list: (command.CommandList children: [(C {(git)} {(rev-parse)} {(DQ ($ VSub_DollarName '$commit4') ('~3'))})] ) left_token: <Left_CommandSub '$('> ) } ) ] ) (C {(test_tick)}) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_Great '>'> fd:16777215 arg_word:{(input)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(INPUT_END)} here_end_span_id: 217 stdin_parts: [ ('commit refs/notes/test\n') ('committer ') ($ VSub_DollarName '$GIT_COMMITTER_NAME') (' <') ($ VSub_DollarName '$GIT_COMMITTER_EMAIL') ('> ') ($ VSub_DollarName '$GIT_COMMITTER_DATE') ('\n') ('data <<COMMIT\n') ('first notes commit\n') ('COMMIT\n') ('\n') ('M 644 inline ') ($ VSub_DollarName '$commit1') ('\n') ('data <<EOF\n') ('first note for first commit\n') ('EOF\n') ('\n') ('M 755 inline ') ($ VSub_DollarName '$commit2') ('\n') ('data <<EOF\n') ('first note for second commit\n') ('EOF\n') ('\n') ] ) ] ) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_Great '>'> fd:16777215 arg_word:{(expect)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(EXPECT_END)} here_end_span_id: 234 stdin_parts: [ (' fourth commit\n') (' third commit\n') (' second commit\n') (' first note for second commit\n') (' first commit\n') (' first note for first commit\n') ] ) ] ) (C {(test_expect_success)} {(SQ <'add notes with simple M command'>)} { (SQ <'\n'> <'\n'> <'\tgit fast-import <input &&\n'> <'\tGIT_NOTES_REF=refs/notes/test git log | grep "^ " > actual &&\n'> <'\ttest_cmp expect actual\n'> <'\n'> ) } ) (C {(test_tick)}) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_Great '>'> fd:16777215 arg_word:{(input)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(INPUT_END)} here_end_span_id: 291 stdin_parts: [ ('feature notes\n') ('commit refs/notes/test\n') ('committer ') ($ VSub_DollarName '$GIT_COMMITTER_NAME') (' <') ($ VSub_DollarName '$GIT_COMMITTER_EMAIL') ('> ') ($ VSub_DollarName '$GIT_COMMITTER_DATE') ('\n') ('data <<COMMIT\n') ('second notes commit\n') ('COMMIT\n') ('\n') ('from refs/notes/test^0\n') ('N inline ') ($ VSub_DollarName '$commit3') ('\n') ('data <<EOF\n') ('first note for third commit\n') ('EOF\n') ('\n') ('N inline ') ($ VSub_DollarName '$commit4') ('\n') ('data <<EOF\n') ('first note for fourth commit\n') ('EOF\n') ('\n') ] ) ] ) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_Great '>'> fd:16777215 arg_word:{(expect)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(EXPECT_END)} here_end_span_id: 310 stdin_parts: [ (' fourth commit\n') (' first note for fourth commit\n') (' third commit\n') (' first note for third commit\n') (' second commit\n') (' first note for second commit\n') (' first commit\n') (' first note for first commit\n') ] ) ] ) (C {(test_expect_success)} {(SQ <'add notes with simple N command'>)} { (SQ <'\n'> <'\n'> <'\tgit fast-import <input &&\n'> <'\tGIT_NOTES_REF=refs/notes/test git log | grep "^ " > actual &&\n'> <'\ttest_cmp expect actual\n'> <'\n'> ) } ) (C {(test_tick)}) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_Great '>'> fd:16777215 arg_word:{(input)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(INPUT_END)} here_end_span_id: 380 stdin_parts: [ ('commit refs/notes/test\n') ('committer ') ($ VSub_DollarName '$GIT_COMMITTER_NAME') (' <') ($ VSub_DollarName '$GIT_COMMITTER_EMAIL') ('> ') ($ VSub_DollarName '$GIT_COMMITTER_DATE') ('\n') ('data <<COMMIT\n') ('third notes commit\n') ('COMMIT\n') ('\n') ('from refs/notes/test^0\n') ('N inline ') ($ VSub_DollarName '$commit1') ('\n') ('data <<EOF\n') ('second note for first commit\n') ('EOF\n') ('\n') ('N inline ') ($ VSub_DollarName '$commit2') ('\n') ('data <<EOF\n') ('second note for second commit\n') ('EOF\n') ('\n') ('N inline ') ($ VSub_DollarName '$commit3') ('\n') ('data <<EOF\n') ('second note for third commit\n') ('EOF\n') ('\n') ('N inline ') ($ VSub_DollarName '$commit4') ('\n') ('data <<EOF\n') ('second note for fourth commit\n') ('EOF\n') ('\n') ] ) ] ) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_Great '>'> fd:16777215 arg_word:{(expect)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(EXPECT_END)} here_end_span_id: 399 stdin_parts: [ (' fourth commit\n') (' second note for fourth commit\n') (' third commit\n') (' second note for third commit\n') (' second commit\n') (' second note for second commit\n') (' first commit\n') (' second note for first commit\n') ] ) ] ) (C {(test_expect_success)} {(SQ <'update existing notes with N command'>)} { (SQ <'\n'> <'\n'> <'\tgit fast-import <input &&\n'> <'\tGIT_NOTES_REF=refs/notes/test git log | grep "^ " > actual &&\n'> <'\ttest_cmp expect actual\n'> <'\n'> ) } ) (C {(test_tick)}) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_Great '>'> fd:16777215 arg_word:{(input)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(INPUT_END)} here_end_span_id: 545 stdin_parts: [ ('commit refs/notes/test\n') ('committer ') ($ VSub_DollarName '$GIT_COMMITTER_NAME') (' <') ($ VSub_DollarName '$GIT_COMMITTER_EMAIL') ('> ') ($ VSub_DollarName '$GIT_COMMITTER_DATE') ('\n') ('data <<COMMIT\n') ('fourth notes commit\n') ('COMMIT\n') ('\n') ('from refs/notes/test^0\n') ('M 644 inline ') (word_part.CommandSubPart command_list: (command.CommandList children: [ (command.Pipeline children: [ (C {(echo)} {(DQ ($ VSub_DollarName '$commit3'))}) (C {(sed)} {(DQ ('s|^..|&/|'))}) ] negated: F ) ] ) left_token: <Left_CommandSub '$('> ) ('\n') ('data <<EOF\n') ('prefix of note for third commit\n') ('EOF\n') ('\n') ('M 644 inline ') (word_part.CommandSubPart command_list: (command.CommandList children: [ (command.Pipeline children: [ (C {(echo)} {(DQ ($ VSub_DollarName '$commit4'))}) (C {(sed)} {(DQ ('s|^..|&/|'))}) ] negated: F ) ] ) left_token: <Left_CommandSub '$('> ) ('\n') ('data <<EOF\n') ('prefix of note for fourth commit\n') ('EOF\n') ('\n') ('M 644 inline ') (word_part.CommandSubPart command_list: (command.CommandList children: [ (command.Pipeline children: [ (C {(echo)} {(DQ ($ VSub_DollarName '$commit4'))}) (C {(sed)} { (DQ ('s|^') (Lit_Other '\\') ('(..') (Lit_Other '\\') (')') (Lit_Other '\\') ('(..') (Lit_Other '\\') (')|') (Lit_Other '\\') (1/) (Lit_Other '\\') ('2/|') ) } ) ] negated: F ) ] ) left_token: <Left_CommandSub '$('> ) ('\n') ('data <<EOF\n') ('pre-prefix of note for fourth commit\n') ('EOF\n') ('\n') ('N inline ') ($ VSub_DollarName '$commit1') ('\n') ('data <<EOF\n') ('third note for first commit\n') ('EOF\n') ('\n') ('N inline ') ($ VSub_DollarName '$commit2') ('\n') ('data <<EOF\n') ('third note for second commit\n') ('EOF\n') ('\n') ('N inline ') ($ VSub_DollarName '$commit3') ('\n') ('data <<EOF\n') ('third note for third commit\n') ('EOF\n') ('\n') ('N inline ') ($ VSub_DollarName '$commit4') ('\n') ('data <<EOF\n') ('third note for fourth commit\n') ('EOF\n') ('\n') ('\n') ] ) ] ) (command.Assignment keyword: Assign_None pairs: [(assign_pair lhs:(lhs_expr.LhsName name:whitespace) op:Equal rhs:{(DQ (' '))})] ) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_Great '>'> fd:16777215 arg_word:{(expect)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(EXPECT_END)} here_end_span_id: 579 stdin_parts: [ (' fourth commit\n') (' pre-prefix of note for fourth commit\n') ($ VSub_DollarName '$whitespace') ('\n') (' prefix of note for fourth commit\n') ($ VSub_DollarName '$whitespace') ('\n') (' third note for fourth commit\n') (' third commit\n') (' prefix of note for third commit\n') ($ VSub_DollarName '$whitespace') ('\n') (' third note for third commit\n') (' second commit\n') (' third note for second commit\n') (' first commit\n') (' third note for first commit\n') ] ) ] ) (C {(test_expect_success)} {(SQ <'add concatentation notes with M command'>)} { (SQ <'\n'> <'\n'> <'\tgit fast-import <input &&\n'> <'\tGIT_NOTES_REF=refs/notes/test git log | grep "^ " > actual &&\n'> <'\ttest_cmp expect actual\n'> <'\n'> ) } ) (C {(test_tick)}) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_Great '>'> fd:16777215 arg_word:{(input)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(INPUT_END)} here_end_span_id: 623 stdin_parts: [ ('commit refs/notes/test\n') ('committer ') ($ VSub_DollarName '$GIT_COMMITTER_NAME') (' <') ($ VSub_DollarName '$GIT_COMMITTER_EMAIL') ('> ') ($ VSub_DollarName '$GIT_COMMITTER_DATE') ('\n') ('data <<COMMIT\n') ('fifth notes commit\n') ('COMMIT\n') ('\n') ('from refs/notes/test^0\n') ('deleteall\n') ('\n') ] ) ] ) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_Great '>'> fd:16777215 arg_word:{(expect)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(EXPECT_END)} here_end_span_id: 638 stdin_parts: [ (' fourth commit\n') (' third commit\n') (' second commit\n') (' first commit\n') ] ) ] ) (C {(test_expect_success)} {(SQ <'verify that deleteall also removes notes'>)} { (SQ <'\n'> <'\n'> <'\tgit fast-import <input &&\n'> <'\tGIT_NOTES_REF=refs/notes/test git log | grep "^ " > actual &&\n'> <'\ttest_cmp expect actual\n'> <'\n'> ) } ) (C {(test_tick)}) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_Great '>'> fd:16777215 arg_word:{(input)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(INPUT_END)} here_end_span_id: 708 stdin_parts: [ ('commit refs/notes/test\n') ('committer ') ($ VSub_DollarName '$GIT_COMMITTER_NAME') (' <') ($ VSub_DollarName '$GIT_COMMITTER_EMAIL') ('> ') ($ VSub_DollarName '$GIT_COMMITTER_DATE') ('\n') ('data <<COMMIT\n') ('sixth notes commit\n') ('COMMIT\n') ('\n') ('from refs/notes/test^0\n') ('M 644 inline ') ($ VSub_DollarName '$commit1') ('\n') ('data <<EOF\n') ('third note for first commit\n') ('EOF\n') ('\n') ('M 644 inline ') ($ VSub_DollarName '$commit3') ('\n') ('data <<EOF\n') ('third note for third commit\n') ('EOF\n') ('\n') ('N inline ') ($ VSub_DollarName '$commit1') ('\n') ('data <<EOF\n') ('fourth note for first commit\n') ('EOF\n') ('\n') ('N inline ') ($ VSub_DollarName '$commit3') ('\n') ('data <<EOF\n') ('fourth note for third commit\n') ('EOF\n') ('\n') ] ) ] ) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_Great '>'> fd:16777215 arg_word:{(expect)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(EXPECT_END)} here_end_span_id: 725 stdin_parts: [ (' fourth commit\n') (' third commit\n') (' fourth note for third commit\n') (' second commit\n') (' first commit\n') (' fourth note for first commit\n') ] ) ] ) (C {(test_expect_success)} {(SQ <'verify that later N commands override earlier M commands'>)} { (SQ <'\n'> <'\n'> <'\tgit fast-import <input &&\n'> <'\tGIT_NOTES_REF=refs/notes/test git log | grep "^ " > actual &&\n'> <'\ttest_cmp expect actual\n'> <'\n'> ) } ) (command.FuncDef name: fast_import_commits body: (command.BraceGroup children: [ (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:my_ref) op: Equal rhs: {($ VSub_Number '$1')} ) ] ) (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:my_num_commits) op: Equal rhs: {($ VSub_Number '$2')} ) ] ) (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:my_append_to_file) op: Equal rhs: {($ VSub_Number '$3')} ) ] ) (command.Assignment keyword: Assign_None pairs: [(assign_pair lhs:(lhs_expr.LhsName name:my_i) op:Equal rhs:{(0)})] ) (command.WhileUntil keyword: <KW_While while> cond: [ (C {(test)} {($ VSub_DollarName '$my_i')} {(-lt)} {($ VSub_DollarName '$my_num_commits')}) ] body: (command.DoGroup children: [ (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:my_i) op: Equal rhs: { (word_part.ArithSubPart anode: (arith_expr.ArithBinary op_id: Arith_Plus left: (arith_expr.ArithWord w:{($ VSub_DollarName '$my_i')}) right: (arith_expr.ArithWord w:{(Lit_Digits 1)}) ) ) } ) ] ) (C {(test_tick)}) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op: <Redir_DGreat '>>'> fd: 16777215 arg_word: {(DQ ($ VSub_DollarName '$my_append_to_file'))} ) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(INPUT_END)} here_end_span_id: 835 stdin_parts: [ ('commit ') ($ VSub_DollarName '$my_ref') ('\n') ('mark :') ($ VSub_DollarName '$my_i') ('\n') ('committer ') ($ VSub_DollarName '$GIT_COMMITTER_NAME') (' <') ($ VSub_DollarName '$GIT_COMMITTER_EMAIL') ('> ') ($ VSub_DollarName '$GIT_COMMITTER_DATE') ('\n') ('data <<COMMIT\n') ('commit #') ($ VSub_DollarName '$my_i') ('\n') ('COMMIT\n') ('\n') ('M 644 inline file\n') ('data <<EOF\n') ('file contents in commit #') ($ VSub_DollarName '$my_i') ('\n') ('EOF\n') ('\n') ] ) ] ) ] ) ) ] ) ) (command.FuncDef name: fast_import_notes body: (command.BraceGroup children: [ (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:my_notes_ref) op: Equal rhs: {($ VSub_Number '$1')} ) ] ) (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:my_num_commits) op: Equal rhs: {($ VSub_Number '$2')} ) ] ) (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:my_append_to_file) op: Equal rhs: {($ VSub_Number '$3')} ) ] ) (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:my_note_append) op: Equal rhs: {($ VSub_Number '$4')} ) ] ) (C {(test_tick)}) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op: <Redir_DGreat '>>'> fd: 16777215 arg_word: {(DQ ($ VSub_DollarName '$my_append_to_file'))} ) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(INPUT_END)} here_end_span_id: 902 stdin_parts: [ ('commit ') ($ VSub_DollarName '$my_notes_ref') ('\n') ('committer ') ($ VSub_DollarName '$GIT_COMMITTER_NAME') (' <') ($ VSub_DollarName '$GIT_COMMITTER_EMAIL') ('> ') ($ VSub_DollarName '$GIT_COMMITTER_DATE') ('\n') ('data <<COMMIT\n') ('committing ') ($ VSub_DollarName '$my_num_commits') (' notes\n') ('COMMIT\n') ('\n') ] ) ] ) (command.Assignment keyword: Assign_None pairs: [(assign_pair lhs:(lhs_expr.LhsName name:my_i) op:Equal rhs:{(0)})] ) (command.WhileUntil keyword: <KW_While while> cond: [ (C {(test)} {($ VSub_DollarName '$my_i')} {(-lt)} {($ VSub_DollarName '$my_num_commits')}) ] body: (command.DoGroup children: [ (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:my_i) op: Equal rhs: { (word_part.ArithSubPart anode: (arith_expr.ArithBinary op_id: Arith_Plus left: (arith_expr.ArithWord w:{($ VSub_DollarName '$my_i')}) right: (arith_expr.ArithWord w:{(Lit_Digits 1)}) ) ) } ) ] ) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op: <Redir_DGreat '>>'> fd: 16777215 arg_word: {(DQ ($ VSub_DollarName '$my_append_to_file'))} ) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(INPUT_END)} here_end_span_id: 955 stdin_parts: [ ('N inline :') ($ VSub_DollarName '$my_i') ('\n') ('data <<EOF\n') ('note for commit #') ($ VSub_DollarName '$my_i') ($ VSub_DollarName '$my_note_append') ('\n') ('EOF\n') ('\n') ] ) ] ) ] ) ) ] ) ) (C {(rm)} {(input)} {(expect)}) (command.Assignment keyword: Assign_None pairs: [(assign_pair lhs:(lhs_expr.LhsName name:num_commits) op:Equal rhs:{(400)})] ) (C {(fast_import_commits)} {(DQ (refs/heads/many_commits))} {($ VSub_DollarName '$num_commits')} {(input)} ) (C {(fast_import_notes)} {(DQ (refs/notes/many_notes))} {($ VSub_DollarName '$num_commits')} {(input)} ) (C {(test_tick)}) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_DGreat '>>'> fd:16777215 arg_word:{(input)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(INPUT_END)} here_end_span_id: 1039 stdin_parts: [ ('commit refs/notes/many_notes\n') ('committer ') ($ VSub_DollarName '$GIT_COMMITTER_NAME') (' <') ($ VSub_DollarName '$GIT_COMMITTER_EMAIL') ('> ') ($ VSub_DollarName '$GIT_COMMITTER_DATE') ('\n') ('data <<COMMIT\n') ('committing some non-notes to the notes tree\n') ('COMMIT\n') ('\n') ('M 755 inline foobar/non-note.txt\n') ('data <<EOF\n') ('This is not a note, but rather a regular file residing in a notes tree\n') ('EOF\n') ('\n') ('M 644 inline deadbeef\n') ('data <<EOF\n') ('Non-note file\n') ('EOF\n') ('\n') ('M 644 inline de/adbeef\n') ('data <<EOF\n') ('Another non-note file\n') ('EOF\n') ('\n') ] ) ] ) (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:i) op: Equal rhs: {($ VSub_DollarName '$num_commits')} ) ] ) (command.WhileUntil keyword: <KW_While while> cond: [(C {(test)} {($ VSub_DollarName '$i')} {(-gt)} {(0)})] body: (command.DoGroup children: [ (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_DGreat '>>'> fd:16777215 arg_word:{(expect)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(EXPECT_END)} here_end_span_id: 1074 stdin_parts: [ (' commit #') ($ VSub_DollarName '$i') ('\n') (' note for commit #') ($ VSub_DollarName '$i') ('\n') ] ) ] ) (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:i) op: Equal rhs: { (word_part.ArithSubPart anode: (arith_expr.ArithBinary op_id: Arith_Minus left: (arith_expr.ArithWord w:{($ VSub_DollarName '$i')}) right: (arith_expr.ArithWord w:{(Lit_Digits 1)}) ) ) } ) ] ) ] ) ) (C {(test_expect_success)} {(SQ <'add lots of commits and notes'>)} { (SQ <'\n'> <'\n'> <'\tgit fast-import <input &&\n'> <'\tGIT_NOTES_REF=refs/notes/many_notes git log refs/heads/many_commits |\n'> <'\t grep "^ " > actual &&\n'> <'\ttest_cmp expect actual\n'> <'\n'> ) } ) (C {(test_expect_success)} {(SQ <'verify that lots of notes trigger a fanout scheme'>)} { (SQ <'\n'> <'\n'> <'\t# None of the entries in the top-level notes tree should be a full SHA1\n'> <'\tgit ls-tree --name-only refs/notes/many_notes |\n'> <'\twhile read path\n'> <'\tdo\n'> <'\t\tif test $(expr length "$path") -ge 40\n'> <'\t\tthen\n'> <'\t\t\treturn 1\n'> <'\t\tfi\n'> <'\tdone\n'> <'\n'> ) } ) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_DGreat '>>'> fd:16777215 arg_word:{(expect_non-note1)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(EOF)} here_end_span_id: 1139 stdin_parts: [('This is not a note, but rather a regular file residing in a notes tree\n')] ) ] ) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_DGreat '>>'> fd:16777215 arg_word:{(expect_non-note2)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(EOF)} here_end_span_id: 1152 stdin_parts: [('Non-note file\n')] ) ] ) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_DGreat '>>'> fd:16777215 arg_word:{(expect_non-note3)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(EOF)} here_end_span_id: 1165 stdin_parts: [('Another non-note file\n')] ) ] ) (C {(test_expect_success)} {(SQ <'verify that non-notes are untouched by a fanout change'>)} { (SQ <'\n'> <'\n'> <'\tgit cat-file -p refs/notes/many_notes:foobar/non-note.txt > actual &&\n'> <'\ttest_cmp expect_non-note1 actual &&\n'> <'\tgit cat-file -p refs/notes/many_notes:deadbeef > actual &&\n'> <'\ttest_cmp expect_non-note2 actual &&\n'> <'\tgit cat-file -p refs/notes/many_notes:de/adbeef > actual &&\n'> <'\ttest_cmp expect_non-note3 actual\n'> <'\n'> ) } ) (C {(test_tick)}) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_Great '>'> fd:16777215 arg_word:{(input)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(INPUT_END)} here_end_span_id: 1212 stdin_parts: [ ('commit refs/notes/many_notes\n') ('committer ') ($ VSub_DollarName '$GIT_COMMITTER_NAME') (' <') ($ VSub_DollarName '$GIT_COMMITTER_EMAIL') ('> ') ($ VSub_DollarName '$GIT_COMMITTER_DATE') ('\n') ('data <<COMMIT\n') ('changing notes for the top three commits\n') ('COMMIT\n') ('from refs/notes/many_notes^0\n') ] ) ] ) (C {(rm)} {(expect)}) (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:i) op: Equal rhs: {($ VSub_DollarName '$num_commits')} ) ] ) (command.Assignment keyword: Assign_None pairs: [(assign_pair lhs:(lhs_expr.LhsName name:j) op:Equal rhs:{(0)})] ) (command.WhileUntil keyword: <KW_While while> cond: [(C {(test)} {($ VSub_DollarName '$j')} {(-lt)} {(3)})] body: (command.DoGroup children: [ (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_DGreat '>>'> fd:16777215 arg_word:{(input)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(INPUT_END)} here_end_span_id: 1254 stdin_parts: [ ('N inline refs/heads/many_commits~') ($ VSub_DollarName '$j') ('\n') ('data <<EOF\n') ('changed note for commit #') ($ VSub_DollarName '$i') ('\n') ('EOF\n') ] ) ] ) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_DGreat '>>'> fd:16777215 arg_word:{(expect)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(EXPECT_END)} here_end_span_id: 1271 stdin_parts: [ (' commit #') ($ VSub_DollarName '$i') ('\n') (' changed note for commit #') ($ VSub_DollarName '$i') ('\n') ] ) ] ) (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:i) op: Equal rhs: { (word_part.ArithSubPart anode: (arith_expr.ArithBinary op_id: Arith_Minus left: (arith_expr.ArithWord w:{($ VSub_DollarName '$i')}) right: (arith_expr.ArithWord w:{(Lit_Digits 1)}) ) ) } ) ] ) (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:j) op: Equal rhs: { (word_part.ArithSubPart anode: (arith_expr.ArithBinary op_id: Arith_Plus left: (arith_expr.ArithWord w:{($ VSub_DollarName '$j')}) right: (arith_expr.ArithWord w:{(Lit_Digits 1)}) ) ) } ) ] ) ] ) ) (C {(test_expect_success)} {(SQ <'change a few existing notes'>)} { (SQ <'\n'> <'\n'> <'\tgit fast-import <input &&\n'> <'\tGIT_NOTES_REF=refs/notes/many_notes git log -n3 refs/heads/many_commits |\n'> <'\t grep "^ " > actual &&\n'> <'\ttest_cmp expect actual\n'> <'\n'> ) } ) (C {(test_expect_success)} {(SQ <'verify that changing notes respect existing fanout'>)} { (SQ <'\n'> <'\n'> <'\t# None of the entries in the top-level notes tree should be a full SHA1\n'> <'\tgit ls-tree --name-only refs/notes/many_notes |\n'> <'\twhile read path\n'> <'\tdo\n'> <'\t\tif test $(expr length "$path") -ge 40\n'> <'\t\tthen\n'> <'\t\t\treturn 1\n'> <'\t\tfi\n'> <'\tdone\n'> <'\n'> ) } ) (command.Assignment keyword: Assign_None pairs: [(assign_pair lhs:(lhs_expr.LhsName name:remaining_notes) op:Equal rhs:{(10)})] ) (C {(test_tick)}) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_Great '>'> fd:16777215 arg_word:{(input)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(INPUT_END)} here_end_span_id: 1364 stdin_parts: [ ('commit refs/notes/many_notes\n') ('committer ') ($ VSub_DollarName '$GIT_COMMITTER_NAME') (' <') ($ VSub_DollarName '$GIT_COMMITTER_EMAIL') ('> ') ($ VSub_DollarName '$GIT_COMMITTER_DATE') ('\n') ('data <<COMMIT\n') ('removing all notes but ') ($ VSub_DollarName '$remaining_notes') ('\n') ('COMMIT\n') ('from refs/notes/many_notes^0\n') ] ) ] ) (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:i) op: Equal rhs: { (word_part.ArithSubPart anode: (arith_expr.ArithBinary op_id: Arith_Minus left: (arith_expr.ArithWord w:{($ VSub_DollarName '$num_commits')}) right: (arith_expr.ArithWord w:{($ VSub_DollarName '$remaining_notes')}) ) ) } ) ] ) (command.ForEach iter_name: sha1 iter_words: [ { (word_part.CommandSubPart command_list: (command.CommandList children: [ (C {(git)} {(rev-list)} {(-n)} {($ VSub_DollarName '$i')} {(refs/heads/many_commits)}) ] ) left_token: <Left_CommandSub '$('> ) } ] do_arg_iter: F body: (command.DoGroup children: [ (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_DGreat '>>'> fd:16777215 arg_word:{(input)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(INPUT_END)} here_end_span_id: 1409 stdin_parts: [ ('N 0000000000000000000000000000000000000000 ') ($ VSub_DollarName '$sha1') ('\n') ] ) ] ) ] ) ) (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:i) op: Equal rhs: {($ VSub_DollarName '$num_commits')} ) ] ) (C {(rm)} {(expect)}) (command.WhileUntil keyword: <KW_While while> cond: [(C {(test)} {($ VSub_DollarName '$i')} {(-gt)} {(0)})] body: (command.DoGroup children: [ (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_DGreat '>>'> fd:16777215 arg_word:{(expect)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(EXPECT_END)} here_end_span_id: 1445 stdin_parts: [(' commit #') ($ VSub_DollarName '$i') ('\n')] ) ] ) (command.If arms: [ (if_arm cond: [ (C {(test)} {($ VSub_DollarName '$i')} {(-le)} {($ VSub_DollarName '$remaining_notes')} ) ] action: [ (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op: <Redir_DGreat '>>'> fd: 16777215 arg_word: {(expect)} ) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(EXPECT_END)} here_end_span_id: 1473 stdin_parts: [(' note for commit #') ($ VSub_DollarName '$i') ('\n')] ) ] ) ] ) ] ) (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:i) op: Equal rhs: { (word_part.ArithSubPart anode: (arith_expr.ArithBinary op_id: Arith_Minus left: (arith_expr.ArithWord w:{($ VSub_DollarName '$i')}) right: (arith_expr.ArithWord w:{(Lit_Digits 1)}) ) ) } ) ] ) ] ) ) (C {(test_expect_success)} {(SQ <'remove lots of notes'>)} { (SQ <'\n'> <'\n'> <'\tgit fast-import <input &&\n'> <'\tGIT_NOTES_REF=refs/notes/many_notes git log refs/heads/many_commits |\n'> <'\t grep "^ " > actual &&\n'> <'\ttest_cmp expect actual\n'> <'\n'> ) } ) (C {(test_expect_success)} {(SQ <'verify that removing notes trigger fanout consolidation'>)} { (SQ <'\n'> <'\n'> <'\t# All entries in the top-level notes tree should be a full SHA1\n'> <'\tgit ls-tree --name-only -r refs/notes/many_notes |\n'> <'\twhile read path\n'> <'\tdo\n'> <'\t\t# Explicitly ignore the non-note paths\n'> <'\t\ttest "$path" = "foobar/non-note.txt" && continue\n'> <'\t\ttest "$path" = "deadbeef" && continue\n'> <'\t\ttest "$path" = "de/adbeef" && continue\n'> <'\n'> <'\t\tif test $(expr length "$path") -ne 40\n'> <'\t\tthen\n'> <'\t\t\treturn 1\n'> <'\t\tfi\n'> <'\tdone\n'> <'\n'> ) } ) (C {(test_expect_success)} {(SQ <'verify that non-notes are untouched by a fanout change'>)} { (SQ <'\n'> <'\n'> <'\tgit cat-file -p refs/notes/many_notes:foobar/non-note.txt > actual &&\n'> <'\ttest_cmp expect_non-note1 actual &&\n'> <'\tgit cat-file -p refs/notes/many_notes:deadbeef > actual &&\n'> <'\ttest_cmp expect_non-note2 actual &&\n'> <'\tgit cat-file -p refs/notes/many_notes:de/adbeef > actual &&\n'> <'\ttest_cmp expect_non-note3 actual\n'> <'\n'> ) } ) (C {(rm)} {(input)} {(expect)}) (command.Assignment keyword: Assign_None pairs: [(assign_pair lhs:(lhs_expr.LhsName name:num_notes_refs) op:Equal rhs:{(10)})] ) (command.Assignment keyword: Assign_None pairs: [(assign_pair lhs:(lhs_expr.LhsName name:num_commits) op:Equal rhs:{(16)})] ) (command.Assignment keyword: Assign_None pairs: [(assign_pair lhs:(lhs_expr.LhsName name:some_commits) op:Equal rhs:{(8)})] ) (C {(fast_import_commits)} {(DQ (refs/heads/more_commits))} {($ VSub_DollarName '$num_commits')} {(input)} ) (command.Assignment keyword: Assign_None pairs: [(assign_pair lhs:(lhs_expr.LhsName name:i) op:Equal rhs:{(0)})] ) (command.WhileUntil keyword: <KW_While while> cond: [(C {(test)} {($ VSub_DollarName '$i')} {(-lt)} {($ VSub_DollarName '$num_notes_refs')})] body: (command.DoGroup children: [ (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:i) op: Equal rhs: { (word_part.ArithSubPart anode: (arith_expr.ArithBinary op_id: Arith_Plus left: (arith_expr.ArithWord w:{($ VSub_DollarName '$i')}) right: (arith_expr.ArithWord w:{(Lit_Digits 1)}) ) ) } ) ] ) (C {(fast_import_notes)} {(DQ (refs/notes/more_notes_) ($ VSub_DollarName '$i'))} {($ VSub_DollarName '$num_commits')} {(input)} ) ] ) ) (command.Assignment keyword: Assign_None pairs: [(assign_pair lhs:(lhs_expr.LhsName name:i) op:Equal rhs:{(0)})] ) (command.WhileUntil keyword: <KW_While while> cond: [(C {(test)} {($ VSub_DollarName '$i')} {(-lt)} {($ VSub_DollarName '$num_notes_refs')})] body: (command.DoGroup children: [ (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:i) op: Equal rhs: { (word_part.ArithSubPart anode: (arith_expr.ArithBinary op_id: Arith_Plus left: (arith_expr.ArithWord w:{($ VSub_DollarName '$i')}) right: (arith_expr.ArithWord w:{(Lit_Digits 1)}) ) ) } ) ] ) (C {(fast_import_notes)} {(DQ (refs/notes/more_notes_) ($ VSub_DollarName '$i'))} {($ VSub_DollarName '$some_commits')} {(input)} {(DQ (' (2)'))} ) ] ) ) (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:i) op: Equal rhs: {($ VSub_DollarName '$num_commits')} ) ] ) (command.WhileUntil keyword: <KW_While while> cond: [(C {(test)} {($ VSub_DollarName '$i')} {(-gt)} {(0)})] body: (command.DoGroup children: [ (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:note_data) op: Equal rhs: {(DQ ('note for commit #') ($ VSub_DollarName '$i'))} ) ] ) (command.If arms: [ (if_arm cond: [ (C {(test)} {($ VSub_DollarName '$i')} {(-le)} {($ VSub_DollarName '$some_commits')}) ] action: [ (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:note_data) op: Equal rhs: {(DQ ($ VSub_DollarName '$note_data') (' (2)'))} ) ] ) ] ) ] ) (command.SimpleCommand words: [{(cat)}] redirects: [ (redir.Redir op:<Redir_DGreat '>>'> fd:16777215 arg_word:{(expect)}) (redir.HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(EXPECT_END)} here_end_span_id: 1738 stdin_parts: [ (' commit #') ($ VSub_DollarName '$i') ('\n') (' ') ($ VSub_DollarName '$note_data') ('\n') ] ) ] ) (command.Assignment keyword: Assign_None pairs: [ (assign_pair lhs: (lhs_expr.LhsName name:i) op: Equal rhs: { (word_part.ArithSubPart anode: (arith_expr.ArithBinary op_id: Arith_Minus left: (arith_expr.ArithWord w:{($ VSub_DollarName '$i')}) right: (arith_expr.ArithWord w:{(Lit_Digits 1)}) ) ) } ) ] ) ] ) ) (C {(test_expect_success)} { (DQ ('add notes to ') ($ VSub_DollarName '$num_commits') (' commits in each of ') ($ VSub_DollarName '$num_notes_refs') (' refs') ) } { (SQ <'\n'> <'\n'> <'\tgit fast-import --active-branches=5 <input &&\n'> <'\tGIT_NOTES_REF=refs/notes/more_notes_1 git log refs/heads/more_commits |\n'> <'\t grep "^ " > actual &&\n'> <'\ttest_cmp expect actual\n'> <'\n'> ) } ) (C {(test_done)}) ] )