1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49
|
auto TraceLogger::construct() -> void {
setCollapsible();
setVisible(false);
tracerLabel.setText("Trace Logger").setFont(Font().setBold());
tracerList.onToggle([&](auto item) { eventToggle(item); });
selectAllButton.setText("Select All").onActivate([&] {
for(auto item : tracerList.items()) {
if(item.checked()) continue;
item.setChecked(true);
eventToggle(item);
}
});
unselectAllButton.setText("Unselect All").onActivate([&] {
for(auto item : tracerList.items()) {
if(!item.checked()) continue;
item.setChecked(false);
eventToggle(item);
}
});
traceToTerminal.setText("Trace To Terminal");
traceToFile.setText("Trace To File");
traceMask.setText("Mask").onToggle([&] {
for(auto instruction : ares::Node::enumerate<ares::Node::Debugger::Tracer::Instruction>(emulator->root)) {
instruction->setMask(traceMask.checked());
}
});
}
auto TraceLogger::reload() -> void {
tracerList.reset();
for(auto tracer : ares::Node::enumerate<ares::Node::Debugger::Tracer::Tracer>(emulator->root)) {
ListViewItem item{&tracerList};
item.setAttribute<ares::Node::Debugger::Tracer::Tracer>("tracer", tracer);
item.setCheckable();
item.setText({tracer->component(), " ", tracer->name()});
}
}
auto TraceLogger::unload() -> void {
tracerList.reset();
if(fp) fp.close();
}
auto TraceLogger::eventToggle(ListViewItem item) -> void {
if(auto tracer = item.attribute<ares::Node::Debugger::Tracer::Tracer>("tracer")) {
tracer->setEnabled(item.checked());
}
}
|