make sim::Compiler not print things to stdout unless you ask for it #10

Merged
programmerjake merged 1 commit from programmerjake/fayalite:make_sim_stdout_less_verbose into master 2024-12-19 05:28:51 +00:00

View file

@ -1601,6 +1601,14 @@ impl MakeTraceDeclTarget {
} }
} }
struct DebugOpaque<T>(T);
impl<T> fmt::Debug for DebugOpaque<T> {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
f.write_str("<...>")
}
}
#[derive(Debug)] #[derive(Debug)]
pub struct Compiler { pub struct Compiler {
insns: Insns<InsnsBuilding>, insns: Insns<InsnsBuilding>,
@ -1622,6 +1630,7 @@ pub struct Compiler {
registers: Vec<Register>, registers: Vec<Register>,
traces: SimTraces<Vec<SimTrace<SimTraceKind, ()>>>, traces: SimTraces<Vec<SimTrace<SimTraceKind, ()>>>,
memories: Vec<Memory>, memories: Vec<Memory>,
dump_assignments_dot: Option<DebugOpaque<Box<dyn Fn(&dyn fmt::Debug)>>>,
} }
impl Compiler { impl Compiler {
@ -1647,8 +1656,14 @@ impl Compiler {
registers: Vec::new(), registers: Vec::new(),
traces: SimTraces(Vec::new()), traces: SimTraces(Vec::new()),
memories: Vec::new(), memories: Vec::new(),
dump_assignments_dot: None,
} }
} }
#[doc(hidden)]
/// This is explicitly unstable and may be changed/removed at any time
pub fn dump_assignments_dot(&mut self, callback: Box<dyn Fn(&dyn fmt::Debug)>) {
self.dump_assignments_dot = Some(DebugOpaque(callback));
}
fn new_sim_trace(&mut self, kind: SimTraceKind) -> TraceScalarId { fn new_sim_trace(&mut self, kind: SimTraceKind) -> TraceScalarId {
let id = TraceScalarId(self.traces.0.len()); let id = TraceScalarId(self.traces.0.len());
self.traces.0.push(SimTrace { self.traces.0.push(SimTrace {
@ -4650,12 +4665,11 @@ impl Compiler {
fn process_assignments(&mut self) { fn process_assignments(&mut self) {
self.assignments self.assignments
.finalize(self.insns.state_layout().ty.clone().into()); .finalize(self.insns.state_layout().ty.clone().into());
println!( if let Some(DebugOpaque(dump_assignments_dot)) = &self.dump_assignments_dot {
"{:#?}", let graph =
petgraph::dot::Dot::new(&petgraph::graph::DiGraph::<_, _, usize>::from_elements( petgraph::graph::DiGraph::<_, _, usize>::from_elements(self.assignments.elements());
self.assignments.elements() dump_assignments_dot(&petgraph::dot::Dot::new(&graph));
)) }
);
let assignments_order: Vec<_> = match petgraph::algo::toposort(&self.assignments, None) { let assignments_order: Vec<_> = match petgraph::algo::toposort(&self.assignments, None) {
Ok(nodes) => nodes Ok(nodes) => nodes
.into_iter() .into_iter()