You can find the gist here.
Example usage:
main.lua
Code: Select all
function love.update( dt )
Hook.Call( "Update", dt )
end
Code: Select all
Hook.Attach( "Update", "UniqueIDHere", function( dt )
print( dt )
end )
Code: Select all
function love.update( dt )
Hook.Call( "Update", dt )
end
Code: Select all
Hook.Attach( "Update", "UniqueIDHere", function( dt )
print( dt )
end )
This is completely unrelated to the debug module hooks brother, also sure thing:
Code: Select all
function love.update( dt )
Hook.Call( "Update", dt )
end
Code: Select all
Hook.Attach( "Update", "UniqueIDHere", function( dt )
print( dt )
end )
Code: Select all
for k, v in pairs( cachedHooks[hookID] ) do
Yes, the first point you mention is the whole reason you'd have a use case for this library over just simply calling the function itself and that's why I created it lol, and Unique IDs have to be specified else how else would you remove a hook if you don't assign it's value to a variable?ivan wrote: ↑Sat Sep 05, 2020 6:53 am I see. Going over the code I think it closely resembles the publisher->subscriber model.
The primary feature which you forgot to mention is that you can attach multiple hooks/callbacks to one particular event/hookID.
It's not bad although I'm not 100% sold on having to specify uniqueIDs. Also this library is non-deterministic due to the following line:pairs does not iterate your hooks in a predictable manner.Code: Select all
for k, v in pairs( cachedHooks[hookID] ) do
This goes completely against what the library was made for, the unique IDs are for direct reference to the table. I believe you are having trouble understanding what the system is used for, here is a similar one used in Garry's Mod and you will see the purpose of the library:I think the lib would be much better if you just stored your hooks in a list and used ipairs. You can also use the func pointer as a unique id anyways.
You can still keep the unique IDs and also keep a table for the stuff added with the integer keys being the order in which they were added; if you use pairs, that order doesn't exist, and your users could e.g. call update and draw in a random order each frame... not a good idea. With that one extra table, you could use that for iteration.GlorifiedPig wrote: ↑Sat Sep 05, 2020 2:51 pmThis goes completely against what the library was made for, the unique IDs are for direct reference to the table. I believe you are having trouble understanding what the system is used for, here is a similar one used in Garry's Mod and you will see the purpose of the library:
https://wiki.facepunch.com/gmod/Hook_Library_Usage
https://github.com/Facepunch/garrysmod/ ... ok.lua#L23
This would work but I cannot find a use case for having it in a specific order as it iterates to the point where it finds the first return value either wayzorg wrote: ↑Sat Sep 05, 2020 3:35 pmYou can still keep the unique IDs and also keep a table for the stuff added with the integer keys being the order in which they were added; if you use pairs, that order doesn't exist, and your users could e.g. call update and draw in a random order each frame... not a good idea. With that one extra table, you could use that for iteration.GlorifiedPig wrote: ↑Sat Sep 05, 2020 2:51 pmThis goes completely against what the library was made for, the unique IDs are for direct reference to the table. I believe you are having trouble understanding what the system is used for, here is a similar one used in Garry's Mod and you will see the purpose of the library:
https://wiki.facepunch.com/gmod/Hook_Library_Usage
https://github.com/Facepunch/garrysmod/ ... ok.lua#L23
There's this thing called "the principle of least surprise", and library code is usually expected to adhere to it. In this case it means that hooks should be called in the order they were added, instead of the order of iteration being undefined, and even semi-randomly change during the lifetime of the program, which is very surprising.GlorifiedPig wrote: ↑Sat Sep 05, 2020 3:47 pm This would work but I cannot find a use case for having it in a specific order
That's not what the code does though. It iterates over all hooks in unspecified order and returns the first return value that was not nil and not false. It does not stop iteration early.as it iterates to the point where it finds the first return value either way
You are right. Let me change that up quickly.grump wrote: ↑Sat Sep 05, 2020 4:44 pmThere's this thing called "the principle of least surprise", and library code is usually expected to adhere to it. In this case it means that hooks should be called in the order they were added, instead of the order of iteration being undefined, and even semi-randomly change during the lifetime of the program, which is very surprising.GlorifiedPig wrote: ↑Sat Sep 05, 2020 3:47 pm This would work but I cannot find a use case for having it in a specific order
https://en.wikipedia.org/wiki/Principle ... tonishment
One use case where your approach immediately fails is all kinds of drawing code, e.g. using it with love.draw.
That's not what the code does though. It iterates over all hooks in unspecified order and returns the first return value that was not nil and not false. It does not stop iteration early.as it iterates to the point where it finds the first return value either way
Not treating false as a valid return value is another surprising behavior btw.
Users browsing this forum: zazabar and 7 guests