Changeset 393342 for src/UIElements/Qt4/InstanceBoard
- Timestamp:
- Feb 14, 2016, 12:34:26 PM (9 years ago)
- Branches:
- 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
- Children:
- 6bce88
- Parents:
- 0af22d
- git-author:
- Frederik Heber <heber@…> (12/30/15 18:42:38)
- git-committer:
- Frederik Heber <heber@…> (02/14/16 12:34:26)
- Location:
- src/UIElements/Qt4/InstanceBoard
- Files:
-
- 2 edited
Legend:
- Unmodified
- Added
- Removed
-
src/UIElements/Qt4/InstanceBoard/ObservedValuesContainer.hpp
r0af22d r393342 102 102 */ 103 103 104 typedef std::deque<std::pair<typename T::ptr, size_t> > RefCountedObservedValues_t; 105 typedef std::map<id, RefCountedObservedValues_t > CountedObservedValues_t; 104 /** Structure to contain the sequence of created observed memories. 105 * 106 * \note QtGUI may lag behind the creation/destruction of observed instances a 107 * lot but one after the other must be served. Here, we keep an additional 108 * iterator that indicates the current instance to be served. 109 */ 110 struct RefCountedObserved 111 { 112 typedef std::pair<typename T::ptr, size_t> Value_t; 113 typedef std::deque<Value_t> Values_t; 114 115 /** Default cstor of RefCountedObservedValues. 116 * 117 * Make sure that currentvalue has some sensible default value. 118 */ 119 RefCountedObserved() : 120 tobedestroyed(values.end()), 121 currentvalue(values.end()) 122 {} 123 124 /** Default copy cstor of RefCountedObservedValues. 125 * 126 * \param _instance instance to copy 127 */ 128 RefCountedObserved(const RefCountedObserved & _instance) : 129 values(_instance.values), 130 tobedestroyed(values.begin()), 131 currentvalue(values.begin()) 132 {} 133 134 /** Cstor of RefCountedObservedValues. 135 * 136 * Make sure that currentvalue has some sensible default value. 137 * 138 * \param _value initial value for the list 139 */ 140 RefCountedObserved(Value_t _value) : 141 values(1, _value), 142 tobedestroyed(values.begin()), 143 currentvalue(values.begin()) 144 {} 145 146 bool empty() const 147 { 148 return values.empty(); 149 } 150 151 void push_back(Value_t _value) 152 { 153 values.push_back(_value); 154 if (currentvalue == values.end()) 155 currentvalue = values.end()--; 156 if (tobedestroyed == values.end()) 157 tobedestroyed = currentvalue; 158 } 159 160 Value_t& getCurrentValue() const 161 { 162 ASSERT (currentvalue != values.end(), 163 "RefCountedObservedValues::getCurrentValue() - cannot get, no values present."); 164 return *currentvalue; 165 } 166 167 Value_t& getEraseCandidate() const 168 { 169 ASSERT (tobedestroyed != values.end(), 170 "RefCountedObservedValues::getCurrentValue() - cannot get, no values present."); 171 return *tobedestroyed; 172 } 173 174 void eraseCurrentValue() 175 { 176 ASSERT (tobedestroyed != values.end(), 177 "RefCountedObservedValues::eraseCurrentValue() - cannot erase, no values present."); 178 if (tobedestroyed == currentvalue) 179 ++currentvalue; 180 values.erase(tobedestroyed); 181 tobedestroyed = currentvalue; 182 // removal of this instance when both iterators point to end is done inside QtObservedInstanceBoard 183 } 184 185 //!> set of values 186 Values_t values; 187 //!> iterator on the value that is next gonna be destroyed 188 typename Values_t::iterator tobedestroyed; 189 //!> iterator on the current value that is served on get 190 typename Values_t::iterator currentvalue; 191 }; 192 193 typedef std::map<id, RefCountedObserved > CountedObservedValues_t; 106 194 //!> internal vector of observed values 107 195 CountedObservedValues_t ObservedValues; -
src/UIElements/Qt4/InstanceBoard/ObservedValuesContainer_impl.hpp
r0af22d r393342 37 37 "~ObservedValuesContainer() of "+NameOfType+" "+toString(iter->first) 38 38 +" has an empty list in ObservedValues."); 39 for (typename RefCountedObserved Values_t::iterator listiter = iter->second.begin();40 listiter != iter->second. end(); ++listiter) {39 for (typename RefCountedObserved::Values_t::iterator listiter = iter->second.values.begin(); 40 listiter != iter->second.values.end(); ++listiter) { 41 41 listiter->first->noteBoardIsGone(); 42 42 } … … 51 51 "ObservedValuesContainer::getObservedValues() - no observed values present for " 52 52 +NameOfType+" "+toString(_id)); 53 ASSERT( !iter->second.empty(), 54 "ObservedValuesContainer<T,id>::get() of "+NameOfType+" "+toString(_id) 55 +" has an empty list in ObservedValues."); 56 const typename T::ptr &obsvalues = iter->second.back().first; 57 58 return obsvalues; 53 return iter->second.getCurrentValue().first; 59 54 } 60 55 … … 65 60 LOG(3, "DEBUG: ObservedValuesContainer got markObservedValuesAsConnected() for an observed value of " 66 61 << NameOfType << " " << _id); 67 typename CountedObservedValues_t::iterator iter = ObservedValues.find(_id);62 typename CountedObservedValues_t::iterator iter = ObservedValues.find(_id); 68 63 ASSERT (iter != ObservedValues.end(), 69 64 "ObservedValuesContainer<T,id>::markObservedValuesAsConnected() - Observed value of " 70 65 +NameOfType+" "+toString(_id)+" is not present yet."); 71 ASSERT( !iter->second.empty(), 72 "ObservedValuesContainer<T,id>::markObservedValuesAsConnected() of "+NameOfType 73 +" "+toString(_id)+" has an empty list in ObservedValues."); 74 ++(iter->second.back().second); 66 ++(iter->second.getCurrentValue().second); 75 67 } 76 68 … … 80 72 { 81 73 typename CountedObservedValues_t::const_iterator iter = ObservedValues.find(_id); 82 ASSERT( !iter->second.empty(), 83 "ObservedValuesContainer<T,id>::checkRefCount() of "+NameOfType 84 +" "+toString(_id)+" has an empty list in ObservedValues."); 85 return ((iter != ObservedValues.end()) && (iter->second.front().second == 0)); 74 return ((iter != ObservedValues.end()) && (iter->second.getEraseCandidate().second == 0)); 86 75 } 87 76 … … 96 85 "ObservedValuesContainer<T,id>::markObservedValuesAsDisconnected() - Observed value of " 97 86 +NameOfType+" "+toString(_id)+" is not present yet."); 98 ASSERT( !iter->second.empty(), 99 "ObservedValuesContainer<T,id>::markObservedValuesAsDisconnected() of "+NameOfType 100 +" "+toString(_id)+" has an empty list in ObservedValues."); 101 ASSERT (iter->second.front().second != 0, 87 ASSERT (iter->second.getEraseCandidate().second != 0, 102 88 "ObservedValuesContainer<T,id>::markObservedValuesAsDisconnected() - Observed value of " 103 89 +NameOfType+" "+toString(_id)+" is already signOff() from all."); 104 --(iter->second. front().second);90 --(iter->second.getEraseCandidate().second); 105 91 106 92 if (checkRefCount(_id) && checksubjectKilled(_id) && checkMarkedForErase(_id)) … … 144 130 subjectKilledCount.erase(_id); 145 131 typename CountedObservedValues_t::iterator iter = ObservedValues.find(_id); 146 ASSERT( !iter->second.empty(), 147 "ObservedValuesContainer<T,id>::removeObservedValues() of "+NameOfType 148 +" for "+toString(_id)+" has an empty list in ObservedValues."); 149 if (iter->second.size() == 1) 132 iter->second.eraseCurrentValue(); 133 if (iter->second.empty()) 150 134 ObservedValues.erase(iter); 151 else {152 //if more than one, erase always the first one153 iter->second.pop_front();154 }155 135 MarkedForErase.erase(_id); 156 136 } … … 180 160 void ObservedValuesContainer<T,id>::insert(const id _id, const typename T::ptr &_obsvalues) 181 161 { 182 std::pair<typename CountedObservedValues_t::iterator, bool> inserter = 183 ObservedValues.insert( 184 std::make_pair( _id, RefCountedObservedValues_t(1,std::make_pair(_obsvalues,0)) ) ); 185 if (!inserter.second) { 162 typename ObservedValuesContainer<T,id>::RefCountedObserved::Value_t value(std::make_pair(_obsvalues,0)); 163 typename CountedObservedValues_t::iterator iter = ObservedValues.find(_id); 164 if (iter == ObservedValues.end()) { 165 std::pair<typename CountedObservedValues_t::iterator, bool> inserter = 166 ObservedValues.insert( 167 std::make_pair( _id, RefCountedObserved(value) ) ); 168 ASSERT( inserter.second, 169 "ObservedValuesContainer<T,id>::insert() of "+NameOfType 170 +" for "+toString(_id)+", insertion failed though empty?"); 171 } else { 172 ASSERT( !iter->second.empty(), 173 "ObservedValuesContainer<T,id>::insert() of "+NameOfType 174 +" for "+toString(_id)+" has an empty list in ObservedValues."); 186 175 // already an entry present? add to deque 187 i nserter.first->second.push_back( std::make_pair(_obsvalues,0));176 iter->second.push_back( value ); 188 177 } 189 178 _obsvalues->activateObserver(); … … 210 199 // whether changing ids "there" is possible when the QtObserved... is under 211 200 // removal. 212 RefCountedObservedValues_tobsvalues = Colditer->second;201 ObservedValuesContainer<T,id>::RefCountedObserved obsvalues = Colditer->second; 213 202 ObservedValues.erase(Colditer); 214 203 ObservedValues.insert( std::make_pair(_newid, obsvalues) );
Note:
See TracChangeset
for help on using the changeset viewer.