[vector] Complete sorted_vector 5-methods

This commit is contained in:
Behdad Esfahbod 2021-11-01 21:49:32 -06:00
parent a28b5d03b5
commit 6f74d80ed1
2 changed files with 25 additions and 5 deletions

View File

@ -313,9 +313,16 @@ struct hb_vector_t
template <typename Type> template <typename Type>
struct hb_sorted_vector_t : hb_vector_t<Type> struct hb_sorted_vector_t : hb_vector_t<Type>
{ {
hb_sorted_vector_t () : hb_vector_t<Type> () {} hb_sorted_vector_t () = default;
~hb_sorted_vector_t () = default;
hb_sorted_vector_t (hb_sorted_vector_t& o) = default;
hb_sorted_vector_t (hb_sorted_vector_t &&o) = default;
hb_sorted_vector_t (std::initializer_list<Type> lst) : hb_vector_t<Type> (lst) {} hb_sorted_vector_t (std::initializer_list<Type> lst) : hb_vector_t<Type> (lst) {}
hb_sorted_vector_t (hb_sorted_vector_t& o) : hb_vector_t<Type> (o) {} template <typename Iterable,
hb_requires (hb_is_iterable (Iterable))>
hb_sorted_vector_t (const Iterable &o) : hb_vector_t<Type> (o) {}
hb_sorted_vector_t& operator = (const hb_sorted_vector_t &o) = default;
hb_sorted_vector_t& operator = (hb_sorted_vector_t &&o) = default;
friend void swap (hb_sorted_vector_t& a, hb_sorted_vector_t& b) friend void swap (hb_sorted_vector_t& a, hb_sorted_vector_t& b)
{ hb_swap ((hb_vector_t<Type>&) (a), (hb_vector_t<Type>&) (b)); } { hb_swap ((hb_vector_t<Type>&) (a), (hb_vector_t<Type>&) (b)); }

View File

@ -36,6 +36,7 @@ main (int argc, char **argv)
{ {
hb_vector_t<int> v1 {1, 2}; hb_vector_t<int> v1 {1, 2};
hb_vector_t<int> v2 {v1}; hb_vector_t<int> v2 {v1};
hb_vector_t<int> V2 {v1};
assert (v1.length == 2); assert (v1.length == 2);
assert (v1[0] == 1); assert (v1[0] == 1);
assert (v1[1] == 2); assert (v1[1] == 2);
@ -48,6 +49,7 @@ main (int argc, char **argv)
{ {
hb_vector_t<int> v1 {1, 2}; hb_vector_t<int> v1 {1, 2};
hb_vector_t<int> v2 = v1; hb_vector_t<int> v2 = v1;
hb_vector_t<int> V2 = v1;
assert (v1.length == 2); assert (v1.length == 2);
assert (v1[0] == 1); assert (v1[0] == 1);
assert (v1[1] == 2); assert (v1[1] == 2);
@ -59,6 +61,7 @@ main (int argc, char **argv)
/* Test move constructor. */ /* Test move constructor. */
{ {
hb_vector_t<int> v {hb_vector_t<int> {1, 2}}; hb_vector_t<int> v {hb_vector_t<int> {1, 2}};
hb_vector_t<int> V {hb_vector_t<int> {1, 2}};
assert (v.length == 2); assert (v.length == 2);
assert (v[0] == 1); assert (v[0] == 1);
assert (v[1] == 2); assert (v[1] == 2);
@ -67,12 +70,14 @@ main (int argc, char **argv)
/* Test move assignment. */ /* Test move assignment. */
{ {
hb_vector_t<int> v; hb_vector_t<int> v;
hb_sorted_vector_t<int> V;
v = hb_vector_t<int> {1, 2}; v = hb_vector_t<int> {1, 2};
V = hb_sorted_vector_t<int> {1, 2};
assert (v.length == 2); assert (v.length == 2);
assert (v[0] == 1); assert (v[0] == 1);
assert (v[1] == 2); assert (v[1] == 2);
} }
/* Test initializing vector from iterable. */ /* Test initializing from iterable. */
{ {
hb_set_t s; hb_set_t s;
@ -80,13 +85,17 @@ main (int argc, char **argv)
s.add (12); s.add (12);
hb_vector_t<int> v (s); hb_vector_t<int> v (s);
hb_sorted_vector_t<int> V (s);
assert (v.length == 2); assert (v.length == 2);
assert (V.length == 2);
assert (v[0] == 12); assert (v[0] == 12);
assert (V[0] == 12);
assert (v[1] == 18); assert (v[1] == 18);
assert (V[1] == 18);
} }
/* Test initializing vector from iterator. */ /* Test initializing from iterator. */
{ {
hb_set_t s; hb_set_t s;
@ -94,13 +103,17 @@ main (int argc, char **argv)
s.add (12); s.add (12);
hb_vector_t<int> v (hb_iter (s)); hb_vector_t<int> v (hb_iter (s));
hb_vector_t<int> V (hb_iter (s));
assert (v.length == 2); assert (v.length == 2);
assert (V.length == 2);
assert (v[0] == 12); assert (v[0] == 12);
assert (V[0] == 12);
assert (v[1] == 18); assert (v[1] == 18);
assert (V[1] == 18);
} }
/* Test initializing vector from initializer list and swapping. */ /* Test initializing from initializer list and swapping. */
{ {
hb_vector_t<int> v1 {1, 2, 3}; hb_vector_t<int> v1 {1, 2, 3};
hb_vector_t<int> v2 {4, 5}; hb_vector_t<int> v2 {4, 5};