1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 |
local ZO_CallbackObjectMixin = { }
local CALLBACK_INDEX = 1
local ARGUMENT_INDEX = 2
local PRIORITY_INDEX = 3
local DELETED_INDEX = 4
do
local leftPriority = left [ PRIORITY_INDEX ]
local rightPriority = right [ PRIORITY_INDEX ]
if leftPriority and rightPriority then
return leftPriority < rightPriority
elseif leftPriority then
return true
else
return false
end
end
--Registers a callback to be executed when eventName is triggered.
--You may optionally specify an argument to be passed to the callback.
return
end
--if this is the first callback then create the registry
end
--create a list to hold callbacks of this type if it doesn't exist
if not registry then
registry = { }
end
--make sure this callback wasn't already registered
-- If the callback is already registered, make sure it hasn't been flagged for delete
-- so it won't be unregistered in self:Clean later
-- This can happen if you attempt to unregister and register for a callback
-- during a callback, since that will delay the clean until after we have tried to re-register
registration [ DELETED_INDEX ] = false
return
end
end
--store the callback with an optional argument
--note: the order of the arguments to the table constructor must match the order of the *_INDEX locals above
if priority then
-- If this registration has a priorty, we need to determine where it goes in the order
-- If it does not, we can assume any with priorities were already sorted to the front, and this can stay tacked on the end with the rest of the unprioritized
end
end
end
return
end
if registry then
--find the entry
for i = 1 , # registry do
local callbackInfo = registry [ i ]
callbackInfo [ DELETED_INDEX ] = true
return
end
end
end
end
return
end
if registry then
--find the entry
for i = 1 , # registry do
local callbackInfo = registry [ i ]
callbackInfo [ DELETED_INDEX ] = true
end
end
end
end
--Executes all callbacks registered on this object with this event name
--Accepts the event name, and a list of arguments to be passed to the callbacks
--The return value is from the callbacks, the most recently registered non-nil non-false callback return value is returned
local result = nil
return result
end
if registry then
local callbackInfoIndex = 1
while callbackInfoIndex <= # registry do
--pass the arg as the first parameter if it exists
local callbackInfo = registry [ callbackInfoIndex ]
local argument = callbackInfo [ ARGUMENT_INDEX ]
local deleted = callbackInfo [ DELETED_INDEX ]
if not deleted then
if argument then
else
end
break
end
end
callbackInfoIndex = callbackInfoIndex + 1
end
end
return result
end
if eventName then
dirtyEvents [ # dirtyEvents + 1 ] = eventName
end
while # dirtyEvents > 0 do
local eventName = dirtyEvents [ # dirtyEvents ]
if registry then
local callbackInfoIndex = 1
while callbackInfoIndex <= # registry do
local callbackTable = registry [ callbackInfoIndex ]
if callbackTable [ DELETED_INDEX ] then
else
callbackInfoIndex = callbackInfoIndex + 1
end
end
if # registry == 0 then
end
end
dirtyEvents [ # dirtyEvents ] = nil
end
end
end
end
end
end
end
end
end
ZO_CallbackObject = { }
ZO_InitializingCallbackObject = { }
|