// Copyright 2014 The Rust Project Developers. See the COPYRIGHT // file at the top-level directory of this distribution and at // http://rust-lang.org/COPYRIGHT. // // Licensed under the Apache License, Version 2.0 or the MIT license // , at your // option. This file may not be copied, modified, or distributed // except according to those terms. // ignore-fast // ignore-android (FIXME #11419) // exec-env:RUST_LOG=info #[feature(phase)]; #[phase(syntax, link)] extern crate log; extern crate native; use std::fmt; use std::io::{ChanReader, ChanWriter}; use log::{set_logger, Logger}; struct MyWriter(ChanWriter); impl Logger for MyWriter { fn log(&mut self, _level: u32, args: &fmt::Arguments) { let MyWriter(ref mut inner) = *self; fmt::writeln(inner as &mut Writer, args); } } #[start] fn start(argc: int, argv: **u8) -> int { native::start(argc, argv, proc() { main(); }) } fn main() { let (tx, rx) = channel(); let (mut r, w) = (ChanReader::new(rx), ChanWriter::new(tx)); spawn(proc() { set_logger(~MyWriter(w) as ~Logger:Send); debug!("debug"); info!("info"); }); assert_eq!(r.read_to_str().unwrap(), ~"info\n"); }