Tạo dbg màu tùy chỉnh! Macro In Rust

Jan 20 2021

Tôi muốn tạo một macro tùy chỉnh tương tự như dbg tiêu chuẩn ! macro , nhưng với tùy chọn sử dụng màu thông qua thùng màu . dbg! thường in thứ gì đó với định dạng

[path_to_file:line_number] "symbol name" = "symbol value"
//[src/gallery/image_slot.rs:231] "my_integer_value_of_12" = "12"
  1. Làm cách nào để truy cập số đường dẫn / dòng [path_to_file:line_number]để tôi có thể in nó?
  2. Làm cách nào để truy cập vào tên ký hiệu của một biến? (tức là in đã my_varcho my_var = 12)

Trả lời

5 vallentin Jan 20 2021 at 02:00
  1. Sử dụng file!, line!và column!macro.
  2. Sử dụng stringify!macro.

Nếu bạn đi tới tài liệu của dbg!macro, bạn có thể nhấp vào [src] , hiển thị việc triển khai dbg!, như sau:

macro_rules! dbg {
    () => {
        $crate::eprintln!("[{}:{}]", $crate::file!(), $crate::line!()); }; ($val:expr $(,)?) => { // Use of `match` here is intentional because it affects the lifetimes // of temporaries - https://stackoverflow.com/a/48732525/1063961 match $val {
            tmp => {
                $crate::eprintln!("[{}:{}] {} = {:#?}", $crate::file!(), $crate::line!(), $crate::stringify!($val), &tmp); tmp } } }; ($($val:expr),+ $(,)?) => {
        ($($crate::dbg!($val)),+,)
    };
}

Sử dụng điều đó, chúng tôi có thể dễ dàng tạo một colored_dbg!macro tương tự , với coloredthùng như bạn đã đề xuất.

(Tôi chỉ chọn màu ngẫu nhiên, để làm ví dụ đơn giản)

// colored = "2.0"
use colored::Colorize;

macro_rules! colored_dbg {
    () => {
        eprintln!("{}", format!("[{}:{}]", file!(), line!()).green());
    };
    ($val:expr $(,)?) => { match $val {
            tmp => {
                eprintln!("{} {} = {}",
                    format!("[{}:{}]", file!(), line!()).green(),
                    stringify!($val).red(), format!("{:#?}", &tmp).blue(), ); tmp } } }; ($($val:expr),+ $(,)?) => {
        ($(colored_dbg!($val)),+,)
    };
}

Bạn sẽ sử dụng nó giống như cách bạn có thể sử dụng dbg!:

fn main() {
    let my_var = 12;
    colored_dbg!(&my_var);

    let v = vec!["foo", "bar", "baz"];
    let v = colored_dbg!(v);
}

Kết quả nào sau đây: