X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Floader.h;h=3c4785c493017eadeef3f2c20bb70e05b4bb9cf8;hb=7df5e45c7f414f6a07681dc4ec2abb63b091a309;hp=57481cff28d36fca44b19db0c91784e7ecc54573;hpb=215e719d0ef85f748898660d15d01e77ac551de9;p=libs%2Fdatafile.git diff --git a/source/loader.h b/source/loader.h index 57481cf..3c4785c 100644 --- a/source/loader.h +++ b/source/loader.h @@ -1,15 +1,7 @@ -/* $Id$ - -This file is part of libmspdatafile -Copyright © 2006-2008 Mikko Rasa, Mikkosoft Productions -Distributed under the LGPL -*/ - #ifndef MSP_DATAFILE_LOADER_H_ #define MSP_DATAFILE_LOADER_H_ #include -#include #include #include "except.h" #include "loaderaction.h" @@ -44,16 +36,31 @@ See also classes BasicLoader and BasicLoader2. class Loader { private: - typedef std::map ActionMap; + struct ActionKey + { + std::string keyword; + std::string signature; - ActionMap actions; - const Statement *cur_st; + ActionKey(const std::string &, const std::string &); + + bool operator<(const ActionKey &) const; + }; + typedef std::map ActionMap; + + ActionMap actions; + const Statement *cur_st; + bool sub_loaded; protected: - Loader(): cur_st(0) { } + bool allow_pointer_reload; + bool check_sub_loads; + + Loader(); public: virtual ~Loader(); + bool is_pointer_reload_allowed() const { return allow_pointer_reload; } + /** Loads statements from a parser. */ void load(Parser &p); @@ -128,6 +135,8 @@ protected: private: void add(const std::string &, LoaderAction *); + LoaderAction *find_action(const ActionKey &) const; + protected: /** Returns the source of the statement being processed. This can be used to implement relative paths in include-like statements. Note that the @@ -144,8 +153,7 @@ protected: /** -Provides the basic functionality of an object loader. Deriving from this -allows loading values directly into member variables of the objects. +Deprecated. See ObjectLoader in objectloader.h. */ template class BasicLoader: public Loader @@ -163,8 +171,7 @@ public: /** -Provides functionality for loading objects with a Collection. Deriving from -this allows loading pointers to objects in the collection automatically. +Deprecated. See CollectionObjectLoader in objectloader.h. */ template class BasicLoader2: public BasicLoader @@ -187,10 +194,9 @@ Loads an object from a file. The object must have a public Loader class. template void load(T &obj, const std::string &fn) { - IO::File in(fn); - IO::Buffered buf(in); + IO::BufferedFile in(fn); - Parser parser(buf, fn); + Parser parser(in, fn); typename T::Loader loader(obj); loader.load(parser); } @@ -198,10 +204,9 @@ void load(T &obj, const std::string &fn) template void load(T &obj, const std::string &fn, U &arg) { - IO::File in(fn); - IO::Buffered buf(in); + IO::BufferedFile in(fn); - Parser parser(buf, fn); + Parser parser(in, fn); typename T::Loader loader(obj, arg); loader.load(parser); }