30#include "neml2/misc/errors.h"
31#include "neml2/base/InputFile.h"
65 bool has_object(
const std::string & section,
const std::string &
name);
84 std::shared_ptr<T>
get_object(
const std::string & section,
85 const std::string &
name,
87 bool force_create =
true);
90 template <
class T = Solver>
93 template <
class T = Data>
96 template <
class T = Model>
99 template <
class T = Driver>
102 template <
class T = WorkScheduler>
113 void print(std::ostream & os = std::cout);
126 bool options_compatible(
const std::shared_ptr<NEML2Object> & obj,
const OptionSet & opts)
const;
135 std::map<std::string, std::map<std::string, std::vector<std::shared_ptr<NEML2Object>>>> _objects;
141 const std::string &
name,
150 if (_objects.count(section) && _objects.at(section).count(
name))
151 for (
const auto & neml2_obj : _objects[section][
name])
154 if (!options_compatible(neml2_obj, additional_options))
158 auto obj = std::dynamic_pointer_cast<T>(neml2_obj);
161 "Found object named " +
name +
" under section " + section +
162 ". But dynamic cast failed. Did you specify the correct object type?");
168 for (
const auto & options : _input_file[section])
169 if (options.first ==
name)
171 auto new_options = options.second;
172 new_options.set<
Factory *>(
"_factory") =
this;
173 new_options.set<std::shared_ptr<Settings>>(
"_settings") =
settings();
174 new_options += additional_options;
179 if (!_objects.count(section) || !_objects.at(section).count(
name))
181 ". Check to make sure the object is defined in the input file.");
183 auto obj = std::dynamic_pointer_cast<T>(_objects[section][
name].back());
std::shared_ptr< T > get_object(const std::string §ion, const std::string &name, const OptionSet &additional_options=OptionSet(), bool force_create=true)
Retrive an object pointer under the given section with the given object name.
Definition Factory.h:140
std::shared_ptr< T > get_driver(const std::string &name)
Get a driver by its name.
Definition Factory.h:214
std::shared_ptr< T > get_data(const std::string &name)
Get a data by its name.
Definition Factory.h:200
void create_object(const std::string §ion, const OptionSet &options)
Manufacture a single NEML2Object.
Definition Factory.cxx:46
const std::shared_ptr< Settings > & settings() const
Global settings.
Definition Factory.h:62
Factory(InputFile)
Definition Factory.cxx:33
std::shared_ptr< T > get_model(const std::string &name)
Get a model by its name.
Definition Factory.h:207
std::shared_ptr< T > get_scheduler(const std::string &name)
Get a scheduler by its name.
Definition Factory.h:221
bool has_object(const std::string §ion, const std::string &name)
Check if an object with the given name exists under the given section.
Definition Factory.cxx:40
InputFile & input_file()
Get the input file.
Definition Factory.h:56
const InputFile & input_file() const
Get the input file.
Definition Factory.h:59
void clear()
Delete all factories and destruct all the objects.
Definition Factory.cxx:87
std::shared_ptr< T > get_solver(const std::string &name)
Get a solver by its name.
Definition Factory.h:193
void print(std::ostream &os=std::cout)
List all the manufactured objects.
Definition Factory.cxx:74
A custom map-like data structure. The keys are strings, and the values can be nonhomogeneously typed.
Definition OptionSet.h:51
Definition DiagnosticsInterface.cxx:30
std::string name(ElasticConstant p)
Definition ElasticityConverter.cxx:30