20 #ifndef WORLD_BUILDER_FEATURES_OCEANIC_PLATE_MODELS_GRAINS_INTERFACE_H 21 #define WORLD_BUILDER_FEATURES_OCEANIC_PLATE_MODELS_GRAINS_INTERFACE_H 38 namespace OceanicPlateModels
63 const std::string &parent_name,
64 const std::vector<std::string> &required_entries);
81 const unsigned int composition_number,
83 const double feature_min_depth,
84 const double feature_max_depth)
const = 0;
121 static std::map<std::string, ObjectFactory *> factories;
125 static std::map<std::string, void ( *)(Parameters &,const std::string &)> &
get_declare_map()
127 static std::map<std::string, void ( *)(Parameters &,const std::string &)> declares;
148 #define WB_REGISTER_FEATURE_OCEANIC_PLATE_GRAINS_MODEL(classname,name) \ 149 class classname##Factory : public ObjectFactory { \ 151 classname##Factory() \ 153 Interface::registerType(#name, classname::declare_entries, this); \ 155 virtual std::unique_ptr<Interface> create(World *world) override final { \ 156 return std::unique_ptr<Interface>(new classname(world)); \ 159 static classname##Factory global_##classname##Factory;
static void declare_entries(Parameters &prm, const std::string &parent_name, const std::vector< std::string > &required_entries)
std::string get_name() const
static std::unique_ptr< Interface > create(const std::string &name, WorldBuilder::World *world)
WorldBuilder::World * world
virtual WorldBuilder::grains get_grains(const Point< 3 > &position, const Objects::NaturalCoordinate &position_in_natural_coordinates, const double depth, const unsigned int composition_number, WorldBuilder::grains grains, const double feature_min_depth, const double feature_max_depth) const =0
static std::map< std::string, ObjectFactory * > & get_factory_map()
virtual void parse_entries(Parameters &prm, const std::vector< Point< 2 >> &coordinates)=0
static void registerType(const std::string &name, void(*)(Parameters &, const std::string &), ObjectFactory *factory)
static std::map< std::string, void(*)(Parameters &, const std::string &)> & get_declare_map()