Sese Framework
2.3.0
A cross-platform framework
Loading...
Searching...
No Matches
Bimap.h
Go to the documentation of this file.
1
// Copyright 2024 libsese
2
//
3
// Licensed under the Apache License, Version 2.0 (the "License");
4
// you may not use this file except in compliance with the License.
5
// You may obtain a copy of the License at
6
//
7
// http://www.apache.org/licenses/LICENSE-2.0
8
//
9
// Unless required by applicable law or agreed to in writing, software
10
// distributed under the License is distributed on an "AS IS" BASIS,
11
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
// See the License for the specific language governing permissions and
13
// limitations under the License.
14
19
20
#pragma once
21
22
#include <cstddef>
23
#include <map>
24
#include <initializer_list>
25
26
namespace
sese
{
27
31
template
<
class
K,
class
V>
32
class
Bimap
final {
33
public
:
34
using
BimapKeyType
= K;
35
using
BimapValueType
= V;
36
37
Bimap
() =
default
;
38
~Bimap
() =
default
;
39
Bimap
(
const
Bimap
&) =
default
;
40
Bimap
&
operator=
(
const
Bimap
&) =
default
;
41
Bimap
(
Bimap
&&) noexcept = default;
42
Bimap
&operator=(
Bimap
&&) noexcept = default;
43
44
Bimap
(const std::initializer_list<std::pair<
BimapKeyType
,
BimapValueType
>> &init) {
45
for
(
const
auto
&[key, value]: init) {
46
insert
(key, value);
47
}
48
}
49
50
decltype
(
auto
)
begin
()
const
{
return
first
.begin(); }
51
52
decltype
(
auto
)
end
()
const
{
return
first
.end(); }
53
54
void
insert
(
const
BimapKeyType
&key,
const
BimapValueType
&value) {
55
first
[key] = value;
56
second
[value] = key;
57
}
58
59
void
eraseByKey
(
const
BimapKeyType
&key) {
60
BimapValueType
value =
first
[key];
61
first
.erase(key);
62
second
.erase(value);
63
}
64
65
void
eraseByValue
(
const
BimapValueType
&value) {
66
BimapKeyType
key =
second
[value];
67
first
.erase(key);
68
second
.erase(value);
69
}
70
71
bool
tryEraseByKey
(
const
BimapKeyType
&key) {
72
if
(!
first
.contains(key))
return
false
;
73
eraseByKey
(key);
74
return
true
;
75
}
76
77
bool
tryEraseByValue
(
const
BimapValueType
&value) {
78
if
(!
second
.contains(value))
return
false
;
79
eraseByValue
(value);
80
return
true
;
81
}
82
83
bool
existByKey
(
const
BimapKeyType
&key)
const
{
84
return
first
.contains(key);
85
}
86
87
bool
existByValue
(
const
BimapValueType
&value)
const
{
88
return
second
.contains(value);
89
}
90
91
[[nodiscard]]
const
BimapValueType
&
getByKey
(
const
BimapKeyType
&key)
const
{
92
return
first
.at(key);
93
}
94
95
[[nodiscard]]
BimapValueType
&
getByKey
(
const
BimapKeyType
&key) {
96
return
first
.at(key);
97
}
98
99
[[nodiscard]]
const
BimapKeyType
&
getByValue
(
const
BimapValueType
&value)
const
{
100
return
second
.at(value);
101
}
102
103
[[nodiscard]]
BimapKeyType
&
getByValue
(
const
BimapValueType
&value) {
104
return
second
.at(value);
105
}
106
107
[[nodiscard]]
bool
empty
()
const
{
108
return
first
.empty();
109
}
110
111
[[nodiscard]]
size_t
size
()
const
{
112
return
first
.size();
113
}
114
115
void
clear
() {
116
first
.clear();
117
second
.clear();
118
}
119
120
private
:
121
std::map<BimapKeyType, BimapValueType>
first
{};
122
std::map<BimapValueType, BimapKeyType>
second
{};
123
};
124
}
// namespace sese
sese
container
Bimap.h
Generated on Tue Jan 7 2025 15:49:05 for Sese Framework by
1.11.0