source: src/Parser/FormatParserInterface.hpp@ 97dff0

Last change on this file since 97dff0 was 765f16, checked in by Frederik Heber <heber@…>, 13 years ago

Huge Refactoring of FormatParserStorage and all FormatParser's.

FormatParser:

FormatParserStorage:

  • We construct all lookup tables and alikes via boost preprocessor magic from a list of all available parser (enums).
  • we use the templated getParser() and addParser() functions to serve parsers to the outside. Instances are as usual created only once.

Tests:

  • tests only had to be changed because of the "renaming" of the Parsers.
  • Property mode set to 100644
File size: 1.1 KB
RevLine 
[765f16]1/*
2 * FormatParserInterface.hpp
3 *
4 * Created on: Sep 27, 2011
5 * Author: heber
6 */
7
8#ifndef FORMATPARSERINTERFACE_HPP_
9#define FORMATPARSERINTERFACE_HPP_
10
11// include config.h
12#ifdef HAVE_CONFIG_H
13#include <config.h>
14#endif
15
16#include <iosfwd>
17#include <string>
18#include <vector>
19
20#include "ParserTypes.hpp"
21#include "types.hpp"
22
23class atom;
24class FormatParser_Parameters;
25
26/**
27 * Interface definition for a general parser.
28 *
29 * In order to allow storage and common interface to all FormatParser
30 * specialization variants, we need this interface definition.
31 */
32class FormatParserInterface {
33public:
34 FormatParserInterface() {}
35 virtual ~FormatParserInterface() {}
36 virtual void save(std::ostream* file, const std::vector<atom *> &atoms)=0;
37 virtual void load(std::istream* file)=0;
38 virtual void setOstream(std::ostream* file)=0;
39
40 FormatParser_Parameters *parameters;
41protected:
42 // these functions are called when atoms are inserted or removed
43 virtual void AtomInserted(atomId_t)=0;
44 virtual void AtomRemoved(atomId_t)=0;
45};
46
47
48#endif /* FORMATPARSERINTERFACE_HPP_ */
Note: See TracBrowser for help on using the repository browser.