2025-09-28 01:33:58 +09:00
|
|
|
use std::io::Write;
|
2025-09-28 01:39:12 +09:00
|
|
|
use std::sync::atomic::{AtomicU64, Ordering};
|
|
|
|
|
|
|
|
|
|
static EMIT_COUNTER: AtomicU64 = AtomicU64::new(0);
|
2025-09-28 01:33:58 +09:00
|
|
|
|
|
|
|
|
/// Minimal debug hub: JSONL event emitter (dev-only; default OFF).
|
|
|
|
|
///
|
|
|
|
|
/// Env knobs:
|
|
|
|
|
/// - NYASH_DEBUG_ENABLE=1 master gate
|
|
|
|
|
/// - NYASH_DEBUG_KINDS=resolve,ssa allowed cats (comma-separated)
|
|
|
|
|
/// - NYASH_DEBUG_SINK=path file to append JSONL events
|
2025-11-21 06:25:17 +09:00
|
|
|
pub fn emit(
|
|
|
|
|
cat: &str,
|
|
|
|
|
kind: &str,
|
|
|
|
|
fn_name: Option<&str>,
|
|
|
|
|
region_id: Option<&str>,
|
|
|
|
|
meta: serde_json::Value,
|
|
|
|
|
) {
|
2025-09-28 01:33:58 +09:00
|
|
|
if std::env::var("NYASH_DEBUG_ENABLE").ok().as_deref() != Some("1") {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
if let Ok(kinds) = std::env::var("NYASH_DEBUG_KINDS") {
|
|
|
|
|
if !kinds.split(',').any(|k| k.trim().eq_ignore_ascii_case(cat)) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
2025-09-28 01:39:12 +09:00
|
|
|
// Optional sampling: emit every N events (default 1 = no sampling)
|
|
|
|
|
let sample_every = std::env::var("NYASH_DEBUG_SAMPLE_EVERY")
|
|
|
|
|
.ok()
|
|
|
|
|
.and_then(|s| s.parse::<u64>().ok())
|
|
|
|
|
.unwrap_or(1);
|
|
|
|
|
if sample_every > 1 {
|
|
|
|
|
let n = EMIT_COUNTER.fetch_add(1, Ordering::Relaxed) + 1;
|
2025-11-21 06:25:17 +09:00
|
|
|
if n % sample_every != 0 {
|
|
|
|
|
return;
|
|
|
|
|
}
|
2025-09-28 01:39:12 +09:00
|
|
|
}
|
2025-09-28 01:33:58 +09:00
|
|
|
let sink = match std::env::var("NYASH_DEBUG_SINK") {
|
|
|
|
|
Ok(s) if !s.is_empty() => s,
|
|
|
|
|
_ => return,
|
|
|
|
|
};
|
|
|
|
|
let ts = chrono::Utc::now().to_rfc3339_opts(chrono::SecondsFormat::Millis, true);
|
|
|
|
|
let obj = serde_json::json!({
|
|
|
|
|
"ts": ts,
|
|
|
|
|
"phase": "builder",
|
|
|
|
|
"fn": fn_name.unwrap_or("<unknown>"),
|
|
|
|
|
"region_id": region_id.unwrap_or(""),
|
|
|
|
|
"cat": cat,
|
|
|
|
|
"kind": kind,
|
|
|
|
|
"meta": meta,
|
|
|
|
|
});
|
2025-11-21 06:25:17 +09:00
|
|
|
if let Ok(mut f) = std::fs::OpenOptions::new()
|
|
|
|
|
.create(true)
|
|
|
|
|
.append(true)
|
|
|
|
|
.open(&sink)
|
|
|
|
|
{
|
2025-09-28 01:33:58 +09:00
|
|
|
let _ = writeln!(f, "{}", obj.to_string());
|
|
|
|
|
}
|
|
|
|
|
}
|