Changes in src/Parser/FormatParser.hpp [f17b5f:765f16]
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
src/Parser/FormatParser.hpp
rf17b5f r765f16 14 14 #endif 15 15 16 #include <iosfwd> 17 #include <string> 18 #include <vector> 16 19 17 #include "CodePatterns/Observer.hpp" 18 #include "ChangeTracker.hpp" 19 #include "FormatParser_Parameters.hpp" 20 #include "CodePatterns/Assert.hpp" 20 21 21 namespace MoleCuilder { 22 class MoleculeLoadAction; 23 } 22 #include "FormatParserTrait.hpp" 23 #include "FormatParserInterface.hpp" 24 #include "FormatParser_common.hpp" 25 #include "ParserTypes.hpp" 24 26 25 27 class atom; 26 28 27 29 /** 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 /** 28 60 * General parser which observes the change tracker. 29 61 */ 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); 62 template <enum ParserTypes Ptype> 63 class 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 } 38 73 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 } 52 82 }; 53 83 84 #include "FormatParser_specializations_header.hpp" 85 54 86 #endif /* FORMATPARSER_HPP_ */
Note:
See TracChangeset
for help on using the changeset viewer.