108 _variable_objects[mvir->mooseVariableBase()->number()].addObject(
object, tid,
false);
111 _variable_objects[mviv->mooseVariableBase()->number()].addObject(
object, tid,
false);
114 _variable_objects[mvie->mooseVariableBase()->number()].addObject(
object, tid,
false);
118 else if (
auto ro = std::dynamic_pointer_cast<ResidualObject>(
object); ro)
119 _variable_objects[ro->variable().number()].addObject(
object, tid,
false);
123 template <
typename T>
127 auto iter = _variable_objects.find(variable_id);
128 return (iter != _variable_objects.end() && iter->second.hasObjects(tid));
131 template <
typename T>
137 auto iter = _variable_objects.find(variable_id);
138 return (iter != _variable_objects.end() && iter->second.hasActiveBlockObjects(block_id, tid));
141 template <
typename T>
142 const std::vector<std::shared_ptr<T>> &
148 const auto iter = _variable_objects.find(variable_id);
149 mooseAssert(iter != _variable_objects.end(),
150 "Unable to locate variable kernels for the given variable id: " << variable_id
152 return iter->second.getActiveBlockObjects(block_id, tid);
155 template <
typename T>
161 for (
const auto &
object : _all_objects[tid])
162 object->initialSetup();
165 template <
typename T>
170 for (
const auto &
object : _active_objects[tid])
171 object->timestepSetup();
174 template <
typename T>
179 for (
const auto &
object : _active_objects[tid])
180 object->customSetup(exec_type);
183 template <
typename T>
188 if (hasActiveBlockObjects(
id, tid))
190 const auto & objects = getActiveBlockObjects(
id, tid);
191 for (
const auto &
object : objects)
192 object->subdomainSetup();
196 template <
typename T>
201 for (
const auto &
object : _active_objects[tid])
202 object->subdomainSetup();
205 template <
typename T>
210 for (
const auto &
object : _active_objects[tid])
211 object->jacobianSetup();
214 template <
typename T>
219 for (
const auto &
object : _active_objects[tid])
220 object->residualSetup();
223 template <
typename T>
229 for (
auto & it : _variable_objects)
230 it.second.updateActive(tid);
virtual void residualSetup(THREAD_ID tid=0) const
const std::vector< std::shared_ptr< T > > & getActiveVariableBlockObjects(unsigned int variable_id, SubdomainID block_id, THREAD_ID tid=0) const
A storage container for MooseObjects that inherit from SetupInterface.
virtual void customSetup(const ExecFlagType &exec_type, THREAD_ID tid=0) const
std::unique_ptr< T_DEST, T_DELETER > dynamic_pointer_cast(std::unique_ptr< T_SRC, T_DELETER > &src)
These are reworked from https://stackoverflow.com/a/11003103.
std::map< unsigned int, MooseObjectWarehouse< T > > _variable_objects
Variable based storage.
bool hasActiveVariableBlockObjects(unsigned int variable_id, SubdomainID block_id, THREAD_ID tid=0) const
Methods for checking/getting variable kernels for a variable and SubdomainID.
virtual void timestepSetup(THREAD_ID tid=0) const
virtual void initialSetup(THREAD_ID tid=0) const
Convenience methods for calling object setup methods.
virtual void jacobianSetup(THREAD_ID tid=0) const
Class for containing MooseEnum item information.
virtual void updateActive(THREAD_ID tid=0) override
Update the active status of Kernels.
virtual void addObject(std::shared_ptr< T > object, THREAD_ID tid=0, bool recurse=true)
Adds an object to the storage structure.
bool hasVariableObjects(unsigned int variable_id, THREAD_ID tid=0) const
Checks for whether this warehouse has objects for a given variable.
MooseObjectWarehouse(bool threaded=true)
Constructor.
virtual void addObject(std::shared_ptr< T > object, THREAD_ID tid=0, bool recurse=true) override
Adds an object to the storage structure.
A base storage container for MooseObjects.
virtual void subdomainSetup(THREAD_ID tid=0) const
virtual void updateActive(THREAD_ID tid=0)
Updates the active objects storage.