20 #ifndef WORLD_BUILDER_GRAVITY_MODELS_INTERFACE_H 21 #define WORLD_BUILDER_GRAVITY_MODELS_INTERFACE_H 33 namespace GravityModel
60 const std::string &parent_name,
61 const std::vector<std::string> &required_entries);
106 static std::map<std::string, ObjectFactory *> factories;
110 static std::map<std::string, void ( *)(Parameters &,const std::string &)> &
get_declare_map()
112 static std::map<std::string, void ( *)(Parameters &,const std::string &)> declares;
133 #define WB_REGISTER_GRAVITY_MODEL(classname,name) \ 134 class classname##Factory : public ObjectFactory { \ 136 classname##Factory() \ 138 Interface::registerType(#name, classname::declare_entries, this); \ 140 std::unique_ptr<Interface> create(World *world) override final { \ 141 return std::unique_ptr<Interface>(new classname(world)); \ 144 static classname##Factory global_##classname##Factory; static std::unique_ptr< Interface > create(const std::string &name, WorldBuilder::World *world)
static void declare_entries(Parameters &prm, const std::string &parent_name, const std::vector< std::string > &required_entries)
WorldBuilder::World * world
static std::map< std::string, ObjectFactory * > & get_factory_map()
static std::map< std::string, void(*)(Parameters &, const std::string &)> & get_declare_map()
virtual void parse_entries(Parameters &prm)=0
virtual Point< 3 > gravity_vector(Point< 3 > point) const =0
virtual double gravity_norm(Point< 3 > point) const =0
static void registerType(const std::string &name, void(*)(Parameters &, const std::string &), ObjectFactory *factory)