(CommandList children: [ (Assignment keyword: Assign_None pairs: [(assign_pair lhs:(LhsName name:n_args) op:Equal rhs:{(10000)} spids:[59])] spids: [59] ) (SimpleCommand words: [{(cat)}] redirects: [ (HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(SQ <EOF>)} here_end_span_id: 82 stdin_parts: [ ('#include <stdio.h>\n') ('#include <mcheck.h>\n') ('\n') ('/*\n') (' Compile do_test without optimization: GCC 4.9/5.0/6.0 takes a long time\n') (' to build this source. https://gcc.gnu.org/bugzilla/show_bug.cgi?id=67396 */\n') ('\n') ('__attribute__ ((optimize ("-O0")))\n') ('int do_test (void)\n') ('{\n') (' mtrace ();\n') (' printf (\n') ] ) ] ) (ForExpr init: (BinaryAssign op_id:Arith_Equal left:(LhsName name:j) right:(ArithWord w:{(Lit_Digits 0)})) cond: (ArithBinary op_id: Arith_Less left: (ArithVarRef name:j) right: (ArithBinary op_id: Arith_Slash left: (ArithWord w:{($ VSub_Name '$n_args')}) right: (ArithWord w:{(Lit_Digits 10)}) ) ) update: (UnaryAssign op_id:Node_PostDPlus child:(LhsName name:j)) body: (DoGroup children: [ (ForExpr init: (BinaryAssign op_id: Arith_Equal left: (LhsName name:k) right: (ArithWord w:{(Lit_Digits 0)}) ) cond: (ArithBinary op_id: Arith_Less left: (ArithVarRef name:k) right: (ArithWord w:{(Lit_Digits 10)}) ) update: (UnaryAssign op_id:Node_PostDPlus child:(LhsName name:k)) body: (DoGroup children: [ (C {(printf)} {(SQ <'"%%%d$s" '>)} { (ArithSubPart anode: (ArithBinary op_id: Arith_Plus left: (ArithBinary op_id: Arith_Plus left: (ArithBinary op_id: Arith_Star left: (ArithWord w:{(Lit_Digits 10)}) right: (ArithWord w:{($ VSub_Name '$j')}) ) right: (ArithWord w:{($ VSub_Name '$k')}) ) right: (ArithWord w:{(Lit_Digits 1)}) ) spids: [146 161] ) } ) ] spids: [137 164] ) ) (C {(printf)} {(DQ (Lit_Other '\\') (n))}) ] spids: [111 174] ) ) (C {(printf)} {(SQ <'"%%%d$s",\\n'>)} { (ArithSubPart anode: (ArithBinary op_id: Arith_Plus left: (ArithWord w:{($ VSub_Name '$n_args')}) right: (ArithWord w:{(Lit_Digits 1)}) ) spids: [183 190] ) } ) (ForExpr init: (BinaryAssign op_id:Arith_Equal left:(LhsName name:j) right:(ArithWord w:{(Lit_Digits 0)})) cond: (ArithBinary op_id: Arith_Less left: (ArithVarRef name:j) right: (ArithBinary op_id: Arith_Slash left: (ArithWord w:{($ VSub_Name '$n_args')}) right: (ArithWord w:{(Lit_Digits 10)}) ) ) update: (UnaryAssign op_id:Node_PostDPlus child:(LhsName name:j)) body: (DoGroup children: [ (ForExpr init: (BinaryAssign op_id: Arith_Equal left: (LhsName name:k) right: (ArithWord w:{(Lit_Digits 0)}) ) cond: (ArithBinary op_id: Arith_Less left: (ArithVarRef name:k) right: (ArithWord w:{(Lit_Digits 10)}) ) update: (UnaryAssign op_id:Node_PostDPlus child:(LhsName name:k)) body: (DoGroup children:[(C {(printf)} {(SQ <'"a", '>)})] spids:[246 256]) ) (C {(printf)} {(DQ (' /* %4d */') (Lit_Other '\\') (n))} { (ArithSubPart anode: (ArithBinary op_id: Arith_Plus left: (ArithBinary op_id: Arith_Star left: (ArithWord w:{(Lit_Digits 10)}) right: (ArithWord w:{($ VSub_Name '$j')}) ) right: (ArithWord w:{($ VSub_Name '$k')}) ) spids: [267 278] ) } ) ] spids: [220 280] ) ) (C {(printf)} {(SQ <'"\\\\n");'>)}) (SimpleCommand words: [{(cat)}] redirects: [ (HereDoc op: <Redir_DLess '<<'> fd: 16777215 here_begin: {(SQ <EOF>)} here_end_span_id: 305 stdin_parts: [ ('\n') (' return 0;\n') ('}\n') ('\n') ('#define TEST_FUNCTION do_test ()\n') ('#include "../test-skeleton.c"\n') ('\n') ] ) ] ) ] )