Ignore:
File:
1 edited

Legend:

Unmodified
Added
Removed
  • src/Descriptors/MoleculeDescriptor.cpp

    r6d574a r8cce2b  
    1212
    1313#include "World.hpp"
     14#include "Patterns/ObservedContainer_impl.hpp"
    1415
    1516#include "molecule.hpp"
     
    2021using namespace std;
    2122
    22 typedef World::MoleculeSet::iterator molecules_iter_t;
     23typedef World::MoleculeSet::internal_iterator molecules_iter_t;
    2324
    2425/************************ Forwarding object **************************************/
     
    7374
    7475molecule* MoleculeDescriptor_impl::find() {
    75   World::MoleculeSet molecules = getMolecules();
    76   molecules_iter_t res = find_if(molecules.begin(),molecules.end(),boost::bind(&MoleculeDescriptor_impl::predicate,this,_1));
    77   return (res!=molecules.end())?((*res).second):0;
     76  World::MoleculeSet &molecules = getMolecules();
     77  molecules_iter_t res = find_if(molecules.begin_internal(),molecules.end_internal(),boost::bind(&MoleculeDescriptor_impl::predicate,this,_1));
     78  return (res!=molecules.end_internal())?((*res).second):0;
    7879}
    7980
    8081vector<molecule*> MoleculeDescriptor_impl::findAll() {
    8182  vector<molecule*> res;
    82   World::MoleculeSet molecules = getMolecules();
    83   molecules_iter_t iter;
    84   for(iter=molecules.begin();iter!=molecules.end();++iter) {
    85     if(predicate(*iter)){
    86       res.push_back((*iter).second);
    87     }
     83  World::MoleculeSet &molecules = getMolecules();
     84  for_each(molecules.begin_internal(),
     85           molecules.end_internal(),
     86           boost::bind(&MoleculeDescriptor_impl::checkAndAdd,
     87                       this,&res,_1));
     88  return res;
     89}
     90
     91void MoleculeDescriptor_impl::checkAndAdd(std::vector<molecule*> *v,std::pair<moleculeId_t,molecule*> p){
     92  if(predicate(p)){
     93    v->push_back(p.second);
    8894  }
    89   return res;
    9095}
    9196
Note: See TracChangeset for help on using the changeset viewer.