Garry's Mod

Garry's Mod

301 ratings
Addon hooks Conflict Finder
   
Award
Favorite
Favorited
Unfavorite
Content Type: Addon
Addon Type: Tool
File Size
Posted
Updated
3.276 KB
3 Jan, 2015 @ 5:00pm
9 May, 2016 @ 7:49am
12 Change Notes ( view )

Subscribe to download
Addon hooks Conflict Finder

In 5 collections by Cédric GÉRILLE [GiletJaune]
Soccer by Mohamed RACHID
37 items
Université Joseph Poireau (serveur)
70 items
MR: Serveur Garry's Mod Jeu en 2D
11 items
Dev Tests Mohamed
50 items
G-1:788429
50 items
Description
Intro
This tool allows the developer or the technician to discover the name of the hook that overrides the result and stops the execution of a given event name.

Available on GitHub: Addon hooks Conflict Finder[github.com]

The problem
When an event is triggered, all the hooks (callbacks) added to it are executed in an unknown order. If the event name is listed here[wiki.garrysmod.com] then this event has a default behavior, probably that from the base gamemode. For user-created event names, the event is triggered manually.
If any hook returns a value then the event execution stops, so pending hooks are ignored as well as the default behavior. This can be correct, but some Lua coders make crap and accidentally stop the event execution list.
That is why this addon has been created! If you have dozens of addons but do not know where to search for the conflict, this addon will help. This addon does not use hooks so it will always work!

Notes
• Event names and hook names are case-sensitive!
• Because the table read order in Lua is unknown, if the failing addons work correctly right after you started the test then you may have to temporary disable the failing addons.
• This addon cannot work with event names that are not strings.
• This addon will not return a meaningful hook name if it is neither a string nor a number.

Step 1
At first, if you see an addon that obviously has an overridden behavior, look inside of the source code to find the event name. An overridden hook is never called.
-- In an addon, you will see this: hook.Add( "EventName", "HookName", ThatHookFunction ) -- In the gamemode, you will more likely find this: function GM:EventName( args ) -- Something to do after all hooks created with hook.Add() have been executed. end

Step 2
Once you get the hook that seems not to work, note the event name.
The command name is find_conflicts_hook_sv to find a hook conflict serverside, or find_conflicts_hook_cl clientside. Only superadmins can use it serverside.

To start the test, use this command:
find_conflicts_hook_sv "EventName"
To stop the test then, use this:
find_conflicts_hook_sv "EventName" 0

Step 3
The screen will display something like the following each time the specified event gets a hook that returns a value:
• for a value returned by a hook created with hook.Add():
Event "EventName", hook "HookName", returned: Arg #1 = table: 0x37e5a550
• for a value returned by the gamemode:
Event "EventName", GAMEMODE, returned: Arg #1 = table: 0x2c69db10

Step 4
Once you got the hook name that stops the event, you can look into the source code of your addons. The addon name is mostly already given in the reports.
Be sure that the selected hook has both the right EventName and the right HookName.
It is now up to you to correct / remove the addon that incorrectly stops the event!
If you can't find the involved addon, for example with Notepad++ (hotkey Ctrl+Shift+F) you can look into every *.lua and *.gma file in the garrysmod\addons folder (+subfolders) by searching for HookName.

Good luck!
60 Comments
H4PPY 9 Apr @ 1:50pm 
ik ik since im trying to know why
Cédric GÉRILLE [GiletJaune]  [author] 9 Apr @ 1:47pm 
Your password issue has nothing to do with sv_restart...
H4PPY 9 Apr @ 1:44pm 
ok i will test it to find out why sv_restart doesnt work
Market Pluh 8 Sep, 2024 @ 1:49am 
https://steamhost.cn/steamcommunity_com/sharedfiles/filedetails/?id=623663324
I RECOMMEND YOU TO USE THIS MOD IT MAKES FINDING HOOKS 100X EASIER
Cluna 16 Jul, 2024 @ 9:35am 
there is too much work to do to find that one hook conflict(like literally, i have to look up every mod's source code), just disabling mods by yourself would be more faster soo this doesnt really helps
Cédric GÉRILLE [GiletJaune]  [author] 21 Apr, 2024 @ 11:37pm 
I don't have full examples. I'm sorry if you feel confused with the instructions in the description.
Market Pluh 21 Apr, 2024 @ 9:11pm 
do you have any examples on how to use this mod?
Cédric GÉRILLE [GiletJaune]  [author] 16 Apr, 2024 @ 11:54pm 
If you can find the event that is blocked then my conflict finder will help you locate the guilty add-on. You may need help to find the name of the event. What are the symptoms?
squam 16 Apr, 2024 @ 12:55pm 
so do i actually have to find the event or do i just have to locate the addon with the problem
Cédric GÉRILLE [GiletJaune]  [author] 16 Apr, 2024 @ 4:52am 
If you can't tell which event has a problem then you cannot use this tool.
I apologize for not being helpful.