Skip to content

Commit

Permalink
Unrot and re-enable run-pass-fulldeps/qquote.rs
Browse files Browse the repository at this point in the history
  • Loading branch information
tamird committed Apr 23, 2015
1 parent 1114fcd commit 4a608e8
Showing 1 changed file with 39 additions and 57 deletions.
96 changes: 39 additions & 57 deletions src/test/run-pass-fulldeps/qquote.rs
Original file line number Diff line number Diff line change
Expand Up @@ -9,86 +9,68 @@
// except according to those terms.

// ignore-pretty
// ignore-test

#![feature(quote)]
#![feature(quote, rustc_private)]

extern crate syntax;

use std::io::*;

use syntax::diagnostic;
use syntax::ast;
use syntax::codemap;
use syntax::codemap::span;
use syntax::parse;
use syntax::print::*;


trait fake_ext_ctxt {
fn cfg() -> ast::CrateConfig;
fn parse_sess() -> parse::parse_sess;
fn call_site() -> span;
fn ident_of(st: &str) -> ast::ident;
use syntax::print::pprust;

trait FakeExtCtxt {
fn call_site(&self) -> codemap::Span;
fn cfg(&self) -> ast::CrateConfig;
fn ident_of(&self, st: &str) -> ast::Ident;
fn name_of(&self, st: &str) -> ast::Name;
fn parse_sess(&self) -> &parse::ParseSess;
}

type fake_session = parse::parse_sess;

impl fake_ext_ctxt for fake_session {
fn cfg() -> ast::CrateConfig { Vec::new() }
fn parse_sess() -> parse::parse_sess { self }
fn call_site() -> span {
codemap::span {
impl FakeExtCtxt for parse::ParseSess {
fn call_site(&self) -> codemap::Span {
codemap::Span {
lo: codemap::BytePos(0),
hi: codemap::BytePos(0),
expn_id: codemap::NO_EXPANSION
expn_id: codemap::NO_EXPANSION,
}
}
fn ident_of(st: &str) -> ast::ident {
self.interner.intern(st)
fn cfg(&self) -> ast::CrateConfig { Vec::new() }
fn ident_of(&self, st: &str) -> ast::Ident {
parse::token::str_to_ident(st)
}
}

fn mk_ctxt() -> fake_ext_ctxt {
parse::new_parse_sess(None) as fake_ext_ctxt
fn name_of(&self, st: &str) -> ast::Name {
parse::token::intern(st)
}
fn parse_sess(&self) -> &parse::ParseSess { self }
}

fn main() {
let cx = mk_ctxt();

let abc = quote_expr!(cx, 23);
check_pp(ext_cx, abc, pprust::print_expr, "23".to_string());
let cx = parse::new_parse_sess();

quote_ty!(&cx, isize).and_then(|ty| {
assert_eq!(pprust::ty_to_string(&ty), "isize")
});

let ty = quote_ty!(cx, isize);
check_pp(ext_cx, ty, pprust::print_type, "isize".to_string());

let item = quote_item!(cx, static x : isize = 10;).get();
check_pp(ext_cx, item, pprust::print_item, "static x: isize = 10;".to_string());
quote_pat!(&cx, Some(_)).and_then(|pat| {
assert_eq!(pprust::pat_to_string(&pat), "Some(_)")
});

let stmt = quote_stmt!(cx, let x = 20;);
check_pp(ext_cx, *stmt, pprust::print_stmt, "let x = 20;".to_string());
let arm = quote_arm!(&cx, (ref x, ref y) => (x, y),);
assert_eq!(pprust::arm_to_string(&arm), " (ref x, ref y) => (x, y),");

let pat = quote_pat!(cx, Some(_));
check_pp(ext_cx, pat, pprust::print_pat, "Some(_)".to_string());
quote_expr!(&cx, 23).and_then(|expr| {
assert_eq!(pprust::expr_to_string(&expr), "23")
});

let arm = quote_arm!(cx, (ref x, ref y) => (x, y));
check_pp(ext_cx, arm, pprust::print_stmt, "(ref x, ref y) = (x, y)".to_string());
quote_stmt!(&cx, let x = 20;).unwrap().and_then(|stmt| {
assert_eq!(pprust::stmt_to_string(&stmt), "let x = 20;")
});

let attr = quote_attr!(cx, #![cfg(foo = "bar")]);
check_pp(ext_cx, attr, pprust::print_attribute, "#![cfg(foo = "bar")]".to_string());
}
let attr = quote_attr!(&cx, #![cfg(foo = "bar")]);
assert_eq!(pprust::attr_to_string(&attr), "#![cfg(foo = \"bar\")]");

fn check_pp<T>(cx: fake_ext_ctxt,
expr: T, f: |pprust::ps, T|, expect: String) {
let s = io::with_str_writer(|wr| {
let pp = pprust::rust_printer(wr, cx.parse_sess().interner);
f(pp, expr);
pp::eof(pp.s);
quote_item!(&cx, static x : isize = 10;).unwrap().and_then(|item| {
assert_eq!(pprust::item_to_string(&item), "static x: isize = 10;")
});
stdout().write_line(s);
if expect != "".to_string() {
println!("expect: '%s', got: '%s'", expect, s);
assert_eq!(s, expect);
}
}

0 comments on commit 4a608e8

Please sign in to comment.