/*
* Project: MoleCuilder
* Description: creates and alters molecular systems
* Copyright (C) 2012 University of Bonn. All rights reserved.
*
*
* This file is part of MoleCuilder.
*
* MoleCuilder is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 2 of the License, or
* (at your option) any later version.
*
* MoleCuilder is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with MoleCuilder. If not, see .
*/
/*
* AtomIdSet.cpp
*
* Created on: Feb 21, 2012
* Author: heber
*/
// include config.h
#ifdef HAVE_CONFIG_H
#include
#endif
#include "CodePatterns/MemDebug.hpp"
#include "AtomIdSet.hpp"
#include
#include "Atom/atom.hpp"
#include "Descriptors/AtomIdDescriptor.hpp"
#include "Fragmentation/KeySet.hpp"
#include "World.hpp"
atom * FromIdToAtom::operator()(atomId_t id) const {
return World::getInstance().getAtom(AtomById(id));
}
const atom * FromIdToConstAtom::operator()(atomId_t id) const {
return const_cast(World::getInstance()).getAtom(AtomById(id));
}
/** Constructor for class AtomIdSet.
*
* @param _atoms atoms to put into this set
*/
AtomIdSet::AtomIdSet(const atomIdSet &_atoms) :
atoms(_atoms)
{}
/** Constructor for class AtomIdSet.
*
* @param _keyset keyset to put into this set
*/
AtomIdSet::AtomIdSet(const KeySet &_keyset) :
atoms(atomIdSet(_keyset.begin(), _keyset.end()))
{}
/** Constructor for class AtomIdSet.
*
* @param _atoms atoms to put into this set
*/
AtomIdSet::AtomIdSet(const std::vector &_atoms)
{
BOOST_FOREACH(const atom * _atom, _atoms) {
insert(_atom->getId());
}
}
/** Constructor for class AtomIdSet.
*
*/
AtomIdSet::AtomIdSet()
{}
/** Destructor for class AtomIdSet.
*
*/
AtomIdSet::~AtomIdSet()
{}
/** Returns iterator to first atim via a transform_iterator.
*
* @return iterator to first atom in this set
*/
AtomIdSet::iterator AtomIdSet::begin(){
return iterator(atoms.begin(), FromIdToAtom());
}
/** Returns constant iterator to first atim via a transform_iterator.
*
* @return const iterator to first atom in this set
*/
AtomIdSet::const_iterator AtomIdSet::begin() const{
return const_iterator(atoms.begin(), FromIdToConstAtom());
}
/** Returns iterator to one beyond last atom via a transform_iterator.
*
* @return iterator to one beyond last atom in this set
*/
AtomIdSet::iterator AtomIdSet::end(){
return iterator(atoms.end(), FromIdToAtom());
}
/** Returns constant iterator to one beyond last atom via a transform_iterator.
*
* @return const iterator to one beyond last atom in this set
*/
AtomIdSet::const_iterator AtomIdSet::end() const{
return const_iterator(atoms.end(), FromIdToConstAtom());
}
/** Returns true if this set is empty.
*
* @return true - set is empty, false - there is at least one atom
*/
bool AtomIdSet::empty() const
{
return (atoms.empty());
}
/** Returns the number of members of this set.
*
* @return number of members in set
*/
size_t AtomIdSet::size() const
{
// set has unique members, hence just return its size
return atoms.size();
}
/** Predicate whether given atomic id is contained.
*
* @param id id to check
* @return true - is contained, false - is not
*/
bool AtomIdSet::contains(const atomId_t &id) const
{
return (atoms.find(id) != atoms.end());
}
/** Predicate whether given atom is contained.
*
* @param key atom to check
* @return true - is contained, false - is not
*/
bool AtomIdSet::contains(const atom * const key) const
{
return contains(key->getId());
}
/** Returns the iterator to the atom \a *key.
*
* @param key atom to find
* @return iterator to atom if found, to end() - else
*/
AtomIdSet::const_iterator AtomIdSet::find(const atom * const key) const
{
return find(key->getId());
}
/** Returns the iterator to the atom \a *key.
*
* @param id atomic id to find
* @return iterator to atom if found, to end() - else
*/
AtomIdSet::const_iterator AtomIdSet::find(const atomId_t &id) const
{
return const_iterator(atoms.find(id), FromIdToConstAtom());
}
/** Inserts a given atom into the set.
*
* @param key atom to insert
* @return pair of iterator and bool that states whether element is already present (true) or not (false)
*/
std::pair AtomIdSet::insert(const atom * const key)
{
std::pair iter =
atoms.insert(key->getId());
std::pair retiter (std::make_pair(iterator(iter.first), iter.second));
return retiter;
}
/** Inserts a given atom into the set.
*
* @param id atomic id to insert
* @return pair of iterator and bool that states whether element is already present (true) or not (false)
*/
std::pair AtomIdSet::insert(const atomId_t &id)
{
std::pair iter =
atoms.insert(id);
std::pair retiter (std::make_pair(iterator(iter.first), iter.second));
return retiter;
}
AtomIdSet::const_iterator AtomIdSet::erase(AtomIdSet::const_iterator &loc)
{
const_iterator iter = loc;
++iter;
atom * const _atom = const_cast(*loc);
atoms.erase( _atom->getId() );
return iter;
}
/** Erase an atom from the list.
*
* @param *key key to atom in list
* @return iterator to just after removed item (compliant with standard)
*/
AtomIdSet::const_iterator AtomIdSet::erase(const atom * const key)
{
const_iterator iter = const_cast(*this).find(key);
if (iter != const_cast(*this).end()){
++iter;
atoms.erase( key->getId() );
}
return iter;
}
/** Erase an atom from the list.
*
* @param id atomic id atom in list to erase
* @return iterator to just after removed item (compliant with standard)
*/
AtomIdSet::const_iterator AtomIdSet::erase(const atomId_t &id)
{
atomIdSet::const_iterator iter = atoms.find(id);
if (iter != atoms.end()){
++iter;
atoms.erase( id );
}
return const_iterator(iter, FromIdToConstAtom());
}