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

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 ec8471 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
RevLine 
[bed759]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
[6d1e0a]21#include <boost/function.hpp>
[cc2976]22#include <boost/thread/recursive_mutex.hpp>
[6d1e0a]23#include <list>
[bed759]24#include <string>
25
[6d1e0a]26#include "molecule.hpp"
[bed759]27
[6d1e0a]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 */
[bed759]39class QtMoleculeItem : public QStandardItem, public Observer
40{
41public:
[6d1e0a]42 //!> typedef for a list of notification channels required, to know when to update
[3e52834]43 typedef Observable::channels_t channellist_t;
[6d1e0a]44
45 //!> enum states whether an item's formula changed or not
46 enum MoveTypes {
47 NeedsMove,
48 DoesNotMove
49 };
50
[fcdf05]51 //!> enumerates all different item types, coinciding with column in QtMoleculeList
52 enum COLUMNTYPES {NAME,VISIBILITY,ATOMCOUNT,FORMULA,OCCURRENCE,COLUMNTYPES_MAX};
53
[6d1e0a]54 //!> typedef for callback function to model to inform when we need update
[fcdf05]55 typedef const boost::function<void (
56 const moleculeId_t _id,
57 const QtMoleculeItem::COLUMNTYPES _type,
58 const enum MoveTypes)> emitDirtyState_t;
[6d1e0a]59
[cc2976]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
[6d1e0a]63 QtMoleculeItem(
[69b434]64 const moleculeId_t _molid,
[6d1e0a]65 const channellist_t &_channellist,
66 const enum MoveTypes _movetype,
[cc2976]67 const emitDirtyState_t _emitDirtyState,
68 const emitSubjectKilledState_t _emitSubjectKilledState);
[bed759]69 virtual ~QtMoleculeItem();
70
[6d1e0a]71 /** Update the state of this item.
72 *
73 */
74 void updateState();
75
[53c1ff]76 /** Const getter to this item's molecule.
77 *
78 * \return const ref to \a mol
79 */
[69b434]80 const molecule * const getMolecule() const;
[53c1ff]81
[7d0ddb]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
[fcdf05]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
[6d1e0a]95private:
96 void update(Observable *publisher);
97 void recieveNotification(Observable *publisher, Notification_ptr notification);
98 void subjectKilled(Observable *publisher);
99
[b9680b]100protected:
[6d1e0a]101 void signOnToMolecule();
102 void signOffFromMolecule();
[bed759]103
104protected:
[6d1e0a]105 /** This function needs to be implemented to make the specific update.
106 *
107 */
108 virtual void internal_updateState() = 0;
[bed759]109
110 //!> molecule we are signed on to
[69b434]111 const moleculeId_t molid;
[6d1e0a]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
[3e52834]120 //!> the Observable we are signed on, also indicates whether we are sign on (not NULL)
121 const Observable * owner;
[6d1e0a]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;
[cc2976]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;
[bed759]134};
135
136
137#endif /* QTMOLECULEITEM_HPP_ */
Note: See TracBrowser for help on using the repository browser.