AddDebugHook: Difference between revisions
		
		
		
		
		
		Jump to navigation
		Jump to search
		
				
		
		
	
| No edit summary | |||
| (11 intermediate revisions by 8 users not shown) | |||
| Line 6: | Line 6: | ||
| Debug hooks are not recursive, so functions and events triggered inside the hook callback will not be traced. | Debug hooks are not recursive, so functions and events triggered inside the hook callback will not be traced. | ||
| }} | }} | ||
| ==Syntax== | ==Syntax== | ||
| <syntaxhighlight lang="lua"> | <syntaxhighlight lang="lua"> | ||
| bool addDebugHook( string hookType, function callbackFunction[, table nameList ] ) | bool addDebugHook ( string hookType, function callbackFunction [, table nameList ] ) | ||
| </syntaxhighlight> | </syntaxhighlight> | ||
| Line 17: | Line 18: | ||
| ** preFunction | ** preFunction | ||
| ** postFunction | ** postFunction | ||
| *'''callbackFunction :''' The function to call | ** preEventFunction | ||
| ** postEventFunction | |||
| *'''callbackFunction:''' The function to call | |||
| ** Returning the string "skip" from the callback function will cause the original function/event to be skipped | |||
| ===Optional Arguments===   | ===Optional Arguments===   | ||
| *'''nameList:''' Table of strings for restricting which functions and events the hook will be triggered on | *'''nameList:''' Table of strings for restricting which functions and events the hook will be triggered on | ||
| ** addDebugHook and removeDebugHook will only be hooked if they are specified in the name list | |||
| ===Returns=== | ===Returns=== | ||
| Line 29: | Line 32: | ||
| ==Callback parameters== | ==Callback parameters== | ||
| <syntaxhighlight lang="lua"> | <syntaxhighlight lang="lua"> | ||
| string preFunction( resource sourceResource, string functionName, bool isAllowedByACL, string luaFilename, int luaLineNumber, ...functionArguments ) | |||
|        postFunction( resource sourceResource, string functionName, bool isAllowedByACL, string luaFilename, int luaLineNumber, ...functionArguments ) | |||
| string preEvent( resource sourceResource, string eventName, element eventSource, element eventClient, string luaFilename, int luaLineNumber, ...eventArguments ) | |||
|        postEvent( resource sourceResource, string eventName, element eventSource, element eventClient, string luaFilename, int luaLineNumber, ...eventArguments ) | |||
| </syntaxhighlight> | |||
| {{New feature/item|3.0158|1.5.5|11856| | |||
| <syntaxhighlight lang="lua"> | |||
| string preEventFunction ( resource eventResource, string eventName, element eventSource, element eventClient, string eventFilename, int eventLineNumber, resource functionResource, string functionFilename, int functionLineNumber, ...eventArgs ) | |||
|        postEventFunction ( resource eventResource, string eventName, element eventSource, element eventClient, string eventFilename, int eventLineNumber, resource functionResource, string functionFilename, int functionLineNumber, ...eventArgs ) | |||
| </syntaxhighlight> | </syntaxhighlight> | ||
| }} | |||
| ==Example== | ==Example== | ||
| This example will dump info about all triggered events: | This example will dump info about all triggered events: | ||
| <syntaxhighlight lang="lua"> | <syntaxhighlight lang="lua"> | ||
| function onPreEvent(  | function onPreEvent( sourceResource, eventName, eventSource, eventClient, luaFilename, luaLineNumber, ... ) | ||
|      local args = { ... } |      local args = { ... } | ||
|      local srctype = eventSource and getElementType(eventSource) |      local srctype = eventSource and getElementType(eventSource) | ||
|      local resname =  |      local resname = sourceResource and getResourceName(sourceResource) | ||
|      local plrname = eventClient and getPlayerName(eventClient) |      local plrname = eventClient and getPlayerName(eventClient) | ||
|      outputDebugString( "preEvent" |      outputDebugString( "preEvent" | ||
| Line 56: | Line 67: | ||
| This example will dump info about all called MTA functions: | This example will dump info about all called MTA functions: | ||
| <syntaxhighlight lang="lua"> | <syntaxhighlight lang="lua"> | ||
| function onPreFunction(  | function onPreFunction( sourceResource, functionName, isAllowedByACL, luaFilename, luaLineNumber, ... ) | ||
|      local args = { ... } |      local args = { ... } | ||
|      local resname =  |      local resname = sourceResource and getResourceName(sourceResource) | ||
|      outputDebugString( "preFunction" |      outputDebugString( "preFunction" | ||
|          .. " " .. tostring(resname) |          .. " " .. tostring(resname) | ||
| Line 76: | Line 87: | ||
| addDebugHook( "preFunction", onPreFunction, {"setElementPosition","loadstring"} ) | addDebugHook( "preFunction", onPreFunction, {"setElementPosition","loadstring"} ) | ||
| </syntaxhighlight> | </syntaxhighlight> | ||
| ==Changelog== | ==Changelog== | ||
| Line 81: | Line 93: | ||
| {{ChangelogItem|1.3.5-9.06054|Added clientside}} | {{ChangelogItem|1.3.5-9.06054|Added clientside}} | ||
| {{ChangelogItem|1.3.5-9.06142|Added option to restrict to specified functions and events }} | {{ChangelogItem|1.3.5-9.06142|Added option to restrict to specified functions and events }} | ||
| {{ChangelogItem|1.5.2-9.07957|Added option to skip original function/event <br/>Added ability to hook addDebugHook and removeDebugHook }} | |||
| {{ | {{ChangelogItem|1.5.5-9.11856|Added pre/postEventFunction hooks }} | ||
| {{ChangelogItem|1.6.0-9.22741|Removed ability to skip 'addDebugHook' }} | |||
| ==See Also== | ==See Also== | ||
| {{Utility functions}} | {{Utility functions}} | ||
Latest revision as of 09:42, 16 September 2025
This function allows tracing of MTA functions and events. It should only be used when debugging scripts as it may degrade script performance.
Debug hooks are not recursive, so functions and events triggered inside the hook callback will not be traced.
Syntax
bool addDebugHook ( string hookType, function callbackFunction [, table nameList ] )
Required Arguments
- hookType: The type of hook to add. This can be:
- preEvent
- postEvent
- preFunction
- postFunction
- preEventFunction
- postEventFunction
 
- callbackFunction: The function to call
- Returning the string "skip" from the callback function will cause the original function/event to be skipped
 
Optional Arguments
- nameList: Table of strings for restricting which functions and events the hook will be triggered on
- addDebugHook and removeDebugHook will only be hooked if they are specified in the name list
 
Returns
Returns true if the hook was successfully added, or false otherwise.
Callback parameters
string preFunction( resource sourceResource, string functionName, bool isAllowedByACL, string luaFilename, int luaLineNumber, ...functionArguments )
       postFunction( resource sourceResource, string functionName, bool isAllowedByACL, string luaFilename, int luaLineNumber, ...functionArguments )
string preEvent( resource sourceResource, string eventName, element eventSource, element eventClient, string luaFilename, int luaLineNumber, ...eventArguments )
       postEvent( resource sourceResource, string eventName, element eventSource, element eventClient, string luaFilename, int luaLineNumber, ...eventArguments )
string preEventFunction ( resource eventResource, string eventName, element eventSource, element eventClient, string eventFilename, int eventLineNumber, resource functionResource, string functionFilename, int functionLineNumber, ...eventArgs )
       postEventFunction ( resource eventResource, string eventName, element eventSource, element eventClient, string eventFilename, int eventLineNumber, resource functionResource, string functionFilename, int functionLineNumber, ...eventArgs )
Example
This example will dump info about all triggered events:
function onPreEvent( sourceResource, eventName, eventSource, eventClient, luaFilename, luaLineNumber, ... )
    local args = { ... }
    local srctype = eventSource and getElementType(eventSource)
    local resname = sourceResource and getResourceName(sourceResource)
    local plrname = eventClient and getPlayerName(eventClient)
    outputDebugString( "preEvent"
        .. " " .. tostring(resname)
        .. " " .. tostring(eventName)
        .. " source:" .. tostring(srctype)
        .. " player:" .. tostring(plrname)
        .. " file:" .. tostring(luaFilename)
        .. "(" .. tostring(luaLineNumber) .. ")"
        .. " numArgs:" .. tostring(#args)
        .. " arg1:" .. tostring(args[1])
        )
end
addDebugHook( "preEvent", onPreEvent )
This example will dump info about all called MTA functions:
function onPreFunction( sourceResource, functionName, isAllowedByACL, luaFilename, luaLineNumber, ... )
    local args = { ... }
    local resname = sourceResource and getResourceName(sourceResource)
    outputDebugString( "preFunction"
        .. " " .. tostring(resname)
        .. " " .. tostring(functionName)
        .. " allowed:" .. tostring(isAllowedByACL)
        .. " file:" .. tostring(luaFilename)
        .. "(" .. tostring(luaLineNumber) .. ")"
        .. " numArgs:" .. tostring(#args)
        .. " arg1:" .. tostring(args[1])
        )
end
addDebugHook( "preFunction", onPreFunction)
This example adds a hook which will only be triggered for the named functions
addDebugHook( "preFunction", onPreFunction, {"setElementPosition","loadstring"} )
Changelog
| Version | Description | 
|---|
| 1.3.5-9.06054 | Added clientside | 
| 1.3.5-9.06142 | Added option to restrict to specified functions and events | 
| 1.5.2-9.07957 | Added option to skip original function/event Added ability to hook addDebugHook and removeDebugHook | 
| 1.5.5-9.11856 | Added pre/postEventFunction hooks | 
| 1.6.0-9.22741 | Removed ability to skip 'addDebugHook' | 
See Also
- addDebugHook
- debugSleep
- decodeString
- encodeString
- fromJSON
- generateKeyPair
- getColorFromString
- getDevelopmentMode
- getDistanceBetweenPoints2D
- getDistanceBetweenPoints3D
- getEasingValue
- getNetworkStats
- getNetworkUsageData
- getPerformanceStats
- getRealTime
- getTickCount
- getTimerDetails
- getTimers
- getFPSLimit
- getUserdataType
- getVersion
- gettok
- isTransferBoxVisible
- setTransferBoxVisible
- hash
- inspect
- interpolateBetween
- iprint
- isOOPEnabled
- isTimer
- killTimer
- md5
- passwordHash
- passwordVerify
- pregFind
- pregMatch
- pregReplace
- removeDebugHook
- resetTimer
- setDevelopmentMode
- setFPSLimit
- setTimer
- ref
- deref
- sha256
- split
- teaDecode
- teaEncode
- toJSON
- tocolor
- getProcessMemoryStats
- utfChar
- utfCode
- utfLen
- utfSeek
- utfSub
- bitAnd
- bitNot
- bitOr
- bitXor
- bitTest
- bitLRotate
- bitRRotate
- bitLShift
- bitRShift
- bitArShift
- bitExtract
- bitReplace