end
local function printsnap(tr, snap)
- for i=1,#snap do
- local ref = snap[i]
- if not ref then
- out:write("---- ")
- elseif ref < 0 then
- out:write(formatk(tr, ref), " ")
- else
- local m, ot, op1, op2 = traceir(tr, ref)
- local t = band(ot, 15)
- local sep = " "
- if t == 8 then
- local oidx = 6*shr(ot, 8)
- local op = sub(vmdef.irnames, oidx+1, oidx+6)
- if op == "FRAME " then
- sep = "|"
- end
+ local n = 2
+ for s=0,snap[1] do
+ local sn = snap[n]
+ if shr(sn, 24) == s then
+ n = n + 1
+ local ref = band(sn, 0xffff) - 0x8000 -- REF_BIAS
+ if ref < 0 then
+ out:write(formatk(tr, ref))
+ else
+ local m, ot, op1, op2 = traceir(tr, ref)
+ out:write(colorize(format("%04d", ref), band(ot, 15)))
end
- out:write(colorize(format("%04d", ref), t), sep)
+ out:write(band(sn, 0x10000) == 0 and " " or "|") -- SNAP_FRAME
+ else
+ out:write("---- ")
end
end
out:write("]\n")
SnapShot *snap = &T->snap[sn];
SnapEntry *map = &T->snapmap[snap->mapofs];
MSize n, nent = snap->nent;
- BCReg nslots = snap->nslots;
GCtab *t;
- lua_createtable(L, nslots ? (int)nslots : 1, 0);
+ lua_createtable(L, nent+2, 0);
t = tabV(L->top-1);
setintV(lj_tab_setint(L, t, 0), (int32_t)snap->ref - REF_BIAS);
- /* NYI: get rid of this and expose the compressed slot map. */
- {
- BCReg s;
- for (s = 0; s < nslots; s++) {
- TValue *o = lj_tab_setint(L, t, (int32_t)(s+1));
- setboolV(o, 0);
- }
- }
- for (n = 0; n < nent; n++) {
- BCReg s = snap_slot(map[n]);
- IRRef ref = snap_ref(map[n]);
- TValue *o = lj_tab_setint(L, t, (int32_t)(s+1));
- setintV(o, (int32_t)ref - REF_BIAS);
- }
+ setintV(lj_tab_setint(L, t, 1), (int32_t)snap->nslots);
+ for (n = 0; n < nent; n++)
+ setintV(lj_tab_setint(L, t, (int32_t)(n+2)), (int32_t)map[n]);
+ setintV(lj_tab_setint(L, t, (int32_t)(nent+2)), (int32_t)SNAP(255, 0, 0));
return 1;
}
return 0;