2 Copyright (C) 2012 Intel Corporation
4 This library is free software; you can redistribute it and/or
5 modify it under the terms of the GNU Lesser General Public
6 License as published by the Free Software Foundation; either
7 version 2.1 of the License, or (at your option) any later version.
9 This library is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 Lesser General Public License for more details.
14 You should have received a copy of the GNU Lesser General Public
15 License along with this library; if not, write to the Free Software
16 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20 #ifndef LISTPLUSPLUS_H
21 #define LISTPLUSPLUS_H
31 ListPlusPlus(std::list<T> *list)
38 void removeOne(T value)
40 typename std::list<T>::iterator itr = std::find(mList->begin(), mList->end(), value);
42 if (itr != mList->end())
48 bool contains(T value)
50 return (std::find(mList->begin(), mList->end(), value) != mList->end());
57 template <class T, class V>
58 bool contains(T iteratable, V value)
60 return (std::find(iteratable.begin(), iteratable.end(), value) != iteratable.end());
63 template <class T, class V>
64 void removeOne(T * iteratable, V value)
66 typename T::iterator itr = std::find(iteratable->begin(), iteratable->end(), value);
68 if (itr != iteratable->end())
70 iteratable->erase(itr);
74 #endif // LISTPLUSPLUS_H