source: src/Parser/FormatParser.hpp@ 30e5dc

Action_Thermostats Add_AtomRandomPerturbation Add_FitFragmentPartialChargesAction Add_RotateAroundBondAction Add_SelectAtomByNameAction Added_ParseSaveFragmentResults Adding_Graph_to_ChangeBondActions Adding_MD_integration_tests Adding_StructOpt_integration_tests Automaking_mpqc_open AutomationFragmentation_failures Candidate_v1.5.4 Candidate_v1.6.0 Candidate_v1.6.1 Candidate_v1.7.0 ChangeBugEmailaddress ChangingTestPorts ChemicalSpaceEvaluator CombiningParticlePotentialParsing Combining_Subpackages Debian_Package_split Debian_package_split_molecuildergui_only Disabling_MemDebug Docu_Python_wait EmpiricalPotential_contain_HomologyGraph EmpiricalPotential_contain_HomologyGraph_documentation Enable_parallel_make_install Enhance_userguide Enhanced_StructuralOptimization Enhanced_StructuralOptimization_continued Example_ManyWaysToTranslateAtom Exclude_Hydrogens_annealWithBondGraph FitPartialCharges_GlobalError Fix_ChargeSampling_PBC Fix_ChronosMutex Fix_FitPartialCharges Fix_FitPotential_needs_atomicnumbers Fix_ForceAnnealing Fix_IndependentFragmentGrids Fix_ParseParticles Fix_ParseParticles_split_forward_backward_Actions Fix_PopActions Fix_QtFragmentList_sorted_selection Fix_Restrictedkeyset_FragmentMolecule Fix_StatusMsg Fix_StepWorldTime_single_argument Fix_Verbose_Codepatterns Fix_fitting_potentials Fixes ForceAnnealing_goodresults ForceAnnealing_oldresults ForceAnnealing_tocheck ForceAnnealing_with_BondGraph ForceAnnealing_with_BondGraph_continued ForceAnnealing_with_BondGraph_continued_betteresults ForceAnnealing_with_BondGraph_contraction-expansion FragmentMolecule_checks_bonddegrees GeometryObjects Gui_Fixes Gui_displays_atomic_force_velocity IndependentFragmentGrids IndependentFragmentGrids_IndividualZeroInstances IndependentFragmentGrids_IntegrationTest IndependentFragmentGrids_Sole_NN_Calculation JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool JobMarket_unresolvable_hostname_fix ODR_violation_mpqc_open PartialCharges_OrthogonalSummation PythonUI_with_named_parameters QtGui_reactivate_TimeChanged_changes Recreated_GuiChecks RotateToPrincipalAxisSystem_UndoRedo SaturateAtoms_findBestMatching SaturateAtoms_singleDegree StoppableMakroAction Subpackage_CodePatterns Subpackage_JobMarket Subpackage_LinearAlgebra Subpackage_levmar Subpackage_mpqc_open Subpackage_vmg Switchable_LogView ThirdParty_MPQC_rebuilt_buildsystem TrajectoryDependenant_MaxOrder TremoloParser_IncreasedPrecision TremoloParser_MultipleTimesteps TremoloParser_setsAtomName Ubuntu_1604_changes stable
Last change on this file since 30e5dc was fac58f, checked in by Frederik Heber <heber@…>, 10 years ago

Converted FormatParser::save() to using vector of const atom ptrs.

  • required to change all save() functions in all parsers.
  • Property mode set to 100644
File size: 2.5 KB
Line 
1/*
2 * FormatParser.hpp
3 *
4 * Created on: Mar 1, 2010
5 * Author: metzler
6 */
7
8#ifndef FORMATPARSER_HPP_
9#define FORMATPARSER_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 "CodePatterns/Assert.hpp"
21
22#include "FormatParserTrait.hpp"
23#include "FormatParserInterface.hpp"
24#include "FormatParser_common.hpp"
25#include "ParserTypes.hpp"
26
27class atom;
28
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/**
60 * General parser which observes the change tracker.
61 */
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 }
73
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<const atom *> &atoms)
79 {
80 ASSERT(0, "FormatParser<>::save() - unspecialized function cannot be called.");
81 }
82};
83
84#include "FormatParser_specializations_header.hpp"
85
86#endif /* FORMATPARSER_HPP_ */
Note: See TracBrowser for help on using the repository browser.