Ignore:
File:
1 edited

Legend:

Unmodified
Added
Removed
  • src/Parser/FormatParser.hpp

    rf17b5f r765f16  
    1414#endif
    1515
     16#include <iosfwd>
     17#include <string>
     18#include <vector>
    1619
    17 #include "CodePatterns/Observer.hpp"
    18 #include "ChangeTracker.hpp"
    19 #include "FormatParser_Parameters.hpp"
     20#include "CodePatterns/Assert.hpp"
    2021
    21 namespace MoleCuilder {
    22   class MoleculeLoadAction;
    23 }
     22#include "FormatParserTrait.hpp"
     23#include "FormatParserInterface.hpp"
     24#include "FormatParser_common.hpp"
     25#include "ParserTypes.hpp"
    2426
    2527class atom;
    2628
    2729/**
     30 * @file
     31 * <H1> FormatParser Howto </H1>
     32 *
     33 * <H2> Introduction </H2>
     34 *
     35 * FormatParsers parse external streams (files) and bring their information
     36 * into the World. That is they implement load and save functions that work
     37 * on a specific vector atoms.
     38 *
     39 * <H2> Building your own Parsers </H2>
     40 *
     41 * Building Parsers is easy. All you have to do is the following:
     42 * -# add a new parser type to the file ParserTypes.def.
     43 * -# add a new template specialization of FormatParser in a new header and
     44 *    module that implement the virtual load and save functions.
     45 * -# Add the header file of your new parser to FormatParserStorage.cpp.
     46 *
     47 * <H3> Specific notes on the macros </H3>
     48 *
     49 * To clarify a bit the internals of all the different FormatParser... files, here
     50 * are some notes:
     51 * -# We make use of boost::preprocessor to generate lists from the sequence
     52 *    given in ParserTypes.def (and undefined in ParserTypes.undef). These might
     53 *    be forward declarations of even implementations. This is to assure that
     54 *    none are forgotten when a new FormatParser is added.
     55 * -# Thanks to the above construct FormatParserStorage also immediately knows
     56 *    about any new parsers and can get and add such instances.
     57 */
     58
     59/**
    2860 * General parser which observes the change tracker.
    2961 */
    30 class FormatParser : public Observer {
    31   friend class MoleCuilder::MoleculeLoadAction;
    32 public:
    33   FormatParser();
    34   virtual ~FormatParser();
    35   virtual void save(std::ostream* file, const std::vector<atom *> &atoms)=0;
    36   virtual void load(std::istream* file)=0;
    37   void setOstream(std::ostream* file);
     62template <enum ParserTypes Ptype>
     63class FormatParser : virtual public FormatParserInterface, public FormatParser_common {
     64  FormatParser() :
     65    FormatParser_common(NULL)
     66  {
     67    ASSERT(0, "FormatParser<>::FormatParser() - unspecialized function cannot be called.");
     68  }
     69  virtual ~FormatParser()
     70  {
     71    ASSERT(0, "FormatParser<>::~FormatParser() - unspecialized function cannot be called.");
     72  }
    3873
    39 protected:
    40   void update(Observable *publisher);
    41   void recieveNotification(Observable *publisher, Notification_ptr notification);
    42   void subjectKilled(Observable *publisher);
    43 
    44   // these functions are called when atoms are inserted or removed
    45   virtual void AtomInserted(atomId_t) {};
    46   virtual void AtomRemoved(atomId_t) {};
    47 
    48   FormatParser_Parameters *parameters;
    49 private:
    50 
    51   std::ostream* saveStream;
     74  void load(std::istream *file)
     75  {
     76    ASSERT(0, "FormatParser<>::load() - unspecialized function cannot be called.");
     77  }
     78  void save(std::ostream *file, const std::vector<atom *> &atoms)
     79  {
     80    ASSERT(0, "FormatParser<>::save() - unspecialized function cannot be called.");
     81  }
    5282};
    5383
     84#include "FormatParser_specializations_header.hpp"
     85
    5486#endif /* FORMATPARSER_HPP_ */
Note: See TracChangeset for help on using the changeset viewer.