1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
|
#[derive(Debug, Clone)]
#[doc(hidden)]
pub struct StringVec {
vec: Vec<String>,
}
impl std::ops::Deref for StringVec {
type Target = Vec<String>;
fn deref(&self) -> &Self::Target {
&self.vec
}
}
impl From<StringVec> for Vec<String> {
fn from(val: StringVec) -> Self {
val.vec
}
}
impl<const N: usize> From<[&str; N]> for StringVec {
fn from(slice: [&str; N]) -> Self {
StringVec {
vec: slice.iter().map(|&s| s.to_string()).collect(),
}
}
}
impl From<&[&str]> for StringVec {
fn from(slice: &[&str]) -> Self {
StringVec {
vec: slice.iter().map(|&s| s.to_string()).collect(),
}
}
}
impl From<Vec<String>> for StringVec {
fn from(vec: Vec<String>) -> Self {
StringVec { vec }
}
}
impl From<&[String]> for StringVec {
fn from(slice: &[String]) -> Self {
StringVec {
vec: slice.to_vec(),
}
}
}
impl From<Vec<&str>> for StringVec {
fn from(vec: Vec<&str>) -> Self {
StringVec {
vec: vec.iter().map(|&s| s.to_string()).collect(),
}
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn test_string_vec_from_array() {
let sv = StringVec::from(["a", "b", "c"]);
assert_eq!(sv.vec, vec!["a", "b", "c"]);
}
#[test]
fn test_string_vec_from_slice_ref() {
let arr = ["x", "y"];
let sv = StringVec::from(&arr[..]);
assert_eq!(sv.vec, vec!["x", "y"]);
}
#[test]
fn test_string_vec_from_vec_string() {
let original = vec!["one".to_string(), "two".to_string()];
let sv = StringVec::from(original.clone());
assert_eq!(sv.vec, original);
}
#[test]
fn test_string_vec_from_slice_string() {
let original = vec!["a".to_string(), "b".to_string()];
let sv = StringVec::from(&original[..]);
assert_eq!(sv.vec, original);
}
#[test]
fn test_string_vec_from_vec_str() {
let sv = StringVec::from(vec!["hello", "world"]);
assert_eq!(sv.vec, vec!["hello", "world"]);
}
#[test]
fn test_string_vec_deref() {
let sv = StringVec::from(["alpha", "beta"]);
let inner: &Vec<String> = &*sv;
assert_eq!(inner.len(), 2);
assert_eq!(inner[0], "alpha");
}
#[test]
fn test_string_vec_into_vec() {
let sv = StringVec::from(["foo", "bar"]);
let v: Vec<String> = sv.into();
assert_eq!(v, vec!["foo", "bar"]);
}
#[test]
fn test_string_vec_empty_from_empty_array() {
let sv = StringVec::from([] as [&str; 0]);
assert!(sv.vec.is_empty());
}
}
|