This is the documentation page for Module:Protect

This metamodule simplifies error handling in other modules. It transforms a function, which may throw an error, into a function, which returns a specified error message in that case.

UsageEdit

 local protect = require('Module:Protect')
 local protectedFunc = protect(func, errFormat, options)

ArgumentsEdit

Return valueEdit

The resulting Template:Code is a function, which calls the original function Template:Code, passing all arguments to it, and returns all its return values. If Template:Code throws an error, the specified error message is returned instead.

ExampleEdit

local protect = require('Module:Protect')

local p = {}

function p.main(frame)
    if not frame.args[1] then
        error('missing argument')
    end
    return frame.args[1]
end

p.main = protect(p.main)

return p

Invoking the main function without arguments will output: Error: missing argument