feat(tvix/cli): set up tracing[-subscriber]

No otlp yet, this simply gives us structured log output and a cli
argument for the log level.

Change-Id: Ifaa60bae419640e92baebb6ee59eedd775c769c2
Reviewed-on: https://cl.tvl.fyi/c/depot/+/10853
Reviewed-by: raitobezarius <tvl@lahfa.xyz>
Tested-by: BuildkiteCI
Autosubmit: flokli <flokli@flokli.de>
This commit is contained in:
Florian Klink 2024-02-14 08:56:31 +07:00 committed by clbot
parent 87bda3ae7a
commit d293304667
4 changed files with 26 additions and 1 deletions

1
tvix/Cargo.lock generated
View file

@ -3317,6 +3317,7 @@ dependencies = [
"thiserror",
"tokio",
"tracing",
"tracing-subscriber",
"tvix-build",
"tvix-castore",
"tvix-eval",

View file

@ -10380,6 +10380,11 @@ rec {
name = "tracing";
packageId = "tracing";
}
{
name = "tracing-subscriber";
packageId = "tracing-subscriber";
features = [ "json" ];
}
{
name = "tvix-build";
packageId = "tvix-build";

View file

@ -19,8 +19,9 @@ clap = { version = "4.0", features = ["derive", "env"] }
dirs = "4.0.0"
rustyline = "10.0.0"
thiserror = "1.0.38"
tracing = "0.1.37"
tokio = "1.28.0"
tracing = "0.1.37"
tracing-subscriber = { version = "0.3.16", features = ["json"] }
[dependencies.wu-manber]
git = "https://github.com/tvlfyi/wu-manber.git"

View file

@ -2,6 +2,9 @@ use clap::Parser;
use rustyline::{error::ReadlineError, Editor};
use std::rc::Rc;
use std::{fs, path::PathBuf};
use tracing::Level;
use tracing_subscriber::fmt::writer::MakeWriterExt;
use tracing_subscriber::{layer::SubscriberExt, util::SubscriberInitExt};
use tvix_build::buildservice;
use tvix_eval::builtins::impure_builtins;
use tvix_eval::observer::{DisassemblingObserver, TracingObserver};
@ -12,6 +15,9 @@ use tvix_glue::{builtins::add_derivation_builtins, configure_nix_path};
#[derive(Parser)]
struct Args {
#[arg(long)]
log_level: Option<Level>,
/// Path to a script to evaluate
script: Option<PathBuf>,
@ -213,6 +219,18 @@ fn lint(code: &str, path: Option<PathBuf>, args: &Args) -> bool {
fn main() {
let args = Args::parse();
// configure log settings
let level = args.log_level.unwrap_or(Level::INFO);
let subscriber = tracing_subscriber::registry().with(
tracing_subscriber::fmt::Layer::new()
.with_writer(std::io::stderr.with_max_level(level))
.pretty(),
);
subscriber
.try_init()
.expect("unable to set up tracing subscriber");
if let Some(file) = &args.script {
run_file(file.clone(), &args)
} else if let Some(expr) = &args.expr {