source: src/Parser/FormatParser_common.cpp@ d640ea

Action_Thermostats Add_AtomRandomPerturbation Add_FitFragmentPartialChargesAction Add_RotateAroundBondAction Add_SelectAtomByNameAction Added_ParseSaveFragmentResults AddingActions_SaveParseParticleParameters Adding_Graph_to_ChangeBondActions Adding_MD_integration_tests Adding_ParticleName_to_Atom Adding_StructOpt_integration_tests AtomFragments Automaking_mpqc_open AutomationFragmentation_failures Candidate_v1.5.4 Candidate_v1.6.0 Candidate_v1.6.1 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_BoundInBox_CenterInBox_MoleculeActions 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 FragmentAction_writes_AtomFragments FragmentMolecule_checks_bonddegrees GeometryObjects Gui_Fixes Gui_displays_atomic_force_velocity ImplicitCharges IndependentFragmentGrids IndependentFragmentGrids_IndividualZeroInstances IndependentFragmentGrids_IntegrationTest IndependentFragmentGrids_Sole_NN_Calculation JobMarket_RobustOnKillsSegFaults JobMarket_StableWorkerPool JobMarket_unresolvable_hostname_fix MoreRobust_FragmentAutomation ODR_violation_mpqc_open PartialCharges_OrthogonalSummation PdbParser_setsAtomName PythonUI_with_named_parameters QtGui_reactivate_TimeChanged_changes Recreated_GuiChecks Rewrite_FitPartialCharges 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 d640ea 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: 2.7 KB
Line 
1/*
2 * Project: MoleCuilder
3 * Description: creates and alters molecular systems
4 * Copyright (C) 2010 University of Bonn. All rights reserved.
5 * Please see the LICENSE file or "Copyright notice" in builder.cpp for details.
6 */
7
8/*
9 * FormatParser_common_common.cpp
10 *
11 * Created on: Mar 1, 2010
12 * Author: metzler
13 */
14
15// include config.h
16#ifdef HAVE_CONFIG_H
17#include <config.h>
18#endif
19
20#include "CodePatterns/MemDebug.hpp"
21
22#include <iostream>
23
24#include "CodePatterns/Observer.hpp"
25#include "World.hpp"
26#include "ChangeTracker.hpp"
27#include "FormatParser_common.hpp"
28
29using namespace std;
30
31/**
32 * Constructor.
33 */
34FormatParser_common::FormatParser_common(FormatParser_Parameters *_parameters) :
35 Observer("FormatParser_common")
36{
37 parameters = _parameters;
38 ChangeTracker::getInstance().signOn(this);
39 World::getInstance().signOn(this, World::getInstance().getChannel(World::AtomInserted));
40 World::getInstance().signOn(this, World::getInstance().getChannel(World::AtomRemoved));
41}
42
43/**
44 * Destructor.
45 */
46FormatParser_common::~FormatParser_common()
47{
48 ChangeTracker::getInstance().signOff(this);
49 World::getInstance().signOff(this, World::getInstance().getChannel(World::AtomInserted));
50 World::getInstance().signOff(this, World::getInstance().getChannel(World::AtomRemoved));
51 if (parameters != NULL)
52 delete parameters;
53}
54
55/**
56 * Update operation which can be invoked by the observable (which should be the
57 * change tracker here).
58 */
59void FormatParser_common::update(Observable *publisher) {
60 if (!saveStream) {
61 cerr << "Please invoke setOstream() so the parser knows where to save the World's data." << endl;
62 return;
63 }
64
65 std::vector<atom *> atoms = World::getInstance().getAllAtoms();
66 save(saveStream, atoms);
67}
68
69/**
70 * With this, each format parser is informed about specific changes in the World.
71 */
72void FormatParser_common::recieveNotification(Observable *publisher, Notification_ptr notification) {
73 switch (notification->getChannelNo()) {
74 case World::AtomInserted:
75 AtomInserted(World::getInstance().lastChanged<atom>()->getId());
76 break;
77 case World::AtomRemoved:
78 AtomRemoved(World::getInstance().lastChanged<atom>()->getId());
79 break;
80 default:
81 ASSERT(0,
82 "FormatParser_common::recieveNotification() - unknown notification "
83 +toString(notification->getChannelNo())+" received.");
84 break;
85 }
86}
87
88/**
89 * The observable can tell when it dies.
90 */
91void FormatParser_common::subjectKilled(Observable *publisher) {}
92
93/**
94 * Sets the output stream for save, so the save() method can be invoked on update
95 * automatically.
96 *
97 * \param ostream where to save the World's state
98 */
99void FormatParser_common::setOstream(ostream* output) {
100 saveStream = output;
101}
Note: See TracBrowser for help on using the repository browser.