source: src/UIElements/Views/Qt4/MoleculeList/QtMoleculeItem.hpp@ 25a81d

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 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_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 25a81d was cc2976, checked in by Frederik Heber <heber@…>, 10 years ago

QtMoleculeItem_.. now shout when they receive subjectKilled().

  • this way we do not have this double system of both QtMoleculeList (in a lazy fashion) and each QtMoleculeList listens for moleculeRemoved (one through the Observer channel, the other through subjectKilled()).
  • we simply count the number of QtMoleculeItems that received subjectKilled() and if max is reached, the row is removed.
  • to prevent molecule id clash, insertion (of same id) after removal is ok. This works cause we first remove and then insert new item. Hence, having the same id is possible.
  • Property mode set to 100644
File size: 3.8 KB
Line 
1/*
2 * QtMoleculeItem.hpp
3 *
4 * Created on: Jan 17, 2015
5 * Author: heber
6 */
7
8#ifndef QTMOLECULEITEM_HPP_
9#define QTMOLECULEITEM_HPP_
10
11// include config.h
12#ifdef HAVE_CONFIG_H
13#include <config.h>
14#endif
15
16#include <QList>
17#include <QStandardItem>
18
19#include "CodePatterns/Observer/Observer.hpp"
20
21#include <boost/function.hpp>
22#include <boost/thread/recursive_mutex.hpp>
23#include <list>
24#include <string>
25
26#include "molecule.hpp"
27
28/** This class describes the general interface for a specific item in a QtAbstractItemModel
29 * to contain a specific piece of information about a specific molecule.
30 *
31 * To this end, we need a ref to the molecule for updating the information when
32 * necessary and we need to know the channels we have to listen to know when an
33 * update is necessary.
34 *
35 * This class takes care of of all the rest:
36 * -# informing QtMoleculeList about required update ("dirty")
37 * -# relaying updateState() call from QtMoleculeList to the specific internal_updateState()
38 */
39class QtMoleculeItem : public QStandardItem, public Observer
40{
41public:
42 //!> typedef for a list of notification channels required, to know when to update
43 typedef Observable::channels_t channellist_t;
44
45 //!> enum states whether an item's formula changed or not
46 enum MoveTypes {
47 NeedsMove,
48 DoesNotMove
49 };
50
51 //!> enumerates all different item types, coinciding with column in QtMoleculeList
52 enum COLUMNTYPES {NAME,VISIBILITY,ATOMCOUNT,FORMULA,OCCURRENCE,COLUMNTYPES_MAX};
53
54 //!> typedef for callback function to model to inform when we need update
55 typedef const boost::function<void (
56 const moleculeId_t _id,
57 const QtMoleculeItem::COLUMNTYPES _type,
58 const enum MoveTypes)> emitDirtyState_t;
59
60 //!> typedef for callback function to model to inform when our subjectKilled() was called
61 typedef const boost::function<void (const moleculeId_t _id)> emitSubjectKilledState_t;
62
63 QtMoleculeItem(
64 const moleculeId_t _molid,
65 const channellist_t &_channellist,
66 const enum MoveTypes _movetype,
67 const emitDirtyState_t _emitDirtyState,
68 const emitSubjectKilledState_t _emitSubjectKilledState);
69 virtual ~QtMoleculeItem();
70
71 /** Update the state of this item.
72 *
73 */
74 void updateState();
75
76 /** Const getter to this item's molecule.
77 *
78 * \return const ref to \a mol
79 */
80 const molecule * const getMolecule() const;
81
82 /** Getter for the id of the molecule this item is associated to
83 *
84 * \return id of molecule
85 */
86 moleculeId_t getMoleculeId() const
87 { return molid; }
88
89 /** Returns the type of this QtMoleculeItem, i.e. the column in QtMoleculeList.
90 *
91 * @return type of this item
92 */
93 virtual QtMoleculeItem::COLUMNTYPES getType() const = 0;
94
95private:
96 void update(Observable *publisher);
97 void recieveNotification(Observable *publisher, Notification_ptr notification);
98 void subjectKilled(Observable *publisher);
99
100protected:
101 void signOnToMolecule();
102 void signOffFromMolecule();
103
104protected:
105 /** This function needs to be implemented to make the specific update.
106 *
107 */
108 virtual void internal_updateState() = 0;
109
110 //!> molecule we are signed on to
111 const moleculeId_t molid;
112
113private:
114 //!> move type for this specific item, set this when implementing
115 const enum MoveTypes movetype;
116
117 //!> ref to the specific static list of channels we are signed on to
118 const channellist_t &channellist;
119
120 //!> the Observable we are signed on, also indicates whether we are sign on (not NULL)
121 const Observable * owner;
122
123 //!> states that this item needs to be updated
124 bool dirty;
125
126 //!> bound callback function to inform model about change
127 const emitDirtyState_t emitDirtyState;
128
129 //!> bound callback function to inform model about change
130 const emitSubjectKilledState_t emitSubjectKilledState;
131
132 //!> this protects the signing on and off
133 mutable boost::recursive_mutex owner_mutex;
134};
135
136
137#endif /* QTMOLECULEITEM_HPP_ */
Note: See TracBrowser for help on using the repository browser.