20 #ifndef WORLD_BUILDER_FEATURES_OCEANIC_PLATE_MODELS_TEMPERATURE_INTERFACE_H 21 #define WORLD_BUILDER_FEATURES_OCEANIC_PLATE_MODELS_TEMPERATURE_INTERFACE_H 32 template <
unsigned int dim>
class Point;
41 namespace OceanicPlateModels
66 const std::string &parent_name,
67 const std::vector<std::string> &required_entries);
85 const double feature_min_depth,
86 const double feature_max_depth)
const = 0;
124 static std::map<std::string, ObjectFactory *> factories;
128 static std::map<std::string, void ( *)(Parameters &,const std::string &)> &
get_declare_map()
130 static std::map<std::string, void ( *)(Parameters &,const std::string &)> declares;
151 #define WB_REGISTER_FEATURE_OCEANIC_PLATE_TEMPERATURE_MODEL(classname,name) \ 152 class classname##Factory : public ObjectFactory { \ 154 classname##Factory() \ 156 Interface::registerType(#name, classname::declare_entries, this); \ 158 std::unique_ptr<Interface> create(World *world) override final { \ 159 return std::unique_ptr<Interface>(new classname(world)); \ 162 static classname##Factory global_##classname##Factory;
static std::map< std::string, ObjectFactory * > & get_factory_map()
static std::unique_ptr< Interface > create(const std::string &name, WorldBuilder::World *world)
virtual double get_temperature(const Point< 3 > &position, const Objects::NaturalCoordinate &position_in_natural_coordinates, const double depth, const double gravity, double temperature, const double feature_min_depth, const double feature_max_depth) const =0
static void registerType(const std::string &name, void(*)(Parameters &, const std::string &), ObjectFactory *factory)
virtual void parse_entries(Parameters &prm, const std::vector< Point< 2 >> &coordinates)=0
std::string get_name() const
WorldBuilder::World * world
static void declare_entries(Parameters &prm, const std::string &parent_name, const std::vector< std::string > &required_entries)
static std::map< std::string, void(*)(Parameters &, const std::string &)> & get_declare_map()