xref: /llvm-project/libcxx/test/std/containers/associative/set/count.pass.cpp (revision cc89063bff0f73ec7049a1dcb5d4688ae6806941)
15a83710eSEric Fiselier //===----------------------------------------------------------------------===//
25a83710eSEric Fiselier //
357b08b09SChandler Carruth // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
457b08b09SChandler Carruth // See https://llvm.org/LICENSE.txt for license information.
557b08b09SChandler Carruth // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
65a83710eSEric Fiselier //
75a83710eSEric Fiselier //===----------------------------------------------------------------------===//
85a83710eSEric Fiselier 
95a83710eSEric Fiselier // <set>
105a83710eSEric Fiselier 
115a83710eSEric Fiselier // class set
125a83710eSEric Fiselier 
135a83710eSEric Fiselier // size_type count(const key_type& k) const;
145a83710eSEric Fiselier 
155a83710eSEric Fiselier #include <set>
165a83710eSEric Fiselier #include <cassert>
175a83710eSEric Fiselier 
180f901c7eSStephan T. Lavavej #include "test_macros.h"
195a83710eSEric Fiselier #include "min_allocator.h"
20*cc89063bSNico Weber #include "private_constructor.h"
215a83710eSEric Fiselier 
main(int,char **)222df59c50SJF Bastien int main(int, char**)
235a83710eSEric Fiselier {
245a83710eSEric Fiselier     {
255a83710eSEric Fiselier         typedef int V;
265a83710eSEric Fiselier         typedef std::set<int> M;
275a83710eSEric Fiselier         typedef M::size_type R;
285a83710eSEric Fiselier         V ar[] =
295a83710eSEric Fiselier         {
305a83710eSEric Fiselier             5,
315a83710eSEric Fiselier             6,
325a83710eSEric Fiselier             7,
335a83710eSEric Fiselier             8,
345a83710eSEric Fiselier             9,
355a83710eSEric Fiselier             10,
365a83710eSEric Fiselier             11,
375a83710eSEric Fiselier             12
385a83710eSEric Fiselier         };
395a83710eSEric Fiselier         const M m(ar, ar+sizeof(ar)/sizeof(ar[0]));
405a83710eSEric Fiselier         R r = m.count(5);
415a83710eSEric Fiselier         assert(r == 1);
425a83710eSEric Fiselier         r = m.count(6);
435a83710eSEric Fiselier         assert(r == 1);
445a83710eSEric Fiselier         r = m.count(7);
455a83710eSEric Fiselier         assert(r == 1);
465a83710eSEric Fiselier         r = m.count(8);
475a83710eSEric Fiselier         assert(r == 1);
485a83710eSEric Fiselier         r = m.count(9);
495a83710eSEric Fiselier         assert(r == 1);
505a83710eSEric Fiselier         r = m.count(10);
515a83710eSEric Fiselier         assert(r == 1);
525a83710eSEric Fiselier         r = m.count(11);
535a83710eSEric Fiselier         assert(r == 1);
545a83710eSEric Fiselier         r = m.count(12);
555a83710eSEric Fiselier         assert(r == 1);
565a83710eSEric Fiselier         r = m.count(4);
575a83710eSEric Fiselier         assert(r == 0);
585a83710eSEric Fiselier     }
59f2f2a639SEric Fiselier #if TEST_STD_VER >= 11
605a83710eSEric Fiselier     {
615a83710eSEric Fiselier         typedef int V;
625a83710eSEric Fiselier         typedef std::set<int, std::less<int>, min_allocator<int>> M;
635a83710eSEric Fiselier         typedef M::size_type R;
645a83710eSEric Fiselier         V ar[] =
655a83710eSEric Fiselier         {
665a83710eSEric Fiselier             5,
675a83710eSEric Fiselier             6,
685a83710eSEric Fiselier             7,
695a83710eSEric Fiselier             8,
705a83710eSEric Fiselier             9,
715a83710eSEric Fiselier             10,
725a83710eSEric Fiselier             11,
735a83710eSEric Fiselier             12
745a83710eSEric Fiselier         };
755a83710eSEric Fiselier         const M m(ar, ar+sizeof(ar)/sizeof(ar[0]));
765a83710eSEric Fiselier         R r = m.count(5);
775a83710eSEric Fiselier         assert(r == 1);
785a83710eSEric Fiselier         r = m.count(6);
795a83710eSEric Fiselier         assert(r == 1);
805a83710eSEric Fiselier         r = m.count(7);
815a83710eSEric Fiselier         assert(r == 1);
825a83710eSEric Fiselier         r = m.count(8);
835a83710eSEric Fiselier         assert(r == 1);
845a83710eSEric Fiselier         r = m.count(9);
855a83710eSEric Fiselier         assert(r == 1);
865a83710eSEric Fiselier         r = m.count(10);
875a83710eSEric Fiselier         assert(r == 1);
885a83710eSEric Fiselier         r = m.count(11);
895a83710eSEric Fiselier         assert(r == 1);
905a83710eSEric Fiselier         r = m.count(12);
915a83710eSEric Fiselier         assert(r == 1);
925a83710eSEric Fiselier         r = m.count(4);
935a83710eSEric Fiselier         assert(r == 0);
945a83710eSEric Fiselier     }
955a83710eSEric Fiselier #endif
960f901c7eSStephan T. Lavavej #if TEST_STD_VER > 11
975a83710eSEric Fiselier     {
985a83710eSEric Fiselier         typedef int V;
995a83710eSEric Fiselier         typedef std::set<int, std::less<>> M;
1005a83710eSEric Fiselier         typedef M::size_type R;
1015a83710eSEric Fiselier         V ar[] =
1025a83710eSEric Fiselier         {
1035a83710eSEric Fiselier             5,
1045a83710eSEric Fiselier             6,
1055a83710eSEric Fiselier             7,
1065a83710eSEric Fiselier             8,
1075a83710eSEric Fiselier             9,
1085a83710eSEric Fiselier             10,
1095a83710eSEric Fiselier             11,
1105a83710eSEric Fiselier             12
1115a83710eSEric Fiselier         };
1125a83710eSEric Fiselier         const M m(ar, ar+sizeof(ar)/sizeof(ar[0]));
1135a83710eSEric Fiselier         R r = m.count(5);
1145a83710eSEric Fiselier         assert(r == 1);
1155a83710eSEric Fiselier         r = m.count(6);
1165a83710eSEric Fiselier         assert(r == 1);
1175a83710eSEric Fiselier         r = m.count(7);
1185a83710eSEric Fiselier         assert(r == 1);
1195a83710eSEric Fiselier         r = m.count(8);
1205a83710eSEric Fiselier         assert(r == 1);
1215a83710eSEric Fiselier         r = m.count(9);
1225a83710eSEric Fiselier         assert(r == 1);
1235a83710eSEric Fiselier         r = m.count(10);
1245a83710eSEric Fiselier         assert(r == 1);
1255a83710eSEric Fiselier         r = m.count(11);
1265a83710eSEric Fiselier         assert(r == 1);
1275a83710eSEric Fiselier         r = m.count(12);
1285a83710eSEric Fiselier         assert(r == 1);
1295a83710eSEric Fiselier         r = m.count(4);
1305a83710eSEric Fiselier         assert(r == 0);
1315a83710eSEric Fiselier     }
1325a83710eSEric Fiselier     {
1335a83710eSEric Fiselier     typedef PrivateConstructor V;
1345a83710eSEric Fiselier     typedef std::set<V, std::less<>> M;
1355a83710eSEric Fiselier         typedef M::size_type R;
1365a83710eSEric Fiselier 
1375a83710eSEric Fiselier     M m;
1385a83710eSEric Fiselier     m.insert ( V::make ( 5 ));
1395a83710eSEric Fiselier     m.insert ( V::make ( 6 ));
1405a83710eSEric Fiselier     m.insert ( V::make ( 7 ));
1415a83710eSEric Fiselier     m.insert ( V::make ( 8 ));
1425a83710eSEric Fiselier     m.insert ( V::make ( 9 ));
1435a83710eSEric Fiselier     m.insert ( V::make ( 10 ));
1445a83710eSEric Fiselier     m.insert ( V::make ( 11 ));
1455a83710eSEric Fiselier     m.insert ( V::make ( 12 ));
1465a83710eSEric Fiselier 
14741b4d6c8SEric Fiselier     const M& mc = m;
14841b4d6c8SEric Fiselier 
14941b4d6c8SEric Fiselier     R r = mc.count(5);
1505a83710eSEric Fiselier     assert(r == 1);
15141b4d6c8SEric Fiselier     r = mc.count(6);
1525a83710eSEric Fiselier     assert(r == 1);
15341b4d6c8SEric Fiselier     r = mc.count(7);
1545a83710eSEric Fiselier     assert(r == 1);
15541b4d6c8SEric Fiselier     r = mc.count(8);
1565a83710eSEric Fiselier     assert(r == 1);
15741b4d6c8SEric Fiselier     r = mc.count(9);
1585a83710eSEric Fiselier     assert(r == 1);
15941b4d6c8SEric Fiselier     r = mc.count(10);
1605a83710eSEric Fiselier     assert(r == 1);
16141b4d6c8SEric Fiselier     r = mc.count(11);
1625a83710eSEric Fiselier     assert(r == 1);
16341b4d6c8SEric Fiselier     r = mc.count(12);
1645a83710eSEric Fiselier     assert(r == 1);
16541b4d6c8SEric Fiselier     r = mc.count(4);
1665a83710eSEric Fiselier     assert(r == 0);
1675a83710eSEric Fiselier     }
1685a83710eSEric Fiselier #endif
1695a83710eSEric Fiselier 
1702df59c50SJF Bastien 
1712df59c50SJF Bastien   return 0;
1725a83710eSEric Fiselier }
173