20 #ifndef WORLD_BUILDER_FEATURES_PLUME_MODELS_TEMPERATURE_INTERFACE_H 21 #define WORLD_BUILDER_FEATURES_PLUME_MODELS_TEMPERATURE_INTERFACE_H 32 template <
unsigned int dim>
class Point;
66 const std::string &parent_name,
67 const std::vector<std::string> &required_entries);
88 const double feature_min_depth,
89 const double feature_max_depth,
90 const double relative_distance_from_center)
const = 0;
128 static std::map<std::string, ObjectFactory *> factories;
132 static std::map<std::string, void ( *)(Parameters &,const std::string &)> &
get_declare_map()
134 static std::map<std::string, void ( *)(Parameters &,const std::string &)> declares;
155 #define WB_REGISTER_FEATURE_PLUME_TEMPERATURE_MODEL(classname,name) \ 156 class classname##Factory : public ObjectFactory { \ 158 classname##Factory() \ 160 Interface::registerType(#name, classname::declare_entries, this); \ 162 std::unique_ptr<Interface> create(World *world) override final { \ 163 return std::unique_ptr<Interface>(new classname(world)); \ 166 static classname##Factory global_##classname##Factory;
static std::unique_ptr< Interface > create(const std::string &name, WorldBuilder::World *world)
static std::map< std::string, void(*)(Parameters &, const std::string &)> & get_declare_map()
static void registerType(const std::string &name, void(*)(Parameters &, const std::string &), ObjectFactory *factory)
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 double relative_distance_from_center) const =0
std::string get_name() const
static std::map< std::string, ObjectFactory * > & get_factory_map()
virtual void parse_entries(Parameters &prm)=0
WorldBuilder::World * world
static void declare_entries(Parameters &prm, const std::string &parent_name, const std::vector< std::string > &required_entries)