// ************************************************************************* // // Copyleft 2004-2007 Bruno PAGES . // // This file is part of the BOUML Uml Toolkit. // // This program 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. // // This program 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 this program; if not, write to the Free Software // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. // // e-mail : bouml@free.fr // home : http://bouml.free.fr // // ************************************************************************* #ifndef MULTIPLEDEPENDENCY_H #define MULTIPLEDEPENDENCY_H #include class BasicData; template class MultipleDependencyIterator; #ifdef __SUNPRO_CC #define TYPENAME #else #define TYPENAME typename #endif template class MultipleDependency { friend class MultipleDependencyIterator; protected: QMap map; public: MultipleDependency() {}; bool subscribe(const K *); bool unsubscribe(const K *); void unsubscribe_all() { map.clear(); }; }; template bool MultipleDependency::subscribe(const K * k) { if (map.contains(k)) { map[k] += 1; return FALSE; } else { map.insert(k, 1); return TRUE; } } template bool MultipleDependency::unsubscribe(const K * k) { if (map.contains(k) && ((map[k] -= 1) == 0)) { map.remove(k); return TRUE; } else return FALSE; } template class MultipleDependencyIterator { protected: QMap & map; typedef TYPENAME QMap::Iterator Iter; Iter iter; public: MultipleDependencyIterator(MultipleDependency * m) : map(m->map), iter(m->map.begin()) { }; const K * current() const { return (iter == map.end()) ? 0 : iter.key(); }; void operator++() { iter++; }; }; #endif