-- This Script is Part of the Prometheus Obfuscator by levno-710 -- -- pass_self_function_call.lua -- -- This Script contains the expression handler for the PassSelfFunctionCallExpression. 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 args = { self:register(scope, baseReg) }; local regs = { baseReg }; 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 or numReturns > 1 then local tmpReg = self:allocRegister(false); self:addStatement(self:setRegister(scope, tmpReg, Ast.StringExpression(expression.passSelfFunctionName)), {tmpReg}, {}, false); self:addStatement(self:setRegister(scope, tmpReg, Ast.IndexExpression(self:register(scope, baseReg), self:register(scope, tmpReg))), {tmpReg}, {baseReg, tmpReg}, false); if returnAll then self:addStatement(self:setRegister(scope, retRegs[1], Ast.TableConstructorExpression{Ast.TableEntry(Ast.FunctionCallExpression(self:register(scope, tmpReg), args))}), {retRegs[1]}, {tmpReg, unpack(regs)}, true); else self:addStatement(self:setRegister(scope, tmpReg, Ast.TableConstructorExpression{Ast.TableEntry(Ast.FunctionCallExpression(self:register(scope, tmpReg), args))}), {tmpReg}, {tmpReg, 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 end self:freeRegister(tmpReg, false); else local tmpReg = retRegs[1] or self:allocRegister(false); self:addStatement(self:setRegister(scope, tmpReg, Ast.StringExpression(expression.passSelfFunctionName)), {tmpReg}, {}, false); self:addStatement(self:setRegister(scope, tmpReg, Ast.IndexExpression(self:register(scope, baseReg), self:register(scope, tmpReg))), {tmpReg}, {baseReg, tmpReg}, false); self:addStatement(self:setRegister(scope, retRegs[1], Ast.FunctionCallExpression(self:register(scope, tmpReg), args)), {retRegs[1]}, {baseReg, unpack(regs)}, true); end for i, reg in ipairs(regs) do self:freeRegister(reg, false); end return retRegs; end;