-- This Script is Part of the Prometheus Obfuscator by levno-710 -- -- function_call.lua -- -- This Script contains the expression handler for the FunctionCallExpression. local Ast = require("prometheus.ast"); local AstKind = Ast.AstKind; return function(self, expression, funcDepth, numReturns) local scope = self.activeBlock.scope; local baseReg = self:compileExpression(expression.base, funcDepth, 1)[1]; local retRegs = {}; local returnAll = numReturns == self.RETURN_ALL; if returnAll then retRegs[1] = self:allocRegister(false); else for i = 1, numReturns do retRegs[i] = self:allocRegister(false); end end local regs = {}; local args = {}; for i, expr in ipairs(expression.args) do if i == #expression.args and (expr.kind == AstKind.FunctionCallExpression or expr.kind == AstKind.PassSelfFunctionCallExpression or expr.kind == AstKind.VarargExpression) then local reg = self:compileExpression(expr, funcDepth, self.RETURN_ALL)[1]; table.insert(args, Ast.FunctionCallExpression( self:unpack(scope), {self:register(scope, reg)})); table.insert(regs, reg); else local reg = self:compileExpression(expr, funcDepth, 1)[1]; table.insert(args, self:register(scope, reg)); table.insert(regs, reg); end end if returnAll then self:addStatement(self:setRegister(scope, retRegs[1], Ast.TableConstructorExpression{Ast.TableEntry(Ast.FunctionCallExpression(self:register(scope, baseReg), args))}), {retRegs[1]}, {baseReg, unpack(regs)}, true); else if numReturns > 1 then local tmpReg = self:allocRegister(false); self:addStatement(self:setRegister(scope, tmpReg, Ast.TableConstructorExpression{Ast.TableEntry(Ast.FunctionCallExpression(self:register(scope, baseReg), args))}), {tmpReg}, {baseReg, unpack(regs)}, true); for i, reg in ipairs(retRegs) do self:addStatement(self:setRegister(scope, reg, Ast.IndexExpression(self:register(scope, tmpReg), Ast.NumberExpression(i))), {reg}, {tmpReg}, false); end self:freeRegister(tmpReg, false); else self:addStatement(self:setRegister(scope, retRegs[1], Ast.FunctionCallExpression(self:register(scope, baseReg), args)), {retRegs[1]}, {baseReg, unpack(regs)}, true); end end self:freeRegister(baseReg, false); for i, reg in ipairs(regs) do self:freeRegister(reg, false); end return retRegs; end;