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 |
--[[
A generic pool to contain "active" and "free" objects. Active objects
are typically objects which:
1. Have a relatively high construction cost
2. Are not lightweight enough to create many of them at once
3. Tend to be reused as dynamic elements of a larger container.
The pool should "rapidly" reach a high-water mark of contained objects
which should flow between active and free states on a regular basis.
Ideal uses of the ZO_ObjectPool would be to contain objects such as:
1. Scrolling combat text
2. Tracked quests
3. Buff icons
The pools are not intended to be used to track a dynamic set of
contained objects whose membership grows to a predetermined size.
As such, do NOT use the pool to track:
1. Chat filters
2. Inventory slots
3. Action buttons (unless creating something like AutoBar)
A common usage pattern is instantiating templated controls. To facilitate this
without bloating your own code you should use ZO_ObjectPool_CreateControl which has
been written here as a convenience. It creates a control named "template"..id where
id is an arbitrary value that will not conflict with other generated id's.
If your system depends on having well-known names for controls, you should not use the
convenience function.
--]]
then
pool . m_Active = { }
pool . m_Free = { }
pool . m_NextFree = 1 -- Just in case the user would like the pool to generate object keys.
pool . m_NextControlId = 0 -- Just in case the user would like the pool to generate id-based control suffixes
end
return pool
end
if freeKey == nil or object == nil then
local nextPotentialFree = self . m_NextFree
self . m_NextFree = self . m_NextFree + 1
return nextPotentialFree , nil
end
return freeKey , object
end
self . m_NextControlId = self . m_NextControlId + 1
return self . m_NextControlId
end
end
end
return self . m_Active
end
end
end
-- If the object referred to by this key is already
-- active there is very little work to do...just return it.
if ( ( objectKey ~= nil ) and ( self . m_Active [ objectKey ] ~= nil ) )
then
return self . m_Active [ objectKey ] , objectKey
end
local object = nil
-- If we know the key that we want, use that object first, otherwise just return the first object from the free pool
-- A nil objectKey means that the caller doesn't care about tracking unique keys for these objects, or that the keys
-- the system uses can't directly be used to look up the data. Just manage them with pool-generated id's
if ( objectKey == nil )
then
else
object = self . m_Free [ objectKey ]
end
--
-- If the object is valid it was reclaimed from the free list, otherwise it needs to be created.
-- Creation uses the m_Factory member which receives this pool as its only argument.
-- Either way, after this, object must be non-nil
--
if ( object )
then
self . m_Free [ objectKey ] = nil
else
end
self . m_Active [ objectKey ] = object
end
return object , objectKey
end
return self . m_Active [ objectKey ]
end
local object = self . m_Active [ objectKey ]
if ( object )
then
then
end
self . m_Active [ objectKey ] = nil
self . m_Free [ objectKey ] = object
end
end
do
then
end
self . m_Free [ k ] = v
end
self . m_Active = { }
end
local object = self . m_Free [ objectKey ]
self . m_Free [ objectKey ] = nil
end
end
self . m_Free = { }
end
return CreateControlFromVirtual ( templateName , parentControl , templateName , objectPool : GetNextControlId ( ) )
end
end
end |