Refactor pprust a bit.

This commit is contained in:
Eduard Burtescu 2014-03-16 20:58:11 +02:00
parent 871e570810
commit e02aa722aa
4 changed files with 2177 additions and 2302 deletions

View File

@ -595,33 +595,36 @@ pub fn compile_input(sess: Session, cfg: ast::CrateConfig, input: &Input,
struct IdentifiedAnnotation; struct IdentifiedAnnotation;
impl pprust::PpAnn for IdentifiedAnnotation { impl pprust::PpAnn for IdentifiedAnnotation {
fn pre(&self, node: pprust::AnnNode) -> io::IoResult<()> { fn pre(&self,
s: &mut pprust::State<IdentifiedAnnotation>,
node: pprust::AnnNode) -> io::IoResult<()> {
match node { match node {
pprust::NodeExpr(s, _) => pprust::popen(s), pprust::NodeExpr(_) => s.popen(),
_ => Ok(()) _ => Ok(())
} }
} }
fn post(&self, node: pprust::AnnNode) -> io::IoResult<()> { fn post(&self,
s: &mut pprust::State<IdentifiedAnnotation>,
node: pprust::AnnNode) -> io::IoResult<()> {
match node { match node {
pprust::NodeItem(s, item) => { pprust::NodeItem(item) => {
try!(pp::space(&mut s.s)); try!(pp::space(&mut s.s));
try!(pprust::synth_comment(s, item.id.to_str())); s.synth_comment(item.id.to_str())
} }
pprust::NodeBlock(s, blk) => { pprust::NodeBlock(blk) => {
try!(pp::space(&mut s.s)); try!(pp::space(&mut s.s));
try!(pprust::synth_comment(s, ~"block " + blk.id.to_str())); s.synth_comment(~"block " + blk.id.to_str())
} }
pprust::NodeExpr(s, expr) => { pprust::NodeExpr(expr) => {
try!(pp::space(&mut s.s)); try!(pp::space(&mut s.s));
try!(pprust::synth_comment(s, expr.id.to_str())); try!(s.synth_comment(expr.id.to_str()));
try!(pprust::pclose(s)); s.pclose()
} }
pprust::NodePat(s, pat) => { pprust::NodePat(pat) => {
try!(pp::space(&mut s.s)); try!(pp::space(&mut s.s));
try!(pprust::synth_comment(s, ~"pat " + pat.id.to_str())); s.synth_comment(~"pat " + pat.id.to_str())
} }
} }
Ok(())
} }
} }
@ -630,26 +633,29 @@ struct TypedAnnotation {
} }
impl pprust::PpAnn for TypedAnnotation { impl pprust::PpAnn for TypedAnnotation {
fn pre(&self, node: pprust::AnnNode) -> io::IoResult<()> { fn pre(&self,
s: &mut pprust::State<TypedAnnotation>,
node: pprust::AnnNode) -> io::IoResult<()> {
match node { match node {
pprust::NodeExpr(s, _) => pprust::popen(s), pprust::NodeExpr(_) => s.popen(),
_ => Ok(()) _ => Ok(())
} }
} }
fn post(&self, node: pprust::AnnNode) -> io::IoResult<()> { fn post(&self,
s: &mut pprust::State<TypedAnnotation>,
node: pprust::AnnNode) -> io::IoResult<()> {
let tcx = &self.analysis.ty_cx; let tcx = &self.analysis.ty_cx;
match node { match node {
pprust::NodeExpr(s, expr) => { pprust::NodeExpr(expr) => {
try!(pp::space(&mut s.s)); try!(pp::space(&mut s.s));
try!(pp::word(&mut s.s, "as")); try!(pp::word(&mut s.s, "as"));
try!(pp::space(&mut s.s)); try!(pp::space(&mut s.s));
try!(pp::word(&mut s.s, try!(pp::word(&mut s.s,
ppaux::ty_to_str(tcx, ty::expr_ty(tcx, expr)))); ppaux::ty_to_str(tcx, ty::expr_ty(tcx, expr))));
try!(pprust::pclose(s)); s.pclose()
} }
_ => () _ => Ok(())
} }
Ok(())
} }
} }
@ -670,34 +676,48 @@ pub fn pretty_print_input(sess: Session,
_ => (krate, None, false) _ => (krate, None, false)
}; };
let codemap = sess.codemap; let src_name = source_name(input);
let span_diagnostic = sess.span_diagnostic; let src = sess.codemap().get_filemap(src_name).deref().src.as_bytes().to_owned();
let mut rdr = MemReader::new(src);
let annotation = match ppm { match ppm {
PpmIdentified | PpmExpandedIdentified => { PpmIdentified | PpmExpandedIdentified => {
~IdentifiedAnnotation as ~pprust::PpAnn pprust::print_crate(sess.codemap(),
sess.diagnostic(),
&krate,
src_name,
&mut rdr,
~io::stdout(),
&IdentifiedAnnotation,
is_expanded)
} }
PpmTyped => { PpmTyped => {
let ast_map = ast_map.expect("--pretty=typed missing ast_map"); let ast_map = ast_map.expect("--pretty=typed missing ast_map");
let analysis = phase_3_run_analysis_passes(sess, &krate, ast_map); let analysis = phase_3_run_analysis_passes(sess, &krate, ast_map);
~TypedAnnotation { let annotation = TypedAnnotation {
analysis: analysis analysis: analysis
} as ~pprust::PpAnn: };
pprust::print_crate(annotation.analysis.ty_cx.sess.codemap(),
annotation.analysis.ty_cx.sess.diagnostic(),
&krate,
src_name,
&mut rdr,
~io::stdout(),
&annotation,
is_expanded)
} }
_ => ~pprust::NoAnn as ~pprust::PpAnn:, _ => {
}; pprust::print_crate(sess.codemap(),
sess.diagnostic(),
&krate,
src_name,
&mut rdr,
~io::stdout(),
&pprust::NoAnn,
is_expanded)
}
}.unwrap()
let src = &codemap.get_filemap(source_name(input)).src;
let mut rdr = MemReader::new(src.as_bytes().to_owned());
let stdout = io::stdout();
pprust::print_crate(codemap,
span_diagnostic,
&krate,
source_name(input),
&mut rdr,
~stdout as ~io::Writer,
annotation,
is_expanded).unwrap();
} }
pub fn get_os(triple: &str) -> Option<abi::Os> { pub fn get_os(triple: &str) -> Option<abi::Os> {
@ -778,8 +798,7 @@ pub fn host_triple() -> ~str {
(env!("CFG_COMPILER")).to_owned() (env!("CFG_COMPILER")).to_owned()
} }
pub fn build_session_options(matches: &getopts::Matches) pub fn build_session_options(matches: &getopts::Matches) -> session::Options {
-> @session::Options {
let mut crate_types: Vec<CrateType> = Vec::new(); let mut crate_types: Vec<CrateType> = Vec::new();
let unparsed_crate_types = matches.opt_strs("crate-type"); let unparsed_crate_types = matches.opt_strs("crate-type");
for unparsed_crate_type in unparsed_crate_types.iter() { for unparsed_crate_type in unparsed_crate_types.iter() {

View File

@ -84,12 +84,14 @@ struct LoopScope<'a> {
} }
impl<'a, O:DataFlowOperator> pprust::PpAnn for DataFlowContext<'a, O> { impl<'a, O:DataFlowOperator> pprust::PpAnn for DataFlowContext<'a, O> {
fn pre(&self, node: pprust::AnnNode) -> io::IoResult<()> { fn pre(&self,
let (ps, id) = match node { ps: &mut pprust::State<DataFlowContext<'a, O>>,
pprust::NodeExpr(ps, expr) => (ps, expr.id), node: pprust::AnnNode) -> io::IoResult<()> {
pprust::NodeBlock(ps, blk) => (ps, blk.id), let id = match node {
pprust::NodeItem(ps, _) => (ps, 0), pprust::NodeExpr(expr) => expr.id,
pprust::NodePat(ps, pat) => (ps, pat.id) pprust::NodeBlock(blk) => blk.id,
pprust::NodeItem(_) => 0,
pprust::NodePat(pat) => pat.id
}; };
if self.nodeid_to_bitset.contains_key(&id) { if self.nodeid_to_bitset.contains_key(&id) {
@ -111,9 +113,8 @@ impl<'a, O:DataFlowOperator> pprust::PpAnn for DataFlowContext<'a, O> {
~"" ~""
}; };
let comment_str = format!("id {}: {}{}{}", try!(ps.synth_comment(format!("id {}: {}{}{}", id, entry_str,
id, entry_str, gens_str, kills_str); gens_str, kills_str)));
try!(pprust::synth_comment(ps, comment_str));
try!(pp::space(&mut ps.s)); try!(pp::space(&mut ps.s));
} }
Ok(()) Ok(())
@ -351,11 +352,10 @@ impl<'a, O:DataFlowOperator+Clone+'static> DataFlowContext<'a, O> {
fn pretty_print_to(&self, wr: ~io::Writer, fn pretty_print_to(&self, wr: ~io::Writer,
blk: &ast::Block) -> io::IoResult<()> { blk: &ast::Block) -> io::IoResult<()> {
let mut ps = pprust::rust_printer_annotated(wr, self); let mut ps = pprust::rust_printer_annotated(wr, self);
try!(pprust::cbox(&mut ps, pprust::indent_unit)); try!(ps.cbox(pprust::indent_unit));
try!(pprust::ibox(&mut ps, 0u)); try!(ps.ibox(0u));
try!(pprust::print_block(&mut ps, blk)); try!(ps.print_block(blk));
try!(pp::eof(&mut ps.s)); pp::eof(&mut ps.s)
Ok(())
} }
} }

View File

@ -800,7 +800,7 @@ fn compare_impl_method(tcx: &ty::ctxt,
format!("method `{}` has a `{}` declaration in the impl, \ format!("method `{}` has a `{}` declaration in the impl, \
but not in the trait", but not in the trait",
token::get_ident(trait_m.ident), token::get_ident(trait_m.ident),
pprust::explicit_self_to_str(&impl_m.explicit_self))); pprust::explicit_self_to_str(impl_m.explicit_self)));
return; return;
} }
(_, &ast::SelfStatic) => { (_, &ast::SelfStatic) => {
@ -809,7 +809,7 @@ fn compare_impl_method(tcx: &ty::ctxt,
format!("method `{}` has a `{}` declaration in the trait, \ format!("method `{}` has a `{}` declaration in the trait, \
but not in the impl", but not in the impl",
token::get_ident(trait_m.ident), token::get_ident(trait_m.ident),
pprust::explicit_self_to_str(&trait_m.explicit_self))); pprust::explicit_self_to_str(trait_m.explicit_self)));
return; return;
} }
_ => { _ => {

File diff suppressed because it is too large Load Diff