You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
103 lines
2.8 KiB
Rust
103 lines
2.8 KiB
Rust
5 years ago
|
// SPDX-License-Identifier: MIT OR Apache-2.0
|
||
|
//
|
||
|
// Copyright (c) 2018-2019 Andre Richter <andre.o.richter@gmail.com>
|
||
|
|
||
|
//! Printing facilities.
|
||
|
|
||
|
use crate::{bsp, interface};
|
||
|
use core::fmt;
|
||
|
|
||
|
#[doc(hidden)]
|
||
|
pub fn _print(args: fmt::Arguments) {
|
||
|
use interface::console::Write;
|
||
|
|
||
|
bsp::console().write_fmt(args).unwrap();
|
||
|
}
|
||
|
|
||
|
/// Prints without a newline.
|
||
|
///
|
||
|
/// Carbon copy from https://doc.rust-lang.org/src/std/macros.rs.html
|
||
|
#[macro_export]
|
||
|
macro_rules! print {
|
||
|
($($arg:tt)*) => ($crate::print::_print(format_args!($($arg)*)));
|
||
|
}
|
||
|
|
||
|
/// Prints with a newline.
|
||
|
///
|
||
|
/// Carbon copy from https://doc.rust-lang.org/src/std/macros.rs.html
|
||
|
#[macro_export]
|
||
|
macro_rules! println {
|
||
|
() => ($crate::print!("\n"));
|
||
|
($($arg:tt)*) => ({
|
||
|
$crate::print::_print(format_args_nl!($($arg)*));
|
||
|
})
|
||
|
}
|
||
|
|
||
|
/// Prints an info, with newline.
|
||
|
#[macro_export]
|
||
|
macro_rules! info {
|
||
|
($string:expr) => ({
|
||
|
#[allow(unused_imports)]
|
||
|
use crate::interface::time::Timer;
|
||
|
|
||
|
let timestamp = $crate::arch::timer().uptime();
|
||
|
let timestamp_subsec_us = timestamp.subsec_micros();
|
||
|
|
||
|
$crate::print::_print(format_args_nl!(
|
||
|
concat!("[ {:>3}.{:03}{:03}] ", $string),
|
||
|
timestamp.as_secs(),
|
||
|
timestamp_subsec_us / 1_000,
|
||
|
timestamp_subsec_us % 1_000
|
||
|
));
|
||
|
});
|
||
|
($format_string:expr, $($arg:tt)*) => ({
|
||
|
#[allow(unused_imports)]
|
||
|
use crate::interface::time::Timer;
|
||
|
|
||
|
let timestamp = $crate::arch::timer().uptime();
|
||
|
let timestamp_subsec_us = timestamp.subsec_micros();
|
||
|
|
||
|
$crate::print::_print(format_args_nl!(
|
||
|
concat!("[ {:>3}.{:03}{:03}] ", $format_string),
|
||
|
timestamp.as_secs(),
|
||
|
timestamp_subsec_us / 1_000,
|
||
|
timestamp_subsec_us % 1_000,
|
||
|
$($arg)*
|
||
|
));
|
||
|
})
|
||
|
}
|
||
|
|
||
|
/// Prints a warning, with newline.
|
||
|
#[macro_export]
|
||
|
macro_rules! warn {
|
||
|
($string:expr) => ({
|
||
|
#[allow(unused_imports)]
|
||
|
use crate::interface::time::Timer;
|
||
|
|
||
|
let timestamp = $crate::arch::timer().uptime();
|
||
|
let timestamp_subsec_us = timestamp.subsec_micros();
|
||
|
|
||
|
$crate::print::_print(format_args_nl!(
|
||
|
concat!("[W {:>3}.{:03}{:03}] ", $string),
|
||
|
timestamp.as_secs(),
|
||
|
timestamp_subsec_us / 1_000,
|
||
|
timestamp_subsec_us % 1_000
|
||
|
));
|
||
|
});
|
||
|
($format_string:expr, $($arg:tt)*) => ({
|
||
|
#[allow(unused_imports)]
|
||
|
use crate::interface::time::Timer;
|
||
|
|
||
|
let timestamp = $crate::arch::timer().uptime();
|
||
|
let timestamp_subsec_us = timestamp.subsec_micros();
|
||
|
|
||
|
$crate::print::_print(format_args_nl!(
|
||
|
concat!("[W {:>3}.{:03}{:03}] ", $format_string),
|
||
|
timestamp.as_secs(),
|
||
|
timestamp_subsec_us / 1_000,
|
||
|
timestamp_subsec_us % 1_000,
|
||
|
$($arg)*
|
||
|
));
|
||
|
})
|
||
|
}
|