VariableValue & Coupleable::coupledValue(const std::string & var_name, unsigned int comp) { if (!isCoupled(var_name)) // Need to generate a "default value" filled VariableValue { VariableValue * value = _default_value[var_name]; if (value == NULL) { value = new VariableValue(_coupleable_max_qps, _coupleable_params.defaultCoupledValue(var_name)); _default_value[var_name] = value; } return *_default_value[var_name]; } coupledCallback(var_name, false); MooseVariable * var = getVar(var_name, comp); if (_nodal) return (_c_is_implicit) ? var->nodalSln() : var->nodalSlnOld(); else return (_c_is_implicit) ? var->sln() : var->slnOld(); }
const VariableValue & Coupleable::coupledValue(const std::string & var_name, unsigned int comp) { if (!isCoupled(var_name)) return *getDefaultValue(var_name); coupledCallback(var_name, false); MooseVariable * var = getVar(var_name, comp); if (!_coupleable_neighbor) { if (_nodal) return (_c_is_implicit) ? var->nodalSln() : var->nodalSlnOld(); else return (_c_is_implicit) ? var->sln() : var->slnOld(); } else { if (_nodal) return (_c_is_implicit) ? var->nodalSlnNeighbor() : var->nodalSlnOldNeighbor(); else return (_c_is_implicit) ? var->slnNeighbor() : var->slnOldNeighbor(); } }