From ed5908d00e810b7ba7b504a471cd2aa12c88f952 Mon Sep 17 00:00:00 2001 From: Vurv <56230599+Vurv78@users.noreply.github.com> Date: Tue, 21 Nov 2023 16:08:03 -0800 Subject: [PATCH] Better error message for dyncall without type --- lua/entities/gmod_wire_expression2/base/compiler.lua | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/lua/entities/gmod_wire_expression2/base/compiler.lua b/lua/entities/gmod_wire_expression2/base/compiler.lua index 82c80ed9ed..86737b128d 100644 --- a/lua/entities/gmod_wire_expression2/base/compiler.lua +++ b/lua/entities/gmod_wire_expression2/base/compiler.lua @@ -133,7 +133,7 @@ end ---@param trace Trace ---@return T function Compiler:Assert(v, message, trace) - if not v then error(Error.new(message, trace), 0) end + if not v then self:Error(message, trace) end return v end @@ -1613,7 +1613,6 @@ local CompileVisitors = { local name, args, types = data[1], {}, {} for k, arg in ipairs(data[2]) do args[k], types[k] = self:CompileExpr(arg) - self:Assert(types[k], "Cannot use void expression as call argument", arg.trace) end local arg_sig = table.concat(types) @@ -2054,7 +2053,13 @@ end function Compiler:CompileExpr(node) assert(node.trace, "Incomplete node: " .. tostring(node)) local op, ty = assert(CompileVisitors[node.variant], "Unimplemented Compile Step: " .. node:instr())(self, node.trace, node.data, false) - self:Assert(ty, "Cannot use void in expression position", node.trace) + + if node.variant == NodeVariant.ExprDynCall then + self:Assert(ty, "Cannot use void in expression position ( Did you mean Call()[type] ? )", node.trace) + else + self:Assert(ty, "Cannot use void in expression position", node.trace) + end + return op, ty end