From 24a0bd8cfb170a002b5266e4dfd3da007b4fc145 Mon Sep 17 00:00:00 2001 From: Laurenz Date: Fri, 27 Oct 2023 15:37:00 +0200 Subject: [PATCH] Fix error priority for function arguments Errors about superfluous arguments are now thrown before errors of the function execution itself. Fixes #1367 --- crates/typst-macros/src/func.rs | 4 ++++ tests/typ/compiler/array.typ | 4 ++++ 2 files changed, 8 insertions(+) diff --git a/crates/typst-macros/src/func.rs b/crates/typst-macros/src/func.rs index 5b8501d0f..b67fb9094 100644 --- a/crates/typst-macros/src/func.rs +++ b/crates/typst-macros/src/func.rs @@ -307,6 +307,9 @@ fn create_wrapper_closure(func: &Func) -> TokenStream { } }; + // Throws errors about unexpected arguments. + let finish = (!func.special.args).then(|| quote! { args.take().finish()?; }); + // This is the actual function call. let call = { let self_ = func @@ -332,6 +335,7 @@ fn create_wrapper_closure(func: &Func) -> TokenStream { |vm, args| { let __typst_func = #parent #ident; #handlers + #finish let output = #call; ::typst::eval::IntoResult::into_result(output, args.span) } diff --git a/tests/typ/compiler/array.typ b/tests/typ/compiler/array.typ index 2ce471587..67b8abc35 100644 --- a/tests/typ/compiler/array.typ +++ b/tests/typ/compiler/array.typ @@ -313,6 +313,10 @@ // Error: 2-26 cannot compare 3em with 2pt #(1pt, 2pt, 3em).sorted() +--- +// Error: 42-52 unexpected argument +#((k: "a", v: 2), (k: "b", v: 1)).sorted(it => it.v) + --- // Error: 2-18 array index out of bounds (index: -4, len: 3) and no default value was specified #(1, 2, 3).at(-4)