automotive-message-broker  0.14.803
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Groups Pages
listplusplus.h
1 /*
2  Copyright (C) 2012 Intel Corporation
3 
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.
8 
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.
13 
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
17 */
18 
19 
20 #ifndef LISTPLUSPLUS_H
21 #define LISTPLUSPLUS_H
22 
23 #include <list>
24 #include <algorithm>
25 #include <functional>
26 
27 template <class T, class V, class Predicate>
28 bool contains(const T & iteratable, V value, Predicate comparator )
29 {
30  return std::any_of(iteratable.begin(), iteratable.end(), [value, &comparator](auto i) { return comparator(value, i); });
31 }
32 
33 template <class T, class V>
34 bool contains(const T & iteratable, V value)
35 {
36  return contains(iteratable, value, [](auto a, auto b) { return a == b; });
37 }
38 
39 
40 template <class T, class V>
41 void removeOne(T * iteratable, V value)
42 {
43  typename T::iterator itr = std::find(iteratable->begin(), iteratable->end(), value);
44 
45  if (itr != iteratable->end())
46  {
47  iteratable->erase(itr);
48  }
49 }
50 
51 namespace amb
52 {
53 template <class T, class Key>
54 bool containsKey(const T & map, const Key & key)
55 {
56  return map.find(key) != map.end();
57 }
58 
59 std::string::size_type count(const std::string & t, const std::string & toFind, const std::string & before = "");
60 
61 int findNth(const std::string & t, const std::string &toFind, std::string::size_type n);
62 
63 }
64 
65 #endif // LISTPLUSPLUS_H