source: src/Parser/FormatParser.hpp@ 045228

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 045228 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
RevLine 
[6bc51d]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
[56f73b]11// include config.h
12#ifdef HAVE_CONFIG_H
13#include <config.h>
14#endif
15
[765f16]16#include <iosfwd>
17#include <string>
18#include <vector>
[56f73b]19
[765f16]20#include "CodePatterns/Assert.hpp"
[6bc51d]21
[765f16]22#include "FormatParserTrait.hpp"
23#include "FormatParserInterface.hpp"
24#include "FormatParser_common.hpp"
25#include "ParserTypes.hpp"
[c1db05]26
[73916f]27class atom;
28
[765f16]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
[ab4b55]59/**
60 * General parser which observes the change tracker.
61 */
[765f16]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 }
[fac58f]78 void save(std::ostream *file, const std::vector<const atom *> &atoms)
[765f16]79 {
80 ASSERT(0, "FormatParser<>::save() - unspecialized function cannot be called.");
81 }
[6bc51d]82};
83
[765f16]84#include "FormatParser_specializations_header.hpp"
85
[6bc51d]86#endif /* FORMATPARSER_HPP_ */
Note: See TracBrowser for help on using the repository browser.