--- source: src/main.rs expression: parsed input_file: test-data/lua5.3-tests/all.lua --- [ Variable { names: [ ( "version", false, ), ], values: [ [ Symbol( "\"Lua 5.3\"", ), ], ], line: 7, column: 0, }, IfStatement { condition: [ Ident { expr: [ Symbol( "_VERSION", ), ], line: 7, }, Operator( ( "~=", true, ), ), Ident { expr: [ Symbol( "version", ), ], line: 7, }, ], body: CodeBlock { start: 9, code: [ Ident { expr: [ Symbol( "io", ), Symbol( ".", ), Symbol( "stderr", ), Symbol( ":", ), Symbol( "write", ), Call( [ [ Symbol( "\"\\nThis test suite is for \"", ), ], [ Ident { expr: [ Symbol( "version", ), ], line: 8, }, ], [ Symbol( "\", not for \"", ), ], [ Ident { expr: [ Symbol( "_VERSION", ), ], line: 8, }, ], [ Symbol( "\"\\nExiting tests\\n\"", ), ], ], ), ], line: 8, }, Return( None, ), ], end: 27, }, next: None, line: 11, column: 1, }, Alter { names: [ Ident { expr: [ Symbol( "_G", ), Symbol( ".", ), Symbol( "_ARG", ), ], line: 11, }, ], values: [ [ Ident { expr: [ Symbol( "arg", ), ], line: 14, }, ], ], line: 14, column: 5, }, Alter { names: [ Ident { expr: [ Symbol( "_soft", ), ], line: 14, }, ], values: [ [ Ident { expr: [ Symbol( "rawget", ), Call( [ [ Ident { expr: [ Symbol( "_G", ), ], line: 21, }, ], [ Symbol( "\"_soft\"", ), ], ], ), ], line: 21, }, Operator( ( "or", true, ), ), Symbol( "false", ), ], ], line: 21, column: 10, }, Alter { names: [ Ident { expr: [ Symbol( "_port", ), ], line: 21, }, ], values: [ [ Ident { expr: [ Symbol( "rawget", ), Call( [ [ Ident { expr: [ Symbol( "_G", ), ], line: 23, }, ], [ Symbol( "\"_port\"", ), ], ], ), ], line: 23, }, Operator( ( "or", true, ), ), Symbol( "false", ), ], ], line: 23, column: 10, }, Alter { names: [ Ident { expr: [ Symbol( "_nomsg", ), ], line: 23, }, ], values: [ [ Ident { expr: [ Symbol( "rawget", ), Call( [ [ Ident { expr: [ Symbol( "_G", ), ], line: 25, }, ], [ Symbol( "\"_nomsg\"", ), ], ], ), ], line: 25, }, Operator( ( "or", true, ), ), Symbol( "false", ), ], ], line: 28, column: 0, }, Variable { names: [ ( "usertests", false, ), ], values: [ [ Ident { expr: [ Symbol( "rawget", ), Call( [ [ Ident { expr: [ Symbol( "_G", ), ], line: 28, }, ], [ Symbol( "\"_U\"", ), ], ], ), ], line: 28, }, ], ], line: 30, column: 0, }, IfStatement { condition: [ Ident { expr: [ Symbol( "usertests", ), ], line: 30, }, ], body: CodeBlock { start: 74, code: [ Alter { names: [ Ident { expr: [ Symbol( "_soft", ), ], line: 32, }, ], values: [ [ Symbol( "true", ), ], ], line: 32, column: 3, }, Alter { names: [ Ident { expr: [ Symbol( "_port", ), ], line: 32, }, ], values: [ [ Symbol( "true", ), ], ], line: 33, column: 3, }, Alter { names: [ Ident { expr: [ Symbol( "_nomsg", ), ], line: 33, }, ], values: [ [ Symbol( "true", ), ], ], line: 34, column: 3, }, ], end: 84, }, next: None, line: 35, column: 1, }, Alter { names: [ Ident { expr: [ Symbol( "debug", ), ], line: 35, }, ], values: [ [ Symbol( "nil", ), ], ], line: 40, column: 0, }, IfStatement { condition: [ Ident { expr: [ Symbol( "usertests", ), ], line: 40, }, ], body: CodeBlock { start: 90, code: [ Alter { names: [ Ident { expr: [ Symbol( "T", ), ], line: 41, }, ], values: [ [ Symbol( "nil", ), ], ], line: 41, column: 3, }, ], end: 94, }, next: Some( IfStatement { condition: [], body: CodeBlock { start: 94, code: [ Alter { names: [ Ident { expr: [ Symbol( "T", ), ], line: 43, }, ], values: [ [ Ident { expr: [ Symbol( "rawget", ), Call( [ [ Ident { expr: [ Symbol( "_G", ), ], line: 43, }, ], [ Symbol( "\"T\"", ), ], ], ), ], line: 43, }, ], ], line: 43, column: 8, }, ], end: 103, }, next: None, line: 44, column: 1, }, ), line: 44, column: 1, }, Ident { expr: [ Symbol( "math", ), Symbol( ".", ), Symbol( "randomseed", ), Call( [ [ Symbol( "0", ), ], ], ), ], line: 44, }, Ident { expr: [ Symbol( "print", ), Call( [ [ Symbol( "\"current path:\\n****\"", ), Operator( ( "..", true, ), ), Ident { expr: [ Symbol( "package", ), Symbol( ".", ), Symbol( "path", ), ], line: 54, }, Operator( ( "..", true, ), ), Symbol( "\"****\\n\"", ), ], ], ), ], line: 46, }, Variable { names: [ ( "initclock", false, ), ], values: [ [ Ident { expr: [ Symbol( "os", ), Symbol( ".", ), Symbol( "clock", ), Call( [], ), ], line: 57, }, ], ], line: 58, column: 0, }, Variable { names: [ ( "lastclock", false, ), ], values: [ [ Ident { expr: [ Symbol( "initclock", ), ], line: 58, }, ], ], line: 59, column: 0, }, Variable { names: [ ( "walltime", false, ), ], values: [ [ Ident { expr: [ Symbol( "os", ), Symbol( ".", ), Symbol( "time", ), Call( [], ), ], line: 59, }, ], ], line: 61, column: 0, }, Variable { names: [ ( "collectgarbage", false, ), ], values: [ [ Ident { expr: [ Symbol( "collectgarbage", ), ], line: 61, }, ], ], line: 63, column: 0, }, DoBlock( CodeBlock { start: 144, code: [ Variable { names: [ ( "msgs", false, ), ], values: [ [ Table { data: [], line: 66, column: 5, }, ], ], line: 67, column: 0, }, Function { local: false, name: [ Symbol( "Message", ), ], args: [ "m", ], body: CodeBlock { start: 10, code: [ IfStatement { condition: [ Operator( ( "not", false, ), ), Ident { expr: [ Symbol( "_nomsg", ), ], line: 68, }, ], body: CodeBlock { start: 4, code: [ Ident { expr: [ Symbol( "print", ), Call( [ [ Ident { expr: [ Symbol( "m", ), ], line: 69, }, ], ], ), ], line: 69, }, Alter { names: [ Ident { expr: [ Symbol( "msgs", ), Symbol( "[", ), Expr( [ Operator( ( "#", false, ), ), Ident { expr: [ Symbol( "msgs", ), ], line: 70, }, Operator( ( "+", true, ), ), Symbol( "1", ), ], ), Symbol( "]", ), ], line: 69, }, ], values: [ [ Ident { expr: [ Symbol( "string", ), Symbol( ".", ), Symbol( "sub", ), Call( [ [ Ident { expr: [ Symbol( "m", ), ], line: 70, }, ], [ Symbol( "3", ), ], [ Operator( ( "-", false, ), ), Symbol( "3", ), ], ], ), ], line: 70, }, ], ], line: 70, column: 19, }, ], end: 28, }, next: None, line: 71, column: 1, }, ], end: 39, }, line: 72, column: 1, }, Ident { expr: [ Symbol( "assert", ), Call( [ [ Ident { expr: [ Symbol( "os", ), Symbol( ".", ), Symbol( "setlocale", ), Call( [ [ Symbol( "\"C\"", ), ], ], ), ], line: 74, }, ], ], ), ], line: 72, }, Variable { names: [ ( "T", false, ), ( "print", false, ), ( "format", false, ), ( "write", false, ), ( "assert", false, ), ( "type", false, ), ( "unpack", false, ), ( "floor", false, ), ], values: [ [ Ident { expr: [ Symbol( "T", ), ], line: 76, }, ], [ Ident { expr: [ Symbol( "print", ), ], line: 77, }, ], [ Ident { expr: [ Symbol( "string", ), Symbol( ".", ), Symbol( "format", ), ], line: 77, }, ], [ Ident { expr: [ Symbol( "io", ), Symbol( ".", ), Symbol( "write", ), ], line: 77, }, ], [ Ident { expr: [ Symbol( "assert", ), ], line: 77, }, ], [ Ident { expr: [ Symbol( "type", ), ], line: 77, }, ], [ Ident { expr: [ Symbol( "table", ), Symbol( ".", ), Symbol( "unpack", ), ], line: 77, }, ], [ Ident { expr: [ Symbol( "math", ), Symbol( ".", ), Symbol( "floor", ), ], line: 77, }, ], ], line: 80, column: 0, }, Function { local: true, name: [ Symbol( "F", ), ], args: [ "m", ], body: CodeBlock { start: 92, code: [ Function { local: true, name: [ Symbol( "round", ), ], args: [ "m", ], body: CodeBlock { start: 6, code: [ Alter { names: [ Ident { expr: [ Symbol( "m", ), ], line: 82, }, ], values: [ [ Ident { expr: [ Symbol( "m", ), ], line: 82, }, Operator( ( "+", true, ), ), Symbol( "0.04999", ), ], ], line: 83, column: 0, }, Return( Some( [ [ Ident { expr: [ Symbol( "format", ), Call( [ [ Symbol( "\"%.1f\"", ), ], [ Ident { expr: [ Symbol( "m", ), ], line: 83, }, ], ], ), ], line: 83, }, ], ], ), ), ], end: 19, }, line: 84, column: 1, }, IfStatement { condition: [ Ident { expr: [ Symbol( "m", ), ], line: 85, }, Operator( ( "<", true, ), ), Symbol( "1000", ), ], body: CodeBlock { start: 24, code: [ Return( Some( [ [ Ident { expr: [ Symbol( "m", ), ], line: 85, }, ], ], ), ), ], end: 27, }, next: Some( IfStatement { condition: [], body: CodeBlock { start: 27, code: [ Alter { names: [ Ident { expr: [ Symbol( "m", ), ], line: 87, }, ], values: [ [ Ident { expr: [ Symbol( "m", ), ], line: 87, }, Operator( ( "/", true, ), ), Symbol( "1000", ), ], ], line: 88, column: 0, }, IfStatement { condition: [ Ident { expr: [ Symbol( "m", ), ], line: 88, }, Operator( ( "<", true, ), ), Symbol( "1000", ), ], body: CodeBlock { start: 10, code: [ Return( Some( [ [ Ident { expr: [ Symbol( "round", ), Call( [ [ Ident { expr: [ Symbol( "m", ), ], line: 88, }, ], ], ), ], line: 88, }, Operator( ( "..", true, ), ), Symbol( "\"K\"", ), ], ], ), ), ], end: 18, }, next: Some( IfStatement { condition: [], body: CodeBlock { start: 18, code: [ Return( Some( [ [ Ident { expr: [ Symbol( "round", ), Call( [ [ Ident { expr: [ Symbol( "m", ), ], line: 90, }, Operator( ( "/", true, ), ), Symbol( "1000", ), ], ], ), ], line: 90, }, Operator( ( "..", true, ), ), Symbol( "\"M\"", ), ], ], ), ), ], end: 28, }, next: None, line: 91, column: 1, }, ), line: 91, column: 1, }, ], end: 56, }, next: None, line: 92, column: 1, }, ), line: 92, column: 1, }, ], end: 149, }, line: 93, column: 1, }, Variable { names: [ ( "showmem", false, ), ], values: [], line: 95, column: 2, }, IfStatement { condition: [ Operator( ( "not", false, ), ), Ident { expr: [ Symbol( "T", ), ], line: 96, }, ], body: CodeBlock { start: 155, code: [ Variable { names: [ ( "max", false, ), ], values: [ [ Symbol( "0", ), ], ], line: 97, column: 4, }, Alter { names: [ Ident { expr: [ Symbol( "showmem", ), ], line: 97, }, ], values: [ [ Lambda { args: [], body: CodeBlock { start: 9, code: [ Variable { names: [ ( "m", false, ), ], values: [ [ Ident { expr: [ Symbol( "collectgarbage", ), Call( [ [ Symbol( "\"count\"", ), ], ], ), ], line: 99, }, Operator( ( "*", true, ), ), Symbol( "1024", ), ], ], line: 99, column: 9, }, Alter { names: [ Ident { expr: [ Symbol( "max", ), ], line: 99, }, ], values: [ [ Expr( [ Ident { expr: [ Symbol( "m", ), ], line: 100, }, Operator( ( ">", true, ), ), Ident { expr: [ Symbol( "max", ), ], line: 100, }, ], ), Ident { expr: [], line: 100, }, Operator( ( "and", true, ), ), Ident { expr: [ Symbol( "m", ), ], line: 100, }, Operator( ( "or", true, ), ), Ident { expr: [ Symbol( "max", ), ], line: 100, }, ], ], line: 100, column: 11, }, Ident { expr: [ Symbol( "print", ), Call( [ [ Ident { expr: [ Symbol( "format", ), Call( [ [ Symbol( "\" ---- total memory: %s, max memory: %s ----\\n\"", ), ], [ Ident { expr: [ Symbol( "F", ), Call( [ [ Ident { expr: [ Symbol( "m", ), ], line: 102, }, ], ], ), ], line: 101, }, ], [ Ident { expr: [ Symbol( "F", ), Call( [ [ Ident { expr: [ Symbol( "max", ), ], line: 102, }, ], ], ), ], line: 102, }, ], ], ), ], line: 101, }, ], ], ), ], line: 100, }, ], end: 47, }, line: 103, column: 1, }, ], ], line: 103, column: 1, }, ], end: 203, }, next: Some( IfStatement { condition: [], body: CodeBlock { start: 203, code: [ Alter { names: [ Ident { expr: [ Symbol( "showmem", ), ], line: 105, }, ], values: [ [ Lambda { args: [], body: CodeBlock { start: 5, code: [ Ident { expr: [ Symbol( "T", ), Symbol( ".", ), Symbol( "checkmemory", ), Call( [], ), ], line: 106, }, Variable { names: [ ( "total", false, ), ( "numblocks", false, ), ( "maxmem", false, ), ], values: [ [ Ident { expr: [ Symbol( "T", ), Symbol( ".", ), Symbol( "totalmem", ), Call( [], ), ], line: 107, }, ], ], line: 108, column: 0, }, Variable { names: [ ( "count", false, ), ], values: [ [ Ident { expr: [ Symbol( "collectgarbage", ), Call( [ [ Symbol( "\"count\"", ), ], ], ), ], line: 108, }, ], ], line: 108, column: 7, }, Ident { expr: [ Symbol( "print", ), Call( [ [ Ident { expr: [ Symbol( "format", ), Call( [ [ Symbol( "\"\\n ---- total memory: %s (%.0fK), max use: %s, blocks: %d\\n\"", ), ], [ Ident { expr: [ Symbol( "F", ), Call( [ [ Ident { expr: [ Symbol( "total", ), ], line: 111, }, ], ], ), ], line: 110, }, ], [ Ident { expr: [ Symbol( "count", ), ], line: 111, }, ], [ Ident { expr: [ Symbol( "F", ), Call( [ [ Ident { expr: [ Symbol( "maxmem", ), ], line: 111, }, ], ], ), ], line: 111, }, ], [ Ident { expr: [ Symbol( "numblocks", ), ], line: 111, }, ], ], ), ], line: 109, }, ], ], ), ], line: 108, }, Ident { expr: [ Symbol( "print", ), Call( [ [ Ident { expr: [ Symbol( "format", ), Call( [ [ Symbol( "\"\\t(strings: %d, tables: %d, functions: %d, \"", ), Operator( ( "..", true, ), ), Symbol( "\"\\n\\tudata: %d, threads: %d)\"", ), ], [ Ident { expr: [ Symbol( "T", ), Symbol( ".", ), Symbol( "totalmem", ), Call( [ [ Symbol( "\"string\"", ), ], ], ), ], line: 113, }, ], [ Ident { expr: [ Symbol( "T", ), Symbol( ".", ), Symbol( "totalmem", ), Call( [ [ Symbol( "\"table\"", ), ], ], ), ], line: 114, }, ], [ Ident { expr: [ Symbol( "T", ), Symbol( ".", ), Symbol( "totalmem", ), Call( [ [ Symbol( "\"function\"", ), ], ], ), ], line: 114, }, ], [ Ident { expr: [ Symbol( "T", ), Symbol( ".", ), Symbol( "totalmem", ), Call( [ [ Symbol( "\"userdata\"", ), ], ], ), ], line: 114, }, ], [ Ident { expr: [ Symbol( "T", ), Symbol( ".", ), Symbol( "totalmem", ), Call( [ [ Symbol( "\"thread\"", ), ], ], ), ], line: 115, }, ], ], ), ], line: 112, }, ], ], ), ], line: 111, }, ], end: 85, }, line: 116, column: 1, }, ], ], line: 116, column: 1, }, ], end: 289, }, next: None, line: 117, column: 1, }, ), line: 117, column: 1, }, Function { local: true, name: [ Symbol( "report", ), ], args: [ "n", ], body: CodeBlock { start: 295, code: [ Ident { expr: [ Symbol( "print", ), Call( [ [ Symbol( "\"\\n***** FILE '\"", ), Operator( ( "..", true, ), ), Ident { expr: [ Symbol( "n", ), ], line: 123, }, Operator( ( "..", true, ), ), Symbol( "\"'*****\"", ), ], ], ), ], line: 123, }, ], end: 304, }, line: 123, column: 15, }, Variable { names: [ ( "olddofile", false, ), ], values: [ [ Ident { expr: [ Symbol( "dofile", ), ], line: 124, }, ], ], line: 125, column: 0, }, Variable { names: [ ( "dofile", false, ), ], values: [ [ Lambda { args: [ "n", "strip", ], body: CodeBlock { start: 317, code: [ Ident { expr: [ Symbol( "showmem", ), Call( [], ), ], line: 126, }, Variable { names: [ ( "c", false, ), ], values: [ [ Ident { expr: [ Symbol( "os", ), Symbol( ".", ), Symbol( "clock", ), Call( [], ), ], line: 127, }, ], ], line: 127, column: 8, }, Ident { expr: [ Symbol( "print", ), Call( [ [ Ident { expr: [ Symbol( "string", ), Symbol( ".", ), Symbol( "format", ), Call( [ [ Symbol( "\"time: %g (+%g)\"", ), ], [ Ident { expr: [ Symbol( "c", ), ], line: 128, }, Operator( ( "-", true, ), ), Ident { expr: [ Symbol( "initclock", ), ], line: 128, }, ], [ Ident { expr: [ Symbol( "c", ), ], line: 128, }, Operator( ( "-", true, ), ), Ident { expr: [ Symbol( "lastclock", ), ], line: 128, }, ], ], ), ], line: 128, }, ], ], ), ], line: 127, }, Alter { names: [ Ident { expr: [ Symbol( "lastclock", ), ], line: 128, }, ], values: [ [ Ident { expr: [ Symbol( "c", ), ], line: 129, }, ], ], line: 129, column: 3, }, Ident { expr: [ Symbol( "report", ), Call( [ [ Ident { expr: [ Symbol( "n", ), ], line: 130, }, ], ], ), ], line: 129, }, Variable { names: [ ( "f", false, ), ], values: [ [ Ident { expr: [ Symbol( "assert", ), Call( [ [ Ident { expr: [ Symbol( "loadfile", ), Call( [ [ Ident { expr: [ Symbol( "n", ), ], line: 131, }, ], ], ), ], line: 131, }, ], ], ), ], line: 131, }, ], ], line: 132, column: 0, }, Variable { names: [ ( "b", false, ), ], values: [ [ Ident { expr: [ Symbol( "string", ), Symbol( ".", ), Symbol( "dump", ), Call( [ [ Ident { expr: [ Symbol( "f", ), ], line: 132, }, ], [ Ident { expr: [ Symbol( "strip", ), ], line: 132, }, ], ], ), ], line: 132, }, ], ], line: 132, column: 11, }, Alter { names: [ Ident { expr: [ Symbol( "f", ), ], line: 132, }, ], values: [ [ Ident { expr: [ Symbol( "assert", ), Call( [ [ Ident { expr: [ Symbol( "load", ), Call( [ [ Ident { expr: [ Symbol( "b", ), ], line: 133, }, ], ], ), ], line: 133, }, ], ], ), ], line: 133, }, ], ], line: 134, column: 0, }, Return( Some( [ [ Ident { expr: [ Symbol( "f", ), Call( [], ), ], line: 134, }, ], ], ), ), ], end: 387, }, line: 135, column: 1, }, ], ], line: 135, column: 1, }, Ident { expr: [ Symbol( "dofile", ), Call( [ [ Symbol( "'main.lua'", ), ], ], ), ], line: 135, }, DoBlock( CodeBlock { start: 392, code: [ Variable { names: [ ( "next", false, ), ( "setmetatable", false, ), ( "stderr", false, ), ], values: [ [ Ident { expr: [ Symbol( "next", ), ], line: 140, }, ], [ Ident { expr: [ Symbol( "setmetatable", ), ], line: 140, }, ], [ Ident { expr: [ Symbol( "io", ), Symbol( ".", ), Symbol( "stderr", ), ], line: 140, }, ], ], line: 142, column: 0, }, Variable { names: [ ( "mt", false, ), ], values: [ [ Table { data: [], line: 142, column: 5, }, ], ], line: 142, column: 5, }, Alter { names: [ Ident { expr: [ Symbol( "mt", ), Symbol( ".", ), Symbol( "__gc", ), ], line: 142, }, ], values: [ [ Lambda { args: [ "o", ], body: CodeBlock { start: 27, code: [ Ident { expr: [ Symbol( "stderr", ), Symbol( ":", ), Symbol( "write", ), Call( [ [ Symbol( "'.'", ), ], ], ), ], line: 146, }, Variable { names: [ ( "n", false, ), ], values: [ [ Ident { expr: [ Symbol( "setmetatable", ), Call( [ [ Ident { expr: [ Symbol( "o", ), ], line: 147, }, ], [ Ident { expr: [ Symbol( "mt", ), ], line: 147, }, ], ], ), ], line: 147, }, ], ], line: 147, column: 9, }, ], end: 41, }, line: 148, column: 1, }, ], ], line: 149, column: 0, }, Variable { names: [ ( "n", false, ), ], values: [ [ Ident { expr: [ Symbol( "setmetatable", ), Call( [ [ Table { data: [], line: 149, column: 7, }, ], [ Ident { expr: [ Symbol( "mt", ), ], line: 149, }, ], ], ), ], line: 149, }, ], ], line: 149, column: 10, }, ], end: 444, }, ), Ident { expr: [ Symbol( "report", ), Call( [ [ Symbol( "\"gc.lua\"", ), ], ], ), ], line: 150, }, Variable { names: [ ( "f", false, ), ], values: [ [ Ident { expr: [ Symbol( "assert", ), Call( [ [ Ident { expr: [ Symbol( "loadfile", ), Call( [ [ Symbol( "'gc.lua'", ), ], ], ), ], line: 153, }, ], ], ), ], line: 153, }, ], ], line: 153, column: 10, }, Ident { expr: [ Symbol( "f", ), Call( [], ), ], line: 153, }, Ident { expr: [ Symbol( "dofile", ), Call( [ [ Symbol( "'db.lua'", ), ], ], ), ], line: 154, }, Ident { expr: [ Symbol( "assert", ), Call( [ [ Ident { expr: [ Symbol( "dofile", ), Call( [ [ Symbol( "'calls.lua'", ), ], ], ), ], line: 157, }, Operator( ( "==", true, ), ), Ident { expr: [ Symbol( "deep", ), ], line: 157, }, Operator( ( "and", true, ), ), Ident { expr: [ Symbol( "deep", ), ], line: 157, }, ], ], ), ], line: 156, }, Ident { expr: [ Symbol( "olddofile", ), Call( [ [ Symbol( "'strings.lua'", ), ], ], ), ], line: 157, }, Ident { expr: [ Symbol( "olddofile", ), Call( [ [ Symbol( "'literals.lua'", ), ], ], ), ], line: 158, }, Ident { expr: [ Symbol( "dofile", ), Call( [ [ Symbol( "'tpack.lua'", ), ], ], ), ], line: 159, }, Ident { expr: [ Symbol( "assert", ), Call( [ [ Ident { expr: [ Symbol( "dofile", ), Call( [ [ Symbol( "'attrib.lua'", ), ], ], ), ], line: 161, }, Operator( ( "==", true, ), ), Symbol( "27", ), ], ], ), ], line: 160, }, Ident { expr: [ Symbol( "assert", ), Call( [ [ Ident { expr: [ Symbol( "dofile", ), Call( [ [ Symbol( "'locals.lua'", ), ], ], ), ], line: 163, }, Operator( ( "==", true, ), ), Symbol( "5", ), ], ], ), ], line: 161, }, Ident { expr: [ Symbol( "dofile", ), Call( [ [ Symbol( "'constructs.lua'", ), ], ], ), ], line: 163, }, Ident { expr: [ Symbol( "dofile", ), Call( [ [ Symbol( "'code.lua'", ), ], [ Symbol( "true", ), ], ], ), ], line: 164, }, IfStatement { condition: [ Operator( ( "not", false, ), ), Ident { expr: [ Symbol( "_G", ), Symbol( ".", ), Symbol( "_soft", ), ], line: 166, }, ], body: CodeBlock { start: 520, code: [ Ident { expr: [ Symbol( "report", ), Call( [ [ Symbol( "'big.lua'", ), ], ], ), ], line: 167, }, Variable { names: [ ( "f", false, ), ], values: [ [ Ident { expr: [ Symbol( "coroutine", ), Symbol( ".", ), Symbol( "wrap", ), Call( [ [ Ident { expr: [ Symbol( "assert", ), Call( [ [ Ident { expr: [ Symbol( "loadfile", ), Call( [ [ Symbol( "'big.lua'", ), ], ], ), ], line: 168, }, ], ], ), ], line: 168, }, ], ], ), ], line: 168, }, ], ], line: 168, column: 15, }, Ident { expr: [ Symbol( "assert", ), Call( [ [ Ident { expr: [ Symbol( "f", ), Call( [], ), ], line: 169, }, Operator( ( "==", true, ), ), Symbol( "'b'", ), ], ], ), ], line: 168, }, Ident { expr: [ Symbol( "assert", ), Call( [ [ Ident { expr: [ Symbol( "f", ), Call( [], ), ], line: 170, }, Operator( ( "==", true, ), ), Symbol( "'a'", ), ], ], ), ], line: 169, }, ], end: 556, }, next: None, line: 171, column: 1, }, Ident { expr: [ Symbol( "dofile", ), Call( [ [ Symbol( "'nextvar.lua'", ), ], ], ), ], line: 171, }, Ident { expr: [ Symbol( "dofile", ), Call( [ [ Symbol( "'pm.lua'", ), ], ], ), ], line: 172, }, Ident { expr: [ Symbol( "dofile", ), Call( [ [ Symbol( "'utf8.lua'", ), ], ], ), ], line: 173, }, Ident { expr: [ Symbol( "dofile", ), Call( [ [ Symbol( "'api.lua'", ), ], ], ), ], line: 174, }, Ident { expr: [ Symbol( "assert", ), Call( [ [ Ident { expr: [ Symbol( "dofile", ), Call( [ [ Symbol( "'events.lua'", ), ], ], ), ], line: 176, }, Operator( ( "==", true, ), ), Symbol( "12", ), ], ], ), ], line: 175, }, Ident { expr: [ Symbol( "dofile", ), Call( [ [ Symbol( "'vararg.lua'", ), ], ], ), ], line: 176, }, Ident { expr: [ Symbol( "dofile", ), Call( [ [ Symbol( "'closure.lua'", ), ], ], ), ], line: 177, }, Ident { expr: [ Symbol( "dofile", ), Call( [ [ Symbol( "'coroutine.lua'", ), ], ], ), ], line: 178, }, Ident { expr: [ Symbol( "dofile", ), Call( [ [ Symbol( "'goto.lua'", ), ], [ Symbol( "true", ), ], ], ), ], line: 179, }, Ident { expr: [ Symbol( "dofile", ), Call( [ [ Symbol( "'errors.lua'", ), ], ], ), ], line: 180, }, Ident { expr: [ Symbol( "dofile", ), Call( [ [ Symbol( "'math.lua'", ), ], ], ), ], line: 181, }, Ident { expr: [ Symbol( "dofile", ), Call( [ [ Symbol( "'sort.lua'", ), ], [ Symbol( "true", ), ], ], ), ], line: 182, }, Ident { expr: [ Symbol( "dofile", ), Call( [ [ Symbol( "'bitwise.lua'", ), ], ], ), ], line: 183, }, Ident { expr: [ Symbol( "assert", ), Call( [ [ Ident { expr: [ Symbol( "dofile", ), Call( [ [ Symbol( "'verybig.lua'", ), ], [ Symbol( "true", ), ], ], ), ], line: 185, }, Operator( ( "==", true, ), ), Symbol( "10", ), ], ], ), ], line: 184, }, Ident { expr: [ Symbol( "collectgarbage", ), Call( [], ), ], line: 185, }, Ident { expr: [ Symbol( "dofile", ), Call( [ [ Symbol( "'files.lua'", ), ], ], ), ], line: 185, }, IfStatement { condition: [ Operator( ( "#", false, ), ), Ident { expr: [ Symbol( "msgs", ), ], line: 188, }, Operator( ( ">", true, ), ), Symbol( "0", ), ], body: CodeBlock { start: 642, code: [ Ident { expr: [ Symbol( "print", ), Call( [ [ Symbol( "\"\\ntests not performed:\"", ), ], ], ), ], line: 189, }, ForLoop { iter: "i", start: [ Symbol( "1", ), ], end: [ Operator( ( "#", false, ), ), Ident { expr: [ Symbol( "msgs", ), ], line: 190, }, ], step: None, code: CodeBlock { start: 12, code: [ Ident { expr: [ Symbol( "print", ), Call( [ [ Ident { expr: [ Symbol( "msgs", ), Symbol( "[", ), Expr( [ Ident { expr: [ Symbol( "i", ), ], line: 191, }, ], ), Symbol( "]", ), ], line: 191, }, ], ], ), ], line: 191, }, ], end: 20, }, line: 192, column: 1, }, Ident { expr: [ Symbol( "print", ), Call( [], ), ], line: 192, }, ], end: 666, }, next: None, line: 194, column: 1, }, Ident { expr: [ Symbol( "assert", ), Call( [ [ Ident { expr: [ Symbol( "debug", ), ], line: 197, }, Operator( ( "==", true, ), ), Symbol( "nil", ), ], ], ), ], line: 194, }, Variable { names: [ ( "debug", false, ), ], values: [ [ Ident { expr: [ Symbol( "require", ), Call( [ [ Symbol( "\"debug\"", ), ], ], ), ], line: 199, }, ], ], line: 199, column: 5, }, Ident { expr: [ Symbol( "print", ), Call( [ [ Ident { expr: [ Symbol( "string", ), Symbol( ".", ), Symbol( "format", ), Call( [ [ Symbol( "\"%d-bit integers, %d-bit floats\"", ), ], [ Ident { expr: [ Symbol( "string", ), Symbol( ".", ), Symbol( "packsize", ), Call( [ [ Symbol( "\"j\"", ), ], ], ), ], line: 201, }, Operator( ( "*", true, ), ), Symbol( "8", ), ], [ Ident { expr: [ Symbol( "string", ), Symbol( ".", ), Symbol( "packsize", ), Call( [ [ Symbol( "\"n\"", ), ], ], ), ], line: 202, }, Operator( ( "*", true, ), ), Symbol( "8", ), ], ], ), ], line: 201, }, ], ], ), ], line: 199, }, Ident { expr: [ Symbol( "debug", ), Symbol( ".", ), Symbol( "sethook", ), Call( [ [ Lambda { args: [ "a", ], body: CodeBlock { start: 712, code: [ Ident { expr: [ Symbol( "assert", ), Call( [ [ Ident { expr: [ Symbol( "type", ), Call( [ [ Ident { expr: [ Symbol( "a", ), ], line: 204, }, ], ], ), ], line: 204, }, Operator( ( "==", true, ), ), Symbol( "'string'", ), ], ], ), ], line: 204, }, ], end: 722, }, line: 204, column: 18, }, ], [ Symbol( "\"cr\"", ), ], ], ), ], line: 202, }, Alter { names: [ Ident { expr: [ Symbol( "_G", ), Symbol( ".", ), Symbol( "showmem", ), ], line: 204, }, ], values: [ [ Ident { expr: [ Symbol( "showmem", ), ], line: 207, }, ], ], line: 207, column: 5, }, ], end: 875, }, ), Variable { names: [ ( "_G", false, ), ( "showmem", false, ), ( "print", false, ), ( "format", false, ), ( "clock", false, ), ( "time", false, ), ( "difftime", false, ), ( "assert", false, ), ( "open", false, ), ], values: [ [ Ident { expr: [ Symbol( "_G", ), ], line: 211, }, ], [ Ident { expr: [ Symbol( "showmem", ), ], line: 212, }, ], [ Ident { expr: [ Symbol( "print", ), ], line: 212, }, ], [ Ident { expr: [ Symbol( "string", ), Symbol( ".", ), Symbol( "format", ), ], line: 212, }, ], [ Ident { expr: [ Symbol( "os", ), Symbol( ".", ), Symbol( "clock", ), ], line: 212, }, ], [ Ident { expr: [ Symbol( "os", ), Symbol( ".", ), Symbol( "time", ), ], line: 212, }, ], [ Ident { expr: [ Symbol( "os", ), Symbol( ".", ), Symbol( "difftime", ), ], line: 212, }, ], [ Ident { expr: [ Symbol( "assert", ), ], line: 212, }, ], [ Ident { expr: [ Symbol( "io", ), Symbol( ".", ), Symbol( "open", ), ], line: 213, }, ], ], line: 216, column: 0, }, Variable { names: [ ( "fname", false, ), ], values: [ [ Ident { expr: [ Symbol( "T", ), ], line: 216, }, Operator( ( "and", true, ), ), Symbol( "\"time-debug.txt\"", ), Operator( ( "or", true, ), ), Symbol( "\"time.txt\"", ), ], ], line: 217, column: 0, }, Variable { names: [ ( "lasttime", false, ), ], values: [], line: 217, column: 2, }, IfStatement { condition: [ Operator( ( "not", false, ), ), Ident { expr: [ Symbol( "usertests", ), ], line: 219, }, ], body: CodeBlock { start: 935, code: [ Variable { names: [ ( "f", false, ), ], values: [ [ Ident { expr: [ Symbol( "io", ), Symbol( ".", ), Symbol( "open", ), Call( [ [ Ident { expr: [ Symbol( "fname", ), ], line: 221, }, ], ], ), ], line: 221, }, ], ], line: 222, column: 0, }, IfStatement { condition: [ Ident { expr: [ Symbol( "f", ), ], line: 222, }, ], body: CodeBlock { start: 12, code: [ Alter { names: [ Ident { expr: [ Symbol( "lasttime", ), ], line: 223, }, ], values: [ [ Ident { expr: [ Symbol( "assert", ), Call( [ [ Ident { expr: [ Symbol( "tonumber", ), Call( [ [ Ident { expr: [ Symbol( "f", ), Symbol( ":", ), Symbol( "read", ), Call( [ [ Symbol( "'a'", ), ], ], ), ], line: 223, }, ], ], ), ], line: 223, }, ], ], ), ], line: 223, }, ], ], line: 223, column: 12, }, Ident { expr: [ Symbol( "f", ), Symbol( ":", ), Symbol( "close", ), Call( [], ), ], line: 223, }, ], end: 31, }, next: Some( IfStatement { condition: [], body: CodeBlock { start: 31, code: [ Alter { names: [ Ident { expr: [ Symbol( "lasttime", ), ], line: 226, }, ], values: [ [ Symbol( "nil", ), ], ], line: 226, column: 3, }, ], end: 35, }, next: None, line: 227, column: 1, }, ), line: 227, column: 1, }, ], end: 971, }, next: None, line: 228, column: 1, }, Ident { expr: [ Symbol( "print", ), Call( [ [ Symbol( "'cleaning all!!!!'", ), ], ], ), ], line: 228, }, ForFuncLoop { iters: [ "n", ], expr: [ Ident { expr: [ Symbol( "pairs", ), Call( [ [ Ident { expr: [ Symbol( "_G", ), ], line: 232, }, ], ], ), ], line: 232, }, ], stop: None, initial: None, code: CodeBlock { start: 983, code: [ IfStatement { condition: [ Operator( ( "not", false, ), ), Expr( [ Table { data: [ ( Some( [ Symbol( "___Glob", ), ], ), [ Symbol( "1", ), ], ), ( Some( [ Symbol( "tostring", ), ], ), [ Symbol( "1", ), ], ), ], line: 233, column: 12, }, ], ), Ident { expr: [ Symbol( "[", ), Expr( [ Ident { expr: [ Symbol( "n", ), ], line: 233, }, ], ), Symbol( "]", ), ], line: 233, }, ], body: CodeBlock { start: 17, code: [ Alter { names: [ Ident { expr: [ Symbol( "_G", ), Symbol( "[", ), Expr( [ Ident { expr: [ Symbol( "n", ), ], line: 234, }, ], ), Symbol( "]", ), ], line: 234, }, ], values: [ [ Symbol( "nil", ), ], ], line: 234, column: 6, }, ], end: 24, }, next: None, line: 235, column: 1, }, ], end: 1008, }, line: 236, column: 1, }, Ident { expr: [ Symbol( "collectgarbage", ), Call( [], ), ], line: 236, }, Ident { expr: [ Symbol( "collectgarbage", ), Call( [], ), ], line: 239, }, Ident { expr: [ Symbol( "collectgarbage", ), Call( [], ), ], line: 240, }, Ident { expr: [ Symbol( "collectgarbage", ), Call( [], ), ], line: 241, }, Ident { expr: [ Symbol( "collectgarbage", ), Call( [], ), ], line: 242, }, Ident { expr: [ Symbol( "collectgarbage", ), Call( [], ), ], line: 243, }, Ident { expr: [ Symbol( "showmem", ), Call( [], ), ], line: 244, }, Variable { names: [ ( "clocktime", false, ), ], values: [ [ Ident { expr: [ Symbol( "clock", ), Call( [], ), ], line: 246, }, Operator( ( "-", true, ), ), Ident { expr: [ Symbol( "initclock", ), ], line: 246, }, ], ], line: 246, column: 8, }, Alter { names: [ Ident { expr: [ Symbol( "walltime", ), ], line: 246, }, ], values: [ [ Ident { expr: [ Symbol( "difftime", ), Call( [ [ Ident { expr: [ Symbol( "time", ), Call( [], ), ], line: 247, }, ], [ Ident { expr: [ Symbol( "walltime", ), ], line: 247, }, ], ], ), ], line: 247, }, ], ], line: 247, column: 10, }, Ident { expr: [ Symbol( "print", ), Call( [ [ Ident { expr: [ Symbol( "format", ), Call( [ [ Symbol( "\"\\n\\ntotal time: %.2fs (wall time: %gs)\\n\"", ), ], [ Ident { expr: [ Symbol( "clocktime", ), ], line: 249, }, ], [ Ident { expr: [ Symbol( "walltime", ), ], line: 249, }, ], ], ), ], line: 249, }, ], ], ), ], line: 247, }, IfStatement { condition: [ Operator( ( "not", false, ), ), Ident { expr: [ Symbol( "usertests", ), ], line: 251, }, ], body: CodeBlock { start: 1063, code: [ Alter { names: [ Ident { expr: [ Symbol( "lasttime", ), ], line: 252, }, ], values: [ [ Ident { expr: [ Symbol( "lasttime", ), ], line: 252, }, Operator( ( "or", true, ), ), Ident { expr: [ Symbol( "clocktime", ), ], line: 252, }, ], ], line: 254, column: 0, }, Variable { names: [ ( "diff", false, ), ], values: [ [ Expr( [ Ident { expr: [ Symbol( "clocktime", ), ], line: 254, }, Operator( ( "-", true, ), ), Ident { expr: [ Symbol( "lasttime", ), ], line: 254, }, ], ), Ident { expr: [], line: 254, }, Operator( ( "/", true, ), ), Ident { expr: [ Symbol( "lasttime", ), ], line: 254, }, ], ], line: 255, column: 0, }, Variable { names: [ ( "tolerance", false, ), ], values: [ [ Symbol( "0.05", ), ], ], line: 256, column: 0, }, IfStatement { condition: [ Expr( [ Ident { expr: [ Symbol( "diff", ), ], line: 256, }, Operator( ( ">=", true, ), ), Ident { expr: [ Symbol( "tolerance", ), ], line: 256, }, Operator( ( "or", true, ), ), Ident { expr: [ Symbol( "diff", ), ], line: 256, }, Operator( ( "<=", true, ), ), Operator( ( "-", false, ), ), Ident { expr: [ Symbol( "tolerance", ), ], line: 256, }, ], ), Ident { expr: [], line: 256, }, ], body: CodeBlock { start: 31, code: [ Ident { expr: [ Symbol( "print", ), Call( [ [ Ident { expr: [ Symbol( "format", ), Call( [ [ Symbol( "\"WARNING: time difference from previous test: %+.1f%%\"", ), ], [ Ident { expr: [ Symbol( "diff", ), ], line: 257, }, Operator( ( "*", true, ), ), Symbol( "100", ), ], ], ), ], line: 257, }, ], ], ), ], line: 257, }, ], end: 43, }, next: None, line: 259, column: 1, }, Ident { expr: [ Symbol( "assert", ), Call( [ [ Ident { expr: [ Symbol( "open", ), Call( [ [ Ident { expr: [ Symbol( "fname", ), ], line: 260, }, ], [ Symbol( "\"w\"", ), ], ], ), ], line: 260, }, ], ], ), Symbol( ":", ), Symbol( "write", ), Call( [ [ Ident { expr: [ Symbol( "clocktime", ), ], line: 260, }, ], ], ), Symbol( ":", ), Symbol( "close", ), Call( [], ), ], line: 259, }, ], end: 1125, }, next: None, line: 261, column: 1, }, Ident { expr: [ Symbol( "print", ), Call( [ [ Symbol( "\"final OK !!!\"", ), ], ], ), ], line: 261, }, ]