salsa-macros 0.26.1

Procedural macros for the salsa crate
Documentation
use std::io::Write;
use std::process::{Command, Stdio};
use std::sync::OnceLock;

use proc_macro2::TokenStream;

static SALSA_DEBUG_MACRO: OnceLock<Option<String>> = OnceLock::new();

pub(crate) fn debug_enabled(input_name: impl ToString) -> bool {
    let Some(env_name) = SALSA_DEBUG_MACRO.get_or_init(|| std::env::var("SALSA_DEBUG_MACRO").ok())
    else {
        return false;
    };

    let input_name = input_name.to_string();
    env_name == "*" || env_name == &input_name[..]
}

pub(crate) fn dump_tokens(input_name: impl ToString, tokens: TokenStream) -> TokenStream {
    if debug_enabled(input_name) {
        let token_string = tokens.to_string();

        let _: Result<(), ()> = Command::new("rustfmt")
            .arg("--emit=stdout")
            .stdin(Stdio::piped())
            .spawn()
            .and_then(|mut rustfmt| {
                rustfmt
                    .stdin
                    .take()
                    .unwrap()
                    .write_all(token_string.as_bytes())?;
                rustfmt.wait_with_output()
            })
            .map(|output| eprintln!("{}", String::from_utf8_lossy(&output.stdout)))
            .or_else(|_| {
                eprintln!("{token_string}");
                Ok(())
            });
    }

    tokens
}