// 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 #[no_uv]; extern crate native; use std::fmt; use std::io::{PortReader, ChanWriter}; use std::logging::{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 (p, c) = Chan::new(); let (mut r, w) = (PortReader::new(p), ChanWriter::new(c)); spawn(proc() { set_logger(~MyWriter(w) as ~Logger); debug!("debug"); info!("info"); }); assert_eq!(r.read_to_str().unwrap(), ~"info\n"); }