See also classes ObjectLoader and CollectionObjectLoader in objectloader.h.
*/
-class Loader
+class Loader: private NonCopyable
{
-private:
- typedef std::map<StatementKey, LoaderAction *> ActionMap;
+protected:
+ class ActionMap: public std::map<StatementKey, LoaderAction *>, private NonCopyable
+ {
+ public:
+ ~ActionMap();
+ };
- ActionMap actions;
+private:
+ ActionMap local_actions;
+ ActionMap *actions;
Parser *cur_parser;
unsigned cur_level;
const Statement *cur_st;
Loader();
public:
- virtual ~Loader();
+ virtual ~Loader() { }
/** Loads statements from a parser. */
void load(Parser &p);
/** Processes the current statement's substatements with another Loader. */
void load_sub_with(Loader &);
+ /** Sets the actions to be used when loading. If the map is empty,
+ init_actions will be called. */
+ void set_actions(ActionMap &);
+ virtual void init_actions() { }
+
/** Adds a keyword that is loaded by calling a function. */
template<typename L>
void add(const std::string &k, void (L::*func)())
}
/**
-Loads an object from a file stored in a collection. The object must havea
+Loads an object from a file stored in a collection. The object must have a
public Loader class. The collection is passed to the Loader constructor,
followed by any extra arguments.
*/