- File:
-
- 1 edited
-
src/Descriptors/AtomDescriptor.cpp (modified) (4 diffs)
Legend:
- Unmodified
- Added
- Removed
-
src/Descriptors/AtomDescriptor.cpp
r6d574a r8cce2b 13 13 #include "World.hpp" 14 14 #include "atom.hpp" 15 #include "Patterns/ObservedContainer_impl.hpp" 15 16 16 17 #include <boost/bind.hpp> … … 20 21 using namespace std; 21 22 22 typedef World::AtomSet::i terator atoms_iter_t;23 typedef World::AtomSet::internal_iterator atoms_iter_t; 23 24 24 25 /************************ Forwarding object **************************************/ … … 73 74 74 75 atom* AtomDescriptor_impl::find() { 75 World::AtomSet atoms = getAtoms();76 atoms_iter_t res = find_if(atoms.begin (),atoms.end(),boost::bind(&AtomDescriptor_impl::predicate,this,_1));77 return (res!=atoms.end ())?((*res).second):0;76 World::AtomSet &atoms = getAtoms(); 77 atoms_iter_t res = find_if(atoms.begin_internal(),atoms.end_internal(),boost::bind(&AtomDescriptor_impl::predicate,this,_1)); 78 return (res!=atoms.end_internal())?((*res).second):0; 78 79 } 79 80 … … 81 82 vector<atom*> res; 82 83 World::AtomSet atoms = getAtoms(); 83 atoms_iter_t iter; 84 for(iter=atoms.begin();iter!=atoms.end();++iter) { 85 if(predicate(*iter)){ 86 res.push_back((*iter).second); 87 } 84 for_each(atoms.begin_internal(), 85 atoms.end_internal(), 86 boost::bind(&AtomDescriptor_impl::checkAndAdd, 87 this,&res,_1)); 88 return res; 89 } 90 91 void AtomDescriptor_impl::checkAndAdd(std::vector<atom*> *v,std::pair<atomId_t,atom*> p){ 92 if(predicate(p)){ 93 v->push_back(p.second); 88 94 } 89 return res;90 95 } 91 96
Note:
See TracChangeset
for help on using the changeset viewer.
