X-Git-Url: http://git.tdb.fi/?p=libs%2Fdatafile.git;a=blobdiff_plain;f=source%2Floader.h;h=3ab6d28fcfd194b2029588a03383ddf53adc7194;hp=5c8726a179683c841e6439e57fd3cfa4772394e2;hb=9763e39e6e09e747b87940920e778ac269dd8b15;hpb=b34b46788d69853eabdbbd9e71ca82f2f5c09df8 diff --git a/source/loader.h b/source/loader.h index 5c8726a..3ab6d28 100644 --- a/source/loader.h +++ b/source/loader.h @@ -1,17 +1,8 @@ -/* $Id$ - -This file is part of libmspdatafile -Copyright © 2006-2008, 2010 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" #include "parser.h" #include "statement.h" @@ -39,7 +30,7 @@ When loading has finished successfully, the virtual function finish() is called. Any post-processing of the data should be placed here and not in the destructor. -See also classes BasicLoader and BasicLoader2. +See also classes ObjectLoader and CollectionObjectLoader in objectloader.h. */ class Loader { @@ -56,11 +47,14 @@ private: typedef std::map ActionMap; - ActionMap actions; + ActionMap actions; const Statement *cur_st; - + bool sub_loaded; + std::list aux_loaders; protected: - Loader(): cur_st(0) { } + bool check_sub_loads; + + Loader(); public: virtual ~Loader(); @@ -138,71 +132,32 @@ protected: private: void add(const std::string &, LoaderAction *); +protected: + void add_auxiliary_loader(Loader &); + +private: + bool has_keyword(const std::string &) const; 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 source may not necessarily be a file. */ - const std::string &get_source() const - { - if(!cur_st) - throw InvalidState("get_source called without current statement"); - return cur_st->source; - } + const std::string &get_source() const; virtual void finish() { } }; -/** -Provides the basic functionality of an object loader. Deriving from this -allows loading values directly into member variables of the objects. -*/ -template -class BasicLoader: public Loader -{ -public: - typedef O Object; - -protected: - O &obj; - -public: - BasicLoader(O &o): obj(o) { } - O &get_object() const { return obj; } -}; - - -/** -Provides functionality for loading objects with a Collection. Deriving from -this allows loading pointers to objects in the collection automatically. -*/ -template -class BasicLoader2: public BasicLoader -{ -public: - typedef C Collection; - -protected: - C &coll; - -public: - BasicLoader2(O &o, C &c): BasicLoader(o), coll(c) { } - C &get_collection() const { return coll; } -}; - - /** 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); } @@ -210,10 +165,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); }