rust/src/bin/miri.rs

63 lines
1.8 KiB
Rust
Raw Normal View History

2016-04-22 07:38:46 -05:00
#![feature(rustc_private, custom_attribute)]
#![allow(unused_attributes)]
2016-05-09 16:30:47 -05:00
extern crate getopts;
extern crate miri;
extern crate rustc;
extern crate rustc_driver;
extern crate env_logger;
extern crate log_settings;
extern crate log;
use miri::interpreter;
use rustc::session::Session;
2016-04-22 03:34:14 -05:00
use rustc_driver::{driver, CompilerCalls};
struct MiriCompilerCalls;
impl<'a> CompilerCalls<'a> for MiriCompilerCalls {
2016-05-09 16:30:47 -05:00
fn build_controller(
&mut self,
_: &Session,
_: &getopts::Matches
) -> driver::CompileController<'a> {
let mut control = driver::CompileController::basic();
control.after_analysis.callback = Box::new(|state| {
state.session.abort_if_errors();
interpreter::interpret_start_points(state.tcx.unwrap(), state.mir_map.unwrap());
});
control
}
}
2016-04-22 07:38:46 -05:00
#[miri_run]
fn main() {
init_logger();
let args: Vec<String> = std::env::args().collect();
rustc_driver::run_compiler(&args, &mut MiriCompilerCalls);
}
#[miri_run]
fn init_logger() {
let format = |record: &log::LogRecord| {
// prepend spaces to indent the final string
let indentation = log_settings::settings().indentation;
let spaces = " ";
let depth = indentation / spaces.len();
let indentation = indentation % spaces.len();
let indentation = &spaces[..indentation];
format!("{}:{}{:2}{} {}", record.level(), record.location().module_path(), depth, indentation, record.args())
};
let mut builder = env_logger::LogBuilder::new();
builder.format(format).filter(None, log::LogLevelFilter::Info);
if std::env::var("MIRI_LOG").is_ok() {
builder.parse(&std::env::var("MIRI_LOG").unwrap());
}
builder.init().unwrap();
}