Ignore:
Timestamp:
Feb 17, 2012, 3:24:17 PM (13 years ago)
Author:
Frederik Heber <heber@…>
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:
8bf9c6
Parents:
3f7587
git-author:
Frederik Heber <heber@…> (01/05/12 16:10:53)
git-committer:
Frederik Heber <heber@…> (02/17/12 15:24:17)
Message:

Rewrite of how GLWorldScene and subsidiaries get notified of changed bonds and atoms.

  • we have made the connections from the real atoms and bonds to the nodes within GLWorldScene a lot easier. Also this fixes a crash when Subgraph- Dissection is called.
  • renamed BondedParticle::BondsChanged -> ::BondsAdded.
  • GLMoleculeObject_bond now observes its associated bond.
  • added documentation on how the mechanism works in qt-gui.dox.
Location:
src/UIElements/Views/Qt4/Qt3D
Files:
6 edited

Legend:

Unmodified
Added
Removed
  • src/UIElements/Views/Qt4/Qt3D/GLMoleculeObject_atom.cpp

    r3f7587 r2ad1ec  
    3030#include "CodePatterns/Observer/Notification.hpp"
    3131
     32#include "Atom/atom.hpp"
     33#include "Bond/bond.hpp"
    3234#include "Descriptors/AtomIdDescriptor.hpp"
    3335#include "Element/element.hpp"
    3436#include "LinearAlgebra/Vector.hpp"
     37#include "GLMoleculeObject_bond.hpp"
    3538#include "World.hpp"
    3639
     
    4548
    4649GLMoleculeObject_atom::GLMoleculeObject_atom(QObject *parent, const atom *atomref) :
    47   GLMoleculeObject(createAtom(parent), parent), Observer("GLMoleculeObject_atom"), _atom(atomref)
     50  GLMoleculeObject(createAtom(parent), parent),
     51  Observer(std::string("GLMoleculeObject_atom")+toString(atomref->getId())),
     52  _atom(atomref)
    4853{
    4954  // sign on as observer (obtain non-const instance before)
     
    5156  atomref->signOn(this, AtomObservable::PositionChanged);
    5257  atomref->signOn(this, AtomObservable::ElementChanged);
    53   atomref->signOn(this, AtomObservable::BondsChanged);
     58  atomref->signOn(this, AtomObservable::BondsAdded);
    5459
    5560  // set the object's id
     
    6671  _atom->signOff(this, AtomObservable::PositionChanged);
    6772  _atom->signOff(this, AtomObservable::ElementChanged);
    68   _atom->signOff(this, AtomObservable::BondsChanged);
     73  _atom->signOff(this, AtomObservable::BondsAdded);
    6974}
    7075
     
    153158      resetPosition();
    154159      break;
    155     case AtomObservable::BondsChanged:
    156       emit BondsChanged(_atom);
    157       break;
     160    case AtomObservable::BondsAdded:
     161      {
     162        ASSERT(!_atom->getListOfBonds().empty(),
     163            "GLMoleculeObject_atom::recieveNotification() - received BondsAdded but ListOfBonds is empty.");
     164        const bond * _bond = *(_atom->getListOfBonds().rbegin());
     165        const GLMoleculeObject_bond::SideOfBond side = (_bond->leftatom == _atom) ?
     166            GLMoleculeObject_bond::left : GLMoleculeObject_bond::right;
     167        emit BondsInserted(_bond, side);
     168        break;
     169      }
    158170    default:
    159171      //setProperties();
  • src/UIElements/Views/Qt4/Qt3D/GLMoleculeObject_atom.hpp

    r3f7587 r2ad1ec  
    1818#include "CodePatterns/Observer/Observer.hpp"
    1919
    20 #include "Atom/atom.hpp"
     20#include "GLMoleculeObject_bond.hpp"
     21
     22class atom;
     23class bond;
    2124
    2225class GLMoleculeObject_atom : public GLMoleculeObject, public Observer
     
    3740signals:
    3841  void clicked(atomId_t);
    39   void BondsChanged(const atom *_atom);
     42  void BondsInserted(const bond *_bond, const GLMoleculeObject_bond::SideOfBond side);
    4043
    4144private:
  • src/UIElements/Views/Qt4/Qt3D/GLMoleculeObject_bond.cpp

    r3f7587 r2ad1ec  
    3131#include "CodePatterns/Assert.hpp"
    3232#include "CodePatterns/Log.hpp"
     33#include "CodePatterns/Observer/Notification.hpp"
    3334#include "Atom/atom.hpp"
    3435#include "Bond/bond.hpp"
     
    4950}
    5051
    51 GLMoleculeObject_bond::GLMoleculeObject_bond(QObject *parent, const bond *bondref, double distance, enum SideOfBond side) :
    52   GLMoleculeObject(createBond(parent, distance), parent), _bond(bondref)
     52GLMoleculeObject_bond::GLMoleculeObject_bond(QObject *parent, const bond *bondref, const double distance, const enum SideOfBond side) :
     53  GLMoleculeObject(createBond(parent, distance), parent),
     54  Observer(std::string("GLMoleculeObject_bond")
     55      +toString(bondref->leftatom->getId())
     56      +std::string("-")
     57      +toString(bondref->rightatom->getId())),
     58  _bond(bondref),
     59  BondSide(side)
    5360{
     61  // sign on as observer (obtain non-const instance before)
     62  _bond->signOn(this, BondObservable::BondRemoved);
     63
    5464  Vector Position;
    5565  Vector OtherPosition;
    5666  size_t elementno = 0;
    57   switch (side) {
     67  switch (BondSide) {
    5868    case left:
    5969      Position = _bond->leftatom->getPosition();
     
    7787    default:
    7888      ASSERT(0,
    79           "GLMoleculeObject_bond::GLMoleculeObject_bond() - side is not a valid argument: "+toString(side)+".");
     89          "GLMoleculeObject_bond::GLMoleculeObject_bond() - side is not a valid argument: "+toString(BondSide)+".");
    8090      break;
    8191  }
     
    113123  setRotationAngle(alpha/M_PI*180.);
    114124}
     125
     126GLMoleculeObject_bond::~GLMoleculeObject_bond()
     127{
     128  // sign on as observer (obtain non-const instance before)
     129  _bond->signOff(this, BondObservable::BondRemoved);
     130
     131  LOG(2, "INFO: Destroying  GLMoleculeObject_bond to bond " << *_bond << " and side " << BondSide << ".");
     132}
     133
     134void GLMoleculeObject_bond::update(Observable *publisher)
     135{
     136#ifdef LOG_OBSERVER
     137  observerLog().addMessage() << "++ Update of Observer " << observerLog().getName(this) << " from bond " << *_bond << ".";
     138#endif
     139}
     140
     141void GLMoleculeObject_bond::subjectKilled(Observable *publisher)
     142{
     143  LOG(2, "INFO: Received subjectKilled from " << *_bond << ".");
     144  switch (BondSide) {
     145    case left:
     146      emit BondRemoved(_bond->leftatom->getId(), _bond->rightatom->getId());
     147      break;
     148    case right:
     149      emit BondRemoved(_bond->rightatom->getId(), _bond->leftatom->getId());
     150      break;
     151    default:
     152      ASSERT(0,
     153          "GLMoleculeObject_bond::subjectKilled() - side is not a valid argument: "+toString(BondSide)+".");
     154      break;
     155  }
     156  delete this;
     157}
     158
     159void GLMoleculeObject_bond::recieveNotification(Observable *publisher, Notification_ptr notification)
     160{
     161#ifdef LOG_OBSERVER
     162  observerLog().addMessage() << "++ Update of Observer "<< observerLog().getName(this)
     163      << " received notification from bond " << *_bond << " for channel "
     164      << notification->getChannelNo() << ".";
     165#endif
     166  switch (notification->getChannelNo()) {
     167    case BondObservable::BondRemoved:
     168      LOG(2, "INFO: Received notification of BondRemoved from " << *_bond << ".");
     169      switch (BondSide) {
     170        case left:
     171          emit BondRemoved(_bond->leftatom->getId(), _bond->rightatom->getId());
     172          break;
     173        case right:
     174          emit BondRemoved(_bond->rightatom->getId(), _bond->leftatom->getId());
     175          break;
     176        default:
     177          ASSERT(0,
     178              "GLMoleculeObject_bond::recieveNotification() - side is not a valid argument: "+toString(BondSide)+".");
     179          break;
     180      }
     181      delete this;
     182      break;
     183    default:
     184      break;
     185  }
     186}
  • src/UIElements/Views/Qt4/Qt3D/GLMoleculeObject_bond.hpp

    r3f7587 r2ad1ec  
    1616#include "GLMoleculeObject.hpp"
    1717
     18#include "CodePatterns/Observer/Observer.hpp"
     19
     20#include "types.hpp"
     21
    1822class bond;
    1923
    20 class GLMoleculeObject_bond : public GLMoleculeObject
     24class GLMoleculeObject_bond : public GLMoleculeObject, public Observer
    2125{
    2226  Q_OBJECT
     
    2428  enum SideOfBond { left, right };
    2529
    26   GLMoleculeObject_bond(QObject *parent, const bond *bondref, double distance, enum SideOfBond side);
    27   virtual ~GLMoleculeObject_bond() {}
     30  GLMoleculeObject_bond(QObject *parent, const bond *bondref, const double distance, const enum SideOfBond side);
     31  virtual ~GLMoleculeObject_bond();
    2832
     33  // Observer functions
     34  void update(Observable *publisher);
     35  void subjectKilled(Observable *publisher);
     36  void recieveNotification(Observable *publisher, Notification_ptr notification);
     37
     38signals:
     39  void BondRemoved(const atomId_t leftnr, const atomId_t rightnr);
    2940
    3041private:
    3142  const bond *_bond;
     43  const enum SideOfBond BondSide;
    3244};
    3345
  • src/UIElements/Views/Qt4/Qt3D/GLWorldScene.cpp

    r3f7587 r2ad1ec  
    3939#include "World.hpp"
    4040
     41#include <iostream>
     42
    4143using namespace MoleCuilder;
     44
     45std::ostream &operator<<(std::ostream &ost, const GLWorldScene::BondIds &t)
     46{
     47  ost << t.first << "," << t.second;
     48  return ost;
     49}
    4250
    4351GLWorldScene::GLWorldScene(QObject *parent)
     
    7482
    7583        // create bond objects in scene
    76         bondsChanged(*atomiter);
     84        const BondList &bondlist = (*atomiter)->getListOfBonds();
     85        for (BondList::const_iterator bonditer = bondlist.begin();
     86            bonditer != bondlist.end();
     87            ++bonditer) {
     88          const bond *_bond = *bonditer;
     89          const GLMoleculeObject_bond::SideOfBond side = (_bond->leftatom == *atomiter) ?
     90              GLMoleculeObject_bond::left : GLMoleculeObject_bond::right;
     91          bondInserted(_bond, side);
     92        }
    7793      }
    7894    }
     
    94110  connect (atomObject, SIGNAL(clicked(atomId_t)), this, SLOT(atomClicked(atomId_t)));
    95111  connect (atomObject, SIGNAL(hoverChanged()), this, SIGNAL(changed()));
    96   connect (atomObject, SIGNAL(BondsChanged(const atom *)), this, SLOT(bondsChanged(const atom *)));
    97   bondsChanged(_atom);
     112  connect (atomObject, SIGNAL(BondsInserted(const bond *, const GLMoleculeObject_bond::SideOfBond)), this, SLOT(bondInserted(const bond *, const GLMoleculeObject_bond::SideOfBond)));
     113  //bondsChanged(_atom);
    98114  emit changeOccured();
    99115}
     
    106122{
    107123  LOG(3, "INFO: GLWorldScene: Received signal atomRemoved for atom "+toString(_atom->getId())+".");
    108   // remove all its bonds
    109   const BondList& bondlist = _atom->getListOfBonds();
    110   for (BondList::const_iterator iter = bondlist.begin(); iter != bondlist.end(); ++iter) {
    111     bondRemoved((*iter)->leftatom->getId(), (*iter)->rightatom->getId());
    112     bondRemoved((*iter)->rightatom->getId(), (*iter)->leftatom->getId());
    113   }
     124  // bonds are removed by signal coming from ~bond
    114125  // remove atoms
    115126  AtomNodeMap::iterator iter = AtomsinSceneMap.find(_atom->getId());
     
    123134}
    124135
    125 /** Updates the bond structure of the signaled \a _atom.
    126  *
    127  * @param _atom atom whose bonds changed.
    128  */
    129 void GLWorldScene::bondsChanged(const atom *_atom)
    130 {
    131   const atomId_t id = _atom->getId();
    132 
    133   // create list with all present bonds
    134   std::set< atomId_t > presentBonds;
    135   std::pair< BondIdsMap::const_iterator, BondIdsMap::const_iterator> range =
    136       BondIdsinSceneMap.equal_range( id );
    137   for (BondIdsMap::const_iterator iter = range.first; iter != range.second; ++iter) {
    138     const atomId_t otherid = iter->second;
    139 #ifndef NDEBUG
    140     std::set< atomId_t >::const_iterator iter = presentBonds.find(otherid);
    141     ASSERT(iter == presentBonds.end(),
    142         "GLWorldScene::BondsChanged() - bond id "+toString(otherid)+" for atom "
    143         +toString(id)+" present twice.");
    144 #endif
    145     presentBonds.insert( otherid );
    146   }
    147   LOG(3, "INFO: We have the following bonds: "+toString(presentBonds)+".");
    148 
    149   // search for added bonds
    150   const BondList &bondlist = _atom->getListOfBonds();
    151   for (BondList::const_iterator bonditer = bondlist.begin();
    152       bonditer != bondlist.end();
    153       ++bonditer) {
    154     const bond *_bond = *bonditer;
    155     const atomId_t otherid = _bond->GetOtherAtom(_atom)->getId();
    156     const BondIds ids = std::make_pair( id, otherid );
    157     BondNodeMap::const_iterator iter = BondsinSceneMap.find(ids);
    158     if (iter != BondsinSceneMap.end()) {
    159       // bond is already present
    160       std::set< atomId_t >::const_iterator iter = presentBonds.find(otherid);
    161       ASSERT(iter != presentBonds.end(),
    162           "GLWorldScene::BondsChanged() - other id "+toString(otherid)+" for atom "
    163           +toString(_atom->getId())+" not present in BondIdsinSceneMap.");
    164       presentBonds.erase(otherid);
    165       LOG(0, "Removing "+toString(otherid)+" from presentBonds.");
    166     } else {
    167       // insert new bond
    168       bondInserted(_bond);
    169     }
    170   }
    171   if (!presentBonds.empty())
    172     ELOG(2, "The following bonds should not be present: "+toString(presentBonds)+".");
    173 
    174   // remove all still presentBonds
    175   for (std::set< atomId_t >::iterator iter = presentBonds.begin();
    176       !presentBonds.empty(); iter = presentBonds.begin()) {
    177     bondRemoved( id, *iter );
    178   }
    179 }
    180 
    181136/** Adds a bond to the scene.
    182137 *
    183138 * @param _bond bond to add
    184  */
    185 void GLWorldScene::bondInserted(const bond *_bond)
     139 * @param side which side of the bond (left or right)
     140 */
     141void GLWorldScene::bondInserted(const bond *_bond, const enum GLMoleculeObject_bond::SideOfBond side)
    186142{
    187143  LOG(3, "INFO: GLWorldScene::bondInserted() - Adding bond "+toString(*_bond)+".");
     144  //LOG(4, "INFO: Currently present bonds " << BondsinSceneMap << ".");
    188145  const double distance =
    189146      _bond->leftatom->getPosition().distance(_bond->rightatom->getPosition())/2.;
    190   {
    191     // left bond
    192     const BondIds Leftids( make_pair(_bond->leftatom->getId(), _bond->rightatom->getId()) );
    193     BondNodeMap::iterator iter = BondsinSceneMap.find(Leftids);
    194     ASSERT(iter == BondsinSceneMap.end(),
    195         "GLWorldScene::bondAdded() - same left-sided bond "+toString(*_bond)+" added again.");
    196     GLMoleculeObject_bond *bondObject =
    197         new GLMoleculeObject_bond(this, _bond, distance, GLMoleculeObject_bond::left);
    198     BondsinSceneMap.insert( make_pair(Leftids, bondObject) );
    199     BondIdsinSceneMap.insert( Leftids );
     147
     148  BondIds ids;
     149  switch (side) {
     150    case GLMoleculeObject_bond::left:
     151      ids = std::make_pair(_bond->leftatom->getId(), _bond->rightatom->getId());
     152      break;
     153    case GLMoleculeObject_bond::right:
     154      ids = std::make_pair(_bond->rightatom->getId(), _bond->leftatom->getId());
     155      break;
    200156  }
    201   {
    202     // right bond
    203     const BondIds Rightids( make_pair(_bond->rightatom->getId(), _bond->leftatom->getId()) );
    204     BondNodeMap::iterator iter = BondsinSceneMap.find(Rightids);
    205     ASSERT(iter == BondsinSceneMap.end(),
    206         "GLWorldScene::bondAdded() - same right-sided bond "+toString(*_bond)+" added again.");
    207     GLMoleculeObject_bond *bondObject =
    208         new GLMoleculeObject_bond(this, _bond, distance, GLMoleculeObject_bond::right);
    209     BondsinSceneMap.insert( make_pair(Rightids, bondObject) );
    210     BondIdsinSceneMap.insert( Rightids );
    211   }
     157#ifndef NDEBUG
     158  BondNodeMap::iterator iter = BondsinSceneMap.find(ids);
     159  ASSERT(iter == BondsinSceneMap.end(),
     160      "GLWorldScene::bondAdded() - same left-sided bond "+toString(*_bond)+" added again.");
     161#endif
     162  GLMoleculeObject_bond *bondObject =
     163      new GLMoleculeObject_bond(this, _bond, distance, side);
     164  connect (
     165      bondObject, SIGNAL(BondRemoved(const atomId_t, const atomId_t)),
     166      this, SLOT(bondRemoved(const atomId_t, const atomId_t)));
     167  BondsinSceneMap.insert( make_pair(ids, bondObject) );
     168//    BondIdsinSceneMap.insert( Leftids );
    212169  emit changeOccured();
    213170}
     
    219176void GLWorldScene::bondRemoved(const atomId_t leftnr, const atomId_t rightnr)
    220177{
    221   LOG(3, "INFO: GLWorldScene::bondRemoved() - Removing bond between "+toString(leftnr)+" and "+toString(leftnr)+".");
     178  LOG(3, "INFO: GLWorldScene::bondRemoved() - Removing bond between "+toString(leftnr)+" and "+toString(rightnr)+".");
    222179  {
    223180    // left bond
     
    227184        "GLWorldScene::bondRemoved() - bond "+toString(leftnr)+"-"
    228185        +toString(rightnr)+" not on display.");
    229     GLMoleculeObject_bond *bondObject = leftiter->second;
     186    //GLMoleculeObject_bond *bondObject = leftiter->second;
    230187    BondsinSceneMap.erase(leftiter);
    231     delete bondObject;
     188    //delete bondObject; // is done by signal from bond itself
     189    //LOG(4, "INFO: Still present bonds " << BondsinSceneMap << ".");
    232190  }
    233   // remove from bond ids
    234   std::pair<BondIdsMap::iterator, BondIdsMap::iterator> leftrange =
    235       BondIdsinSceneMap.equal_range(leftnr);
    236   BondIdsMap::iterator iter;
    237   for (iter = leftrange.first; iter != leftrange.second; ++iter) {
    238     if (iter->second == rightnr) {
    239       BondIdsinSceneMap.erase(iter);
    240       break;
    241     }
    242   }
    243   ASSERT(iter != leftrange.second,
    244       "GLWorldScene::bondRemoved() - could not find ("
    245       +toString(leftnr)+"-"+toString(rightnr)+" in BondIdsinSceneMap.");
     191
    246192  emit changeOccured();
    247193}
  • src/UIElements/Views/Qt4/Qt3D/GLWorldScene.hpp

    r3f7587 r2ad1ec  
    2020#include "molecule.hpp"
    2121
     22#include <iosfwd>
     23
     24#include "GLMoleculeObject_bond.hpp"
     25
    2226class atom;
    2327
     
    2832class GLMoleculeObject;
    2933class GLMoleculeObject_atom;
    30 class GLMoleculeObject_bond;
    3134
    3235/** This class contains a list of all molecules in the world.
     
    6568  void atomInserted(const atom *_atom);
    6669  void atomRemoved(const atom *_atom);
    67   void bondsChanged(const atom *_atom);
     70  void bondInserted(const bond *_bond, const GLMoleculeObject_bond::SideOfBond side);
     71  void bondRemoved(const atomId_t leftnr, const atomId_t rightnr);
    6872
    6973private:
    7074  void init();
    71   void bondInserted(const bond *_bond);
    72   void bondRemoved(const atomId_t leftnr, const atomId_t rightnr);
    7375
     76private:
    7477  typedef std::pair< atomId_t, atomId_t> BondIds;
     78  friend std::ostream &operator<<(std::ostream &ost, const BondIds &t);
     79
    7580  typedef std::map< atomId_t, GLMoleculeObject_atom* > AtomNodeMap;
    7681  typedef std::map< BondIds , GLMoleculeObject_bond* > BondNodeMap;
    77   typedef std::multimap< atomId_t, atomId_t > BondIdsMap;
    7882  AtomNodeMap AtomsinSceneMap;
    79   BondIdsMap BondIdsinSceneMap;
    8083  BondNodeMap BondsinSceneMap;
    8184};
    8285
    83 
     86std::ostream &operator<<(std::ostream &ost, const GLWorldScene::BondIds &t);
    8487
    8588#endif /* GLWORLDSCENE_HPP_ */
Note: See TracChangeset for help on using the changeset viewer.