--- getting runtime debug information. -- @module debug local debug = {} --- -- Enters an interactive mode with the user, running each string that -- the user enters. Using simple commands and other debug facilities, -- the user can inspect global and local variables, change their values, -- evaluate expressions, and so on. A line containing only the word `cont` -- finishes this function, so that the caller continues its execution. -- Note that commands for `debug.debug` are not lexically nested within any -- function, and so have no direct access to local variables. function debug.debug() end --- -- Returns the environment of object `o`. function debug.getfenv(o) end --- -- Returns the current hook settings of the thread, as three values: the -- current hook function, the current hook mask, and the current hook count -- (as set by the `debug.sethook` function). function debug.gethook(thread) end --- -- Returns a table with information about a function. You can give the -- function directly, or you can give a number as the value of `function`, -- which means the function running at level `function` of the call stack -- of the given thread: level 0 is the current function (`getinfo` itself); -- level 1 is the function that called `getinfo`; and so on. If `function` -- is a number larger than the number of active functions, then `getinfo` -- returns nil. -- -- `thread` and `what` are optional. -- -- The returned table can contain all the fields returned by `lua_getinfo`, -- with the string `what` describing which fields to fill in. The default for -- `what` is to get all information available, except the table of valid -- lines. If present, the option '`f`' adds a field named `func` with -- the function itself. If present, the option '`L`' adds a field named -- `activelines` with the table of valid lines. -- For instance, the expression `debug.getinfo(1,"n").name` returns a table -- with a name for the current function, if a reasonable name can be found, -- and the expression `debug.getinfo(print)` returns a table with all available -- information about the `print` function. function debug.getinfo(thread, func , what) end --- -- This function returns the name and the value of the local variable with -- index `loc` of the function at level `level` of the stack. (The first -- parameter or local variable has index 1, and so on, until the last active -- local variable.) The function returns nil if there is no local variable -- with the given index, and raises an error when called with a `level` out -- of range. (You can call `debug.getinfo` to check whether the level is valid.) -- Variable names starting with '`(`' (open parentheses) represent internal -- variables (loop control variables, temporaries, and C function locals). function debug.getlocal(thread, level, loc) end --- -- Returns the metatable of the given `object` or nil if it does not have -- a metatable. function debug.getmetatable(object) end --- -- Returns the registry table (see ยง3.5). function debug.getregistry() end --- -- This function returns the name and the value of the upvalue with index -- `up` of the function `func`. The function returns nil if there is no -- upvalue with the given index. function debug.getupvalue(func, up) end --- -- Sets the environment of the given `object` to the given `table`. Returns -- `object`. function debug.setfenv(object, table) end --- -- Sets the given function as a hook. The string `mask` and the number -- `count` describe when the hook will be called. The string mask may have -- the following characters, with the given meaning: -- -- * `"c"`: the hook is called every time Lua calls a function; -- * `"r"`: the hook is called every time Lua returns from a function; -- * `"l"`: the hook is called every time Lua enters a new line of code. -- -- With a `count` different from zero, the hook is called after every `count` -- instructions. -- -- When called without arguments, `debug.sethook` turns off the hook. -- -- When the hook is called, its first parameter is a string describing -- the event that has triggered its call: `"call"`, `"return"` (or `"tail -- return"`, when simulating a return from a tail call), `"line"`, and -- `"count"`. For line events, the hook also gets the new line number as its -- second parameter. Inside a hook, you can call `getinfo` with level 2 to -- get more information about the running function (level 0 is the `getinfo` -- function, and level 1 is the hook function), unless the event is `"tail -- return"`. In this case, Lua is only simulating the return, and a call to -- `getinfo` will return invalid data. function debug.sethook(thread, hook, mask , count) end --- -- This function assigns the value `value` to the local variable with -- index `loc` of the function at level `level` of the stack. The function -- returns nil if there is no local variable with the given index, and raises -- an error when called with a `level` out of range. (You can call `getinfo` -- to check whether the level is valid.) Otherwise, it returns the name of -- the local variable. function debug.setlocal(thread, level, loc, value) end --- -- Sets the metatable for the given `object` to the given `table` (which -- can be nil). function debug.setmetatable(object, table) end --- -- This function assigns the value `value` to the upvalue with index `up` -- of the function `func`. The function returns nil if there is no upvalue -- with the given index. Otherwise, it returns the name of the upvalue. function debug.setupvalue(func, up, value) end return debug