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 | */
|
---|
39 | class QtMoleculeItem : public QStandardItem, public Observer
|
---|
40 | {
|
---|
41 | public:
|
---|
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 |
|
---|
95 | private:
|
---|
96 | void update(Observable *publisher);
|
---|
97 | void recieveNotification(Observable *publisher, Notification_ptr notification);
|
---|
98 | void subjectKilled(Observable *publisher);
|
---|
99 |
|
---|
100 | protected:
|
---|
101 | void signOnToMolecule();
|
---|
102 | void signOffFromMolecule();
|
---|
103 |
|
---|
104 | protected:
|
---|
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 |
|
---|
113 | private:
|
---|
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_ */
|
---|