ed61c139c2
feed resolver_for_lowering instead of storing it in a field r? `@cjgillot` opening this as * a discussion for `no_hash` + `feedable` queries. I think we'll want those, but I don't quite understand why they are rejected beyond a double check of the stable hashes for situations where the query is fed but also read from incremental caches. * and a discussion on removing all untracked fields from TyCtxt and setting it up so that they are fed queries instead
28 lines
674 B
Rust
28 lines
674 B
Rust
//! This pass just dumps MIR at a specified point.
|
|
|
|
use std::fs::File;
|
|
use std::io;
|
|
|
|
use crate::MirPass;
|
|
use rustc_middle::mir::write_mir_pretty;
|
|
use rustc_middle::mir::Body;
|
|
use rustc_middle::ty::TyCtxt;
|
|
use rustc_session::config::OutputType;
|
|
|
|
pub struct Marker(pub &'static str);
|
|
|
|
impl<'tcx> MirPass<'tcx> for Marker {
|
|
fn name(&self) -> &str {
|
|
self.0
|
|
}
|
|
|
|
fn run_pass(&self, _tcx: TyCtxt<'tcx>, _body: &mut Body<'tcx>) {}
|
|
}
|
|
|
|
pub fn emit_mir(tcx: TyCtxt<'_>) -> io::Result<()> {
|
|
let path = tcx.output_filenames(()).path(OutputType::Mir);
|
|
let mut f = io::BufWriter::new(File::create(&path)?);
|
|
write_mir_pretty(tcx, None, &mut f)?;
|
|
Ok(())
|
|
}
|