1e5c31af7Sopenharmony_ci/*-------------------------------------------------------------------------
2e5c31af7Sopenharmony_ci * drawElements C++ Base Library
3e5c31af7Sopenharmony_ci * -----------------------------
4e5c31af7Sopenharmony_ci *
5e5c31af7Sopenharmony_ci * Copyright 2014 The Android Open Source Project
6e5c31af7Sopenharmony_ci *
7e5c31af7Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
8e5c31af7Sopenharmony_ci * you may not use this file except in compliance with the License.
9e5c31af7Sopenharmony_ci * You may obtain a copy of the License at
10e5c31af7Sopenharmony_ci *
11e5c31af7Sopenharmony_ci *      http://www.apache.org/licenses/LICENSE-2.0
12e5c31af7Sopenharmony_ci *
13e5c31af7Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
14e5c31af7Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
15e5c31af7Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16e5c31af7Sopenharmony_ci * See the License for the specific language governing permissions and
17e5c31af7Sopenharmony_ci * limitations under the License.
18e5c31af7Sopenharmony_ci *
19e5c31af7Sopenharmony_ci *//*!
20e5c31af7Sopenharmony_ci * \file
21e5c31af7Sopenharmony_ci * \brief Utilities for STL containers.
22e5c31af7Sopenharmony_ci *//*--------------------------------------------------------------------*/
23e5c31af7Sopenharmony_ci
24e5c31af7Sopenharmony_ci#include "deSTLUtil.hpp"
25e5c31af7Sopenharmony_ci
26e5c31af7Sopenharmony_ci#include <map>
27e5c31af7Sopenharmony_ci#include <set>
28e5c31af7Sopenharmony_ci
29e5c31af7Sopenharmony_ciusing std::map;
30e5c31af7Sopenharmony_ciusing std::set;
31e5c31af7Sopenharmony_ci
32e5c31af7Sopenharmony_cinamespace de
33e5c31af7Sopenharmony_ci{
34e5c31af7Sopenharmony_ci
35e5c31af7Sopenharmony_civoid STLUtil_selfTest (void)
36e5c31af7Sopenharmony_ci{
37e5c31af7Sopenharmony_ci	{
38e5c31af7Sopenharmony_ci		map<int, int> m;
39e5c31af7Sopenharmony_ci		insert(m, 4, 5);
40e5c31af7Sopenharmony_ci		DE_TEST_ASSERT(contains(m, 4));
41e5c31af7Sopenharmony_ci		DE_TEST_ASSERT(lookup(m, 4) == 5);
42e5c31af7Sopenharmony_ci		DE_TEST_ASSERT(*tryLookup(m, 4) == 5);
43e5c31af7Sopenharmony_ci		DE_TEST_ASSERT(!contains(m, 3));
44e5c31af7Sopenharmony_ci		DE_TEST_ASSERT(tryLookup(m, 3) == DE_NULL);
45e5c31af7Sopenharmony_ci		DE_TEST_ASSERT(lookupDefault(m, 3, 7) == 7);
46e5c31af7Sopenharmony_ci	}
47e5c31af7Sopenharmony_ci
48e5c31af7Sopenharmony_ci	{
49e5c31af7Sopenharmony_ci		set<int> s1;
50e5c31af7Sopenharmony_ci		s1.insert(2);
51e5c31af7Sopenharmony_ci		s1.insert(3);
52e5c31af7Sopenharmony_ci		DE_TEST_ASSERT(contains(s1, 2));
53e5c31af7Sopenharmony_ci		DE_TEST_ASSERT(contains(s1, 3));
54e5c31af7Sopenharmony_ci		DE_TEST_ASSERT(!contains(s1, 5));
55e5c31af7Sopenharmony_ci
56e5c31af7Sopenharmony_ci		set<int> s2;
57e5c31af7Sopenharmony_ci		s2.insert(3);
58e5c31af7Sopenharmony_ci		s2.insert(5);
59e5c31af7Sopenharmony_ci		DE_TEST_ASSERT(!contains(s2, 2));
60e5c31af7Sopenharmony_ci		DE_TEST_ASSERT(contains(s2, 3));
61e5c31af7Sopenharmony_ci		DE_TEST_ASSERT(contains(s2, 5));
62e5c31af7Sopenharmony_ci
63e5c31af7Sopenharmony_ci		set<int> si = intersection(s1, s2);
64e5c31af7Sopenharmony_ci		DE_TEST_ASSERT(!contains(si, 2));
65e5c31af7Sopenharmony_ci		DE_TEST_ASSERT(contains(si, 3));
66e5c31af7Sopenharmony_ci		DE_TEST_ASSERT(!contains(si, 5));
67e5c31af7Sopenharmony_ci
68e5c31af7Sopenharmony_ci		set<int> su = set_union(s1, s2);
69e5c31af7Sopenharmony_ci		DE_TEST_ASSERT(contains(su, 2));
70e5c31af7Sopenharmony_ci		DE_TEST_ASSERT(contains(su, 3));
71e5c31af7Sopenharmony_ci		DE_TEST_ASSERT(contains(su, 5));
72e5c31af7Sopenharmony_ci	}
73e5c31af7Sopenharmony_ci}
74e5c31af7Sopenharmony_ci
75e5c31af7Sopenharmony_ci}
76