fix(tvix/eval): emit warnings from builtins.import again

Wires up generator logic to emit warnings that already have spans
attached again.

Change-Id: I9f878cec3b9d4f6f7819e7c71bab7ae70bd3f08b
Reviewed-on: https://cl.tvl.fyi/c/depot/+/8224
Tested-by: BuildkiteCI
Reviewed-by: raitobezarius <tvl@lahfa.xyz>
This commit is contained in:
Vincent Ambo 2023-03-06 17:23:17 +03:00 committed by tazjin
parent 43b0416bd8
commit 5d9bfd7735
3 changed files with 35 additions and 14 deletions

View file

@ -923,7 +923,8 @@ mod pure_builtins {
#[builtin("placeholder")] #[builtin("placeholder")]
async fn builtin_placeholder(co: GenCo, #[lazy] _x: Value) -> Result<Value, ErrorKind> { async fn builtin_placeholder(co: GenCo, #[lazy] _x: Value) -> Result<Value, ErrorKind> {
generators::emit_warning(&co, WarningKind::NotImplemented("builtins.placeholder")).await; generators::emit_warning_kind(&co, WarningKind::NotImplemented("builtins.placeholder"))
.await;
Ok("<builtins.placeholder-is-not-implemented-in-tvix-yet>".into()) Ok("<builtins.placeholder-is-not-implemented-in-tvix-yet>".into())
} }
@ -1017,7 +1018,7 @@ mod placeholder_builtins {
#[lazy] _context: Value, #[lazy] _context: Value,
#[lazy] val: Value, #[lazy] val: Value,
) -> Result<Value, ErrorKind> { ) -> Result<Value, ErrorKind> {
generators::emit_warning(&co, WarningKind::NotImplemented("builtins.addErrorContext")) generators::emit_warning_kind(&co, WarningKind::NotImplemented("builtins.addErrorContext"))
.await; .await;
Ok(val) Ok(val)
} }
@ -1028,7 +1029,7 @@ mod placeholder_builtins {
_name: Value, _name: Value,
_attrset: Value, _attrset: Value,
) -> Result<Value, ErrorKind> { ) -> Result<Value, ErrorKind> {
generators::emit_warning( generators::emit_warning_kind(
&co, &co,
WarningKind::NotImplemented("builtins.unsafeGetAttrsPos"), WarningKind::NotImplemented("builtins.unsafeGetAttrsPos"),
) )

View file

@ -77,10 +77,9 @@ async fn import_impl(
}); });
} }
// TODO: emit not just the warning kind, hmm for warning in result.warnings {
// for warning in result.warnings { generators::emit_warning(&co, warning).await;
// vm.push_warning(warning); }
// }
// Compilation succeeded, we can construct a thunk from whatever it spat // Compilation succeeded, we can construct a thunk from whatever it spat
// out and return that. // out and return that.

View file

@ -15,7 +15,7 @@ use std::fmt::Display;
use std::future::Future; use std::future::Future;
use crate::value::{PointerEquality, SharedThunkSet}; use crate::value::{PointerEquality, SharedThunkSet};
use crate::warnings::WarningKind; use crate::warnings::{EvalWarning, WarningKind};
use crate::FileType; use crate::FileType;
use crate::NixString; use crate::NixString;
@ -85,8 +85,12 @@ pub enum GeneratorRequest {
light_span: LightSpan, light_span: LightSpan,
}, },
/// Emit a runtime warning through the VM. Receives a NoOp-response. /// Emit a runtime warning (already containing a span) through the VM.
EmitWarning(WarningKind), EmitWarning(EvalWarning),
/// Emit a runtime warning through the VM. The span of the current generator
/// is used for the final warning.
EmitWarningKind(WarningKind),
/// Request a lookup in the VM's import cache, which tracks the /// Request a lookup in the VM's import cache, which tracks the
/// thunks yielded by previously imported files. /// thunks yielded by previously imported files.
@ -150,6 +154,7 @@ impl Display for GeneratorRequest {
write!(f, "enter_lambda({:p})", *lambda) write!(f, "enter_lambda({:p})", *lambda)
} }
GeneratorRequest::EmitWarning(_) => write!(f, "emit_warning"), GeneratorRequest::EmitWarning(_) => write!(f, "emit_warning"),
GeneratorRequest::EmitWarningKind(_) => write!(f, "emit_warning_kind"),
GeneratorRequest::ImportCacheLookup(p) => { GeneratorRequest::ImportCacheLookup(p) => {
write!(f, "import_cache_lookup({})", p.to_string_lossy()) write!(f, "import_cache_lookup({})", p.to_string_lossy())
} }
@ -374,7 +379,12 @@ impl<'o> VM<'o> {
return Ok(false); return Ok(false);
} }
GeneratorRequest::EmitWarning(kind) => { GeneratorRequest::EmitWarning(warning) => {
self.push_warning(warning);
message = GeneratorResponse::Empty;
}
GeneratorRequest::EmitWarningKind(kind) => {
self.emit_warning(kind); self.emit_warning(kind);
message = GeneratorResponse::Empty; message = GeneratorResponse::Empty;
} }
@ -611,9 +621,20 @@ pub(crate) async fn check_equality(
} }
} }
/// Emit a runtime warning. /// Emit a fully constructed runtime warning.
pub(crate) async fn emit_warning(co: &GenCo, kind: WarningKind) { pub(crate) async fn emit_warning(co: &GenCo, warning: EvalWarning) {
match co.yield_(GeneratorRequest::EmitWarning(kind)).await { match co.yield_(GeneratorRequest::EmitWarning(warning)).await {
GeneratorResponse::Empty => {}
msg => panic!(
"Tvix bug: VM responded with incorrect generator message: {}",
msg
),
}
}
/// Emit a runtime warning with the span of the current generator.
pub(crate) async fn emit_warning_kind(co: &GenCo, kind: WarningKind) {
match co.yield_(GeneratorRequest::EmitWarningKind(kind)).await {
GeneratorResponse::Empty => {} GeneratorResponse::Empty => {}
msg => panic!( msg => panic!(
"Tvix bug: VM responded with incorrect generator message: {}", "Tvix bug: VM responded with incorrect generator message: {}",